diff options
-rw-r--r-- | Source/cmMakefile.cxx | 23 | ||||
-rw-r--r-- | Source/cmMakefile.h | 4 |
2 files changed, 14 insertions, 13 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx index 2dbe07d..60af93b 100644 --- a/Source/cmMakefile.cxx +++ b/Source/cmMakefile.cxx @@ -866,29 +866,29 @@ int cmMakefile::DumpDocumentationToFile(std::ostream& f) } -void cmMakefile::ExpandVariablesInString(std::string& source) const +const char *cmMakefile::ExpandVariablesInString(std::string& source) const { - this->ExpandVariablesInString(source, false); + return this->ExpandVariablesInString(source, false); } -void cmMakefile::ExpandVariablesInString(std::string& source, +const char *cmMakefile::ExpandVariablesInString(std::string& source, bool escapeQuotes) const { // This method replaces ${VAR} and @VAR@ where VAR is looked up // in the m_Definitions map, if not found in the map, nothing is expanded. // It also supports the $ENV{VAR} syntax where VAR is looked up in // the current environment variables. - + // start by look for $ or @ in the string std::string::size_type markerPos = source.find_first_of("$@"); // if not found, or found as the last character, then leave quickly as // nothing needs to be expanded if((markerPos == std::string::npos) || (markerPos >= source.size()-1)) { - return; + return source.c_str(); } // current position - std::string::size_type currentPos =0; // start at 0 + std::string::size_type currentPos =0; // start at 0 std::string result; // string with replacements // go until the the end of the string while((markerPos != std::string::npos) && (markerPos < source.size()-1)) @@ -907,7 +907,7 @@ void cmMakefile::ExpandVariablesInString(std::string& source, markerStartSize = 2; } // $ENV{var} case - else if(markerPos+4 < source.size() && + else if(markerPos+4 < source.size() && source[markerPos+4] == '{' && !source.substr(markerPos+1, 3).compare("ENV")) { @@ -932,7 +932,7 @@ void cmMakefile::ExpandVariablesInString(std::string& source, { markerPos += markerStartSize; // move past marker // find the end variable marker starting at the markerPos - std::string::size_type endVariablePos = + std::string::size_type endVariablePos = source.find(endVariableMarker, markerPos); if(endVariablePos == std::string::npos) { @@ -955,7 +955,7 @@ void cmMakefile::ExpandVariablesInString(std::string& source, if (markerStartSize == 5) // $ENV{ { char *ptr = getenv(var.c_str()); - if (ptr) + if (ptr) { if (escapeQuotes) { @@ -985,7 +985,7 @@ void cmMakefile::ExpandVariablesInString(std::string& source, } } // if found add to result, if not, then it gets blanked - if (!found) + if (!found) { // if no definition is found then add the var back if(endVariableMarker == '@') @@ -1006,9 +1006,10 @@ void cmMakefile::ExpandVariablesInString(std::string& source, } } markerPos = source.find_first_of("$@", currentPos); - } + } result += source.substr(currentPos); // pick up the rest of the string source = result; + return source.c_str(); } void cmMakefile::RemoveVariablesInString(std::string& source) const diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h index 7161cc8..3b844fa 100644 --- a/Source/cmMakefile.h +++ b/Source/cmMakefile.h @@ -504,8 +504,8 @@ public: * entry in the m_Definitions map. Also @var@ is * expanded to match autoconf style expansions. */ - void ExpandVariablesInString(std::string& source) const; - void ExpandVariablesInString(std::string& source, bool escapeQuotes) const; + const char *ExpandVariablesInString(std::string& source) const; + const char *ExpandVariablesInString(std::string& source, bool escapeQuotes) const; /** * Remove any remaining variables in the string. Anything with ${var} or |