From 71af96aad1f9fc57cdf831207e9517514d238f16 Mon Sep 17 00:00:00 2001 From: Bill Hoffman Date: Mon, 14 Aug 2006 09:50:52 -0400 Subject: ENH: still escape () but do not escape --- Source/kwsys/SystemTools.cxx | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/Source/kwsys/SystemTools.cxx b/Source/kwsys/SystemTools.cxx index 19462af..7a7ae2c 100644 --- a/Source/kwsys/SystemTools.cxx +++ b/Source/kwsys/SystemTools.cxx @@ -1366,17 +1366,31 @@ kwsys_stl::string SystemTools::ConvertToUnixOutputPath(const char* path) { ret.erase(pos, 1); } - // now escape spaces if there is a space in the path + // escape spaces and () in the path if(ret.find_first_of(" ()") != kwsys_stl::string::npos) { kwsys_stl::string result = ""; char lastch = 1; + bool inDollarVariable = false; for(const char* ch = ret.c_str(); *ch != '\0'; ++ch) { // if it is already escaped then don't try to escape it again if((*ch == ' ' || *ch == '(' || *ch == ')') && lastch != '\\') { - result += '\\'; + if(*ch == '(' && lastch == '$') + { + inDollarVariable = true; + } + // if we are in a $(..... and we get a ) then do not escape + // the ) and but set inDollarVariable to false + else if(*ch == ')' && inDollarVariable) + { + inDollarVariable = false; + } + else + { + result += '\\'; + } } result += *ch; lastch = *ch; -- cgit v0.12