From e0899bcaf2a813d2210cb6f991ed354645ef83c1 Mon Sep 17 00:00:00 2001 From: Bill Hoffman Date: Tue, 2 Oct 2007 15:48:21 -0400 Subject: ENH: speed up actual path name by cache on windows --- Source/kwsys/SystemTools.cxx | 15 ++++++++++++++- Source/kwsys/SystemTools.hxx.in | 1 + 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/Source/kwsys/SystemTools.cxx b/Source/kwsys/SystemTools.cxx index a5d7e2f..d7dfda6 100644 --- a/Source/kwsys/SystemTools.cxx +++ b/Source/kwsys/SystemTools.cxx @@ -1464,7 +1464,8 @@ kwsys_stl::string SystemTools::ConvertToWindowsOutputPath(const char* path) // make it big enough for all of path and double quotes ret.reserve(strlen(path)+3); // put path into the string - ret.insert(0,path); + ret.assign(path); + ret = path; kwsys_stl::string::size_type pos = 0; // first convert all of the slashes while((pos = ret.find('/', pos)) != kwsys_stl::string::npos) @@ -2879,6 +2880,14 @@ kwsys_stl::string SystemTools::GetActualCaseForPath(const char* p) #ifndef _WIN32 return p; #else + // Check to see if actual case has already been called + // for this path, and the result is stored in the LongPathMap + SystemToolsTranslationMap::iterator i = + SystemTools::LongPathMap->find(p); + if(i != SystemTools::LongPathMap->end()) + { + return i->second; + } kwsys_stl::string shortPath; if(!SystemTools::GetShortPath(p, shortPath)) { @@ -2895,6 +2904,7 @@ kwsys_stl::string SystemTools::GetActualCaseForPath(const char* p) { longPath[0] = toupper(longPath[0]); } + (*SystemTools::LongPathMap)[p] = longPath; return longPath; #endif } @@ -4192,6 +4202,7 @@ kwsys_stl::string SystemTools::GetOperatingSystemNameAndVersion() // necessary. unsigned int SystemToolsManagerCount; SystemToolsTranslationMap *SystemTools::TranslationMap; +SystemToolsTranslationMap *SystemTools::LongPathMap; // SystemToolsManager manages the SystemTools singleton. // SystemToolsManager should be included in any translation unit @@ -4219,6 +4230,7 @@ void SystemTools::ClassInitialize() { // Allocate the translation map first. SystemTools::TranslationMap = new SystemToolsTranslationMap; + SystemTools::LongPathMap = new SystemToolsTranslationMap; // Add some special translation paths for unix. These are not added // for windows because drive letters need to be maintained. Also, @@ -4274,6 +4286,7 @@ void SystemTools::ClassInitialize() void SystemTools::ClassFinalize() { delete SystemTools::TranslationMap; + delete SystemTools::LongPathMap; } diff --git a/Source/kwsys/SystemTools.hxx.in b/Source/kwsys/SystemTools.hxx.in index c89bd49..6faf9d2 100644 --- a/Source/kwsys/SystemTools.hxx.in +++ b/Source/kwsys/SystemTools.hxx.in @@ -813,6 +813,7 @@ private: * Each time 'dir' will be found it will be replace by 'refdir' */ static SystemToolsTranslationMap *TranslationMap; + static SystemToolsTranslationMap *LongPathMap; friend class SystemToolsManager; }; -- cgit v0.12