summaryrefslogtreecommitdiffstats
path: root/Source/cmSystemTools.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmSystemTools.cxx')
-rw-r--r--Source/cmSystemTools.cxx34
1 files changed, 31 insertions, 3 deletions
diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx
index 962cfe5..02b0274 100644
--- a/Source/cmSystemTools.cxx
+++ b/Source/cmSystemTools.cxx
@@ -94,6 +94,7 @@ inline int Chdir(const char* dir)
bool cmSystemTools::s_DisableRunCommandOutput = false;
bool cmSystemTools::s_ErrorOccured = false;
bool cmSystemTools::s_DisableMessages = false;
+cmSystemTools::PathMap cmSystemTools::s_PathMap;
void (*cmSystemTools::s_ErrorCallback)(const char*, const char*, bool&);
@@ -1176,6 +1177,7 @@ std::string cmSystemTools::GetCurrentWorkingDirectory()
{
char buf[2048];
std::string path = Getcwd(buf, 2048);
+ ApplyPathTranslation( path );
return path;
}
@@ -1237,6 +1239,7 @@ void cmSystemTools::SplitProgramPath(const char* in_name,
std::string cmSystemTools::CollapseFullPath(const char* in_name)
{
std::string dir, file;
+ std::string return_value;
cmSystemTools::SplitProgramPath(in_name, dir, file);
#ifdef _WIN32
// Ultra-hack warning:
@@ -1248,8 +1251,7 @@ std::string cmSystemTools::CollapseFullPath(const char* in_name)
Chdir(cwd.c_str());
cmSystemTools::ConvertToUnixSlashes(newDir);
- std::string newPath = newDir+"/"+file;
- return newPath;
+ return_value = newDir;
#else
# ifdef MAXPATHLEN
char resolved_name[MAXPATHLEN];
@@ -1269,8 +1271,13 @@ std::string cmSystemTools::CollapseFullPath(const char* in_name)
{
dir = cmSystemTools::GetCurrentWorkingDirectory();
}
- return dir + "/" + file;
+ return_value = dir;
#endif
+ if(file != "")
+ return_value += "/" + file;
+
+ ApplyPathTranslation( return_value );
+ return return_value;
}
/**
@@ -1424,3 +1431,24 @@ void cmSystemTools::GlobDirs(const char *fullPath,
}
}
}
+
+
+void cmSystemTools::AddPathTranslation( const std::string& from, const std::string& to )
+{
+ s_PathMap[from] = to;
+}
+
+void cmSystemTools::ApplyPathTranslation( std::string& path )
+{
+ PathMap::iterator i;
+
+ // For each key in the map, see if path starts with it. If so, perform the substitution.
+ for( i = s_PathMap.begin(); i != s_PathMap.end(); ++i )
+ {
+ if( path.substr( 0, i->first.length() ) == i->first )
+ {
+ path.replace( 0, i->first.length(), i->second );
+ return;
+ }
+ }
+}