diff options
author | Ken Martin <ken.martin@kitware.com> | 2004-10-04 16:31:09 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2004-10-04 16:31:09 (GMT) |
commit | 1066af45278f29e7a5f1b5ba3d7d12bce15719e4 (patch) | |
tree | 6beeea084d3bb262b2d9ada6c562a4ac7109e34c /Source | |
parent | 7e3c70082ae433e7793afad6d9a3366bf6c1e215 (diff) | |
download | CMake-1066af45278f29e7a5f1b5ba3d7d12bce15719e4.zip CMake-1066af45278f29e7a5f1b5ba3d7d12bce15719e4.tar.gz CMake-1066af45278f29e7a5f1b5ba3d7d12bce15719e4.tar.bz2 |
ENH: Mathieus support for path conversions
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmake.cxx | 26 | ||||
-rw-r--r-- | Source/cmake.h | 7 | ||||
-rw-r--r-- | Source/kwsys/SystemTools.cxx | 139 | ||||
-rw-r--r-- | Source/kwsys/SystemTools.hxx.in | 23 |
4 files changed, 160 insertions, 35 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index ae57145..37da3a9 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -40,6 +40,7 @@ #endif #include <stdlib.h> // required for atoi +#include <fstream> #ifdef __APPLE__ #include <sys/types.h> @@ -983,6 +984,9 @@ int cmake::DoPreConfigureChecks() int cmake::Configure() { + // Construct right now our path conversion table before it's too late: + this->UpdateConversionPathTable(); + int res = 0; if ( !m_ScriptMode ) { @@ -1506,3 +1510,25 @@ void cmake::CleanupWrittenFiles() { m_WrittenFiles.clear(); } + +void cmake::UpdateConversionPathTable() +{ + // Update the path conversion table with any specified file: + const char* tablepath = + m_CacheManager->GetCacheValue("CMAKE_PATH_TRANSLATION_FILE"); + + if(tablepath) + { + std::ifstream table( tablepath ); + std::string a, b; + if( table.is_open() && table.good() ) + { + while(!table.eof()) + { + // two entries per line + table >> a; table >> b; + cmSystemTools::AddTranslationPath( a.c_str(), b.c_str()); + } + } + } +} diff --git a/Source/cmake.h b/Source/cmake.h index 7f13f74..168d690 100644 --- a/Source/cmake.h +++ b/Source/cmake.h @@ -1,5 +1,3 @@ -#ifndef cmake_h -#define cmake_h /*========================================================================= Program: CMake - Cross-Platform Makefile Generator @@ -39,6 +37,9 @@ // +#ifndef cmake_h +#define cmake_h + #include "cmSystemTools.h" class cmGlobalGenerator; @@ -309,6 +310,8 @@ private: std::string m_CXXEnvironment; std::string m_CCEnvironment; bool m_DebugTryCompile; + + void UpdateConversionPathTable(); }; #define CMAKE_STANDARD_OPTIONS_TABLE \ diff --git a/Source/kwsys/SystemTools.cxx b/Source/kwsys/SystemTools.cxx index f08a50f..9488e56 100644 --- a/Source/kwsys/SystemTools.cxx +++ b/Source/kwsys/SystemTools.cxx @@ -68,6 +68,17 @@ inline int Chdir(const char* dir) return _chdir(dir); #endif } +inline char *Realpath(const char *path, char *resolved_path) +{ + char *ptemp; + char fullpath[MAX_PATH]; + if( GetFullPathName(path, sizeof(fullpath), fullpath, &ptemp) ) + { + return strcpy(resolved_path, fullpath); + } + + return 0; +} #else #include <sys/types.h> #include <fcntl.h> @@ -88,6 +99,10 @@ inline int Chdir(const char* dir) { return chdir(dir); } +inline char *Realpath(const char *path, char *resolved_path) +{ + return realpath(path, resolved_path); +} #endif #if !defined(_WIN32) && defined(__COMO__) @@ -753,12 +768,6 @@ void SystemTools::ConvertToUnixSlashes(kwsys_stl::string& path) path = kwsys_stl::string(getenv("HOME")) + path.substr(1); } } - - // if there is a /tmp_mnt in a path get rid of it! - if(path.find("/tmp_mnt") == 0) - { - path = path.substr(8); - } } // change // to /, and escape any spaces in the path @@ -1346,7 +1355,8 @@ kwsys_stl::string SystemTools::GetCurrentWorkingDirectory() { path = cwd; } - return path; + + return SystemTools::CollapseFullPath(path.c_str()); } kwsys_stl::string SystemTools::GetProgramPath(const char* in_name) @@ -1452,15 +1462,77 @@ kwsys_stl::string SystemTools::CollapseFullPath(const char* in_relative) return SystemTools::CollapseFullPath(in_relative, 0); } +kwsys_stl::map<kwsys_stl::string,kwsys_stl::string> SystemTools::TranslationMap; + +void SystemTools::AddTranslationPath(const char * a, const char * b) +{ + kwsys_stl::string path_a = a; + kwsys_stl::string path_b = b; + SystemTools::ConvertToUnixSlashes(path_a); + SystemTools::ConvertToUnixSlashes(path_b); + // First check this is a directory path, since we don't want the table to grow + // too fat + if( SystemTools::FileIsDirectory( path_a.c_str() ) ) + { + // Make sure the path is a full path and does not contain no '..' + if( SystemTools::FileIsFullPath(path_b.c_str()) && path_b.find("..") == kwsys_stl::string::npos ) + { + // Before inserting make sure path ends with '/' + path_a += '/'; path_b += '/'; + if( !(path_a == path_b) ) + { + TranslationMap.insert( + kwsys_stl::pair<kwsys_stl::string,kwsys_stl::string>(path_a, path_b)); + } + } + } +} + +void SystemTools::AddKeepPath(const char* dir) +{ + kwsys_stl::string cdir = SystemTools::CollapseFullPath(dir); + SystemTools::AddTranslationPath(cdir.c_str(), dir); +} + +void SystemTools::CheckTranslationPath(kwsys_stl::string & path) +{ + // In case a file was specified we still have to go through this: + // Now convert any path found in the table back to the one desired: + kwsys_stl::map<kwsys_stl::string,kwsys_stl::string>::const_iterator it; + for(it = TranslationMap.begin(); + it != TranslationMap.end(); + ++it ) + { + // We need to check of the path is a substring of the other path + // But also check that the last character is a '/' otherwise we could + // have some weird case such as /tmp/VTK and /tmp/VTK-bin + if(path.size() > 1 && path[path.size()-1] != '/') + { + // Do not append '/' on a program name: + if( SystemTools::FileIsDirectory( path.c_str() ) ) + { + path += "/"; + } + } + if(path.find( it->first ) == 0) + { + path = path.replace( 0, it->first.size(), it->second); + } + } +} + kwsys_stl::string SystemTools::CollapseFullPath(const char* in_relative, - const char* in_base) + const char* in_base) { - // Save original working directory. - kwsys_stl::string orig = SystemTools::GetCurrentWorkingDirectory(); + static int initialized = 0; + + kwsys_stl::string orig; // Change to base of relative path. if(in_base) { + // Save original working directory. + orig = SystemTools::GetCurrentWorkingDirectory(); Chdir(in_base); } @@ -1473,19 +1545,6 @@ kwsys_stl::string SystemTools::CollapseFullPath(const char* in_relative, dir = "/"; } -#ifdef _WIN32 - // Follow relative path. - if(!(dir == "")) - { - Chdir(dir.c_str()); - } - - // Get the resulting directory. - kwsys_stl::string newDir = SystemTools::GetCurrentWorkingDirectory(); - - // Add the file back on to the directory. - SystemTools::ConvertToUnixSlashes(newDir); -#else # ifdef MAXPATHLEN char resolved_name[MAXPATHLEN]; # else @@ -1493,29 +1552,26 @@ kwsys_stl::string SystemTools::CollapseFullPath(const char* in_relative, char resolved_name[PATH_MAX]; # else char resolved_name[5024]; -# endif -# endif +# endif //PATH_MAX +# endif //MAXPATHLEN // Resolve relative path. kwsys_stl::string newDir; if(!(dir == "")) { - realpath(dir.c_str(), resolved_name); + Realpath(dir.c_str(), resolved_name); newDir = resolved_name; } else { newDir = SystemTools::GetCurrentWorkingDirectory(); } - // if there is a /tmp_mnt in a path get rid of it! - if(newDir.find("/tmp_mnt") == 0) + + if(in_base) { - newDir = newDir.substr(8); + // Restore original working directory. + Chdir(orig.c_str()); } -#endif - - // Restore original working directory. - Chdir(orig.c_str()); // Construct and return the full path. kwsys_stl::string newPath = newDir; @@ -1527,6 +1583,23 @@ kwsys_stl::string SystemTools::CollapseFullPath(const char* in_relative, } newPath += file; } + + // If the table has never been initialized, add default path: + if(!initialized) + { + initialized = 1; + //Also add some good default one: + // This one should always be there it fix a bug on sgi + SystemTools::AddTranslationPath("/tmp_mnt/", "/"); + + //This is a good default also: + SystemTools::AddKeepPath("/tmp/"); + } + + // Now we need to update the translation table with this potentially new path + SystemTools::AddTranslationPath(newPath.c_str(), in_relative); + SystemTools::CheckTranslationPath(newPath); + return newPath; } diff --git a/Source/kwsys/SystemTools.hxx.in b/Source/kwsys/SystemTools.hxx.in index 1c48af7..128e0c2 100644 --- a/Source/kwsys/SystemTools.hxx.in +++ b/Source/kwsys/SystemTools.hxx.in @@ -17,6 +17,7 @@ #include <@KWSYS_NAMESPACE@/ios/iosfwd> #include <@KWSYS_NAMESPACE@/stl/string> #include <@KWSYS_NAMESPACE@/stl/vector> +#include <@KWSYS_NAMESPACE@/stl/map> #include <@KWSYS_NAMESPACE@/Configure.h> @@ -291,6 +292,22 @@ public: static int GetTerminalWidth(); /** + * Add an entry in the path translation table. + */ + static void AddTranslationPath(const char * dir, const char * refdir); + + /** + * If dir is different after CollapseFullPath is called, + * Then insert it into the path translation table + */ + static void AddKeepPath(const char* dir); + + /** + * Update path by going through the Path Translation table; + */ + static void CheckTranslationPath(kwsys_stl::string & path); + + /** * Get and set permissions of the file. */ static bool GetPermissions(const char* file, mode_t& mode); @@ -312,6 +329,12 @@ protected: */ static kwsys_stl::string ConvertToWindowsOutputPath(const char*); +private: + /** + * Path translation table from dir to refdir + * Each time 'dir' will be found it will be replace by 'refdir' + */ + static kwsys_stl::map<kwsys_stl::string,kwsys_stl::string> TranslationMap; }; } // namespace @KWSYS_NAMESPACE@ |