summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2007-10-02 19:48:21 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2007-10-02 19:48:21 (GMT)
commite0899bcaf2a813d2210cb6f991ed354645ef83c1 (patch)
tree2c9cebd816519501ca91c7d55ddb1e1d83518fb3 /Source
parent019a0989d5112ae27fc639390a2aebe648683167 (diff)
downloadCMake-e0899bcaf2a813d2210cb6f991ed354645ef83c1.zip
CMake-e0899bcaf2a813d2210cb6f991ed354645ef83c1.tar.gz
CMake-e0899bcaf2a813d2210cb6f991ed354645ef83c1.tar.bz2
ENH: speed up actual path name by cache on windows
Diffstat (limited to 'Source')
-rw-r--r--Source/kwsys/SystemTools.cxx15
-rw-r--r--Source/kwsys/SystemTools.hxx.in1
2 files changed, 15 insertions, 1 deletions
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;
};