summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2005-04-12 17:25:19 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2005-04-12 17:25:19 (GMT)
commit266d5d16df0c5e0356b70fe8a44c4da78814a821 (patch)
tree688f914c0cf7e22c700bc42c4019e136258acc6e /Source
parentee7fbdf0588d9aabcd69d57a934f3681d60eff05 (diff)
downloadCMake-266d5d16df0c5e0356b70fe8a44c4da78814a821.zip
CMake-266d5d16df0c5e0356b70fe8a44c4da78814a821.tar.gz
CMake-266d5d16df0c5e0356b70fe8a44c4da78814a821.tar.bz2
ENH: optimization of cwd and do not leak library handle
Diffstat (limited to 'Source')
-rw-r--r--Source/kwsys/SystemTools.cxx25
-rw-r--r--Source/kwsys/SystemTools.hxx.in3
2 files changed, 18 insertions, 10 deletions
diff --git a/Source/kwsys/SystemTools.cxx b/Source/kwsys/SystemTools.cxx
index 57be4d9..256b8f1 100644
--- a/Source/kwsys/SystemTools.cxx
+++ b/Source/kwsys/SystemTools.cxx
@@ -1258,7 +1258,11 @@ kwsys_stl::string SystemTools::ConvertToOutputPath(const char* path)
// remove double slashes not at the start
kwsys_stl::string SystemTools::ConvertToWindowsOutputPath(const char* path)
{
- kwsys_stl::string ret = path;
+ kwsys_stl::string ret;
+ // 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);
kwsys_stl::string::size_type pos = 0;
// first convert all of the slashes
while((pos = ret.find('/', pos)) != kwsys_stl::string::npos)
@@ -1289,12 +1293,11 @@ kwsys_stl::string SystemTools::ConvertToWindowsOutputPath(const char* path)
}
// now double quote the path if it has spaces in it
// and is not already double quoted
- if(ret.find(" ") != kwsys_stl::string::npos
+ if(ret.find(' ') != kwsys_stl::string::npos
&& ret[0] != '\"')
{
- kwsys_stl::string result;
- result = "\"" + ret + "\"";
- ret = result;
+ ret.insert(0, 1, '\"');
+ ret.append(1, '\"');
}
return ret;
}
@@ -1970,7 +1973,7 @@ int SystemTools::ChangeDirectory(const char *dir)
return Chdir(dir);
}
-kwsys_stl::string SystemTools::GetCurrentWorkingDirectory()
+kwsys_stl::string SystemTools::GetCurrentWorkingDirectory(bool collapse)
{
char buf[2048];
const char* cwd = Getcwd(buf, 2048);
@@ -1979,8 +1982,11 @@ kwsys_stl::string SystemTools::GetCurrentWorkingDirectory()
{
path = cwd;
}
-
- return SystemTools::CollapseFullPath(path.c_str());
+ if(collapse)
+ {
+ return SystemTools::CollapseFullPath(path.c_str());
+ }
+ return path;
}
kwsys_stl::string SystemTools::GetProgramPath(const char* in_name)
@@ -2303,11 +2309,14 @@ int PortableGetLongPathName(const char* pathIn,
int len = (*func)(shortPath.c_str(), buffer, MAX_PATH+1);
if(len == 0 || len > MAX_PATH+1)
{
+ FreeLibrary(lh);
return 0;
}
longPath = buffer;
+ FreeLibrary(lh);
return len;
}
+ FreeLibrary(lh);
}
return OldWindowsGetLongPath(shortPath.c_str(), longPath);
}
diff --git a/Source/kwsys/SystemTools.hxx.in b/Source/kwsys/SystemTools.hxx.in
index eec2617..1c063bd 100644
--- a/Source/kwsys/SystemTools.hxx.in
+++ b/Source/kwsys/SystemTools.hxx.in
@@ -580,7 +580,7 @@ public:
/**
* Get current working directory CWD
*/
- static kwsys_stl::string GetCurrentWorkingDirectory();
+ static kwsys_stl::string GetCurrentWorkingDirectory(bool collapse =true);
/**
* Change directory the the directory specified
@@ -668,7 +668,6 @@ private:
* Each time 'dir' will be found it will be replace by 'refdir'
*/
static SystemToolsTranslationMap *TranslationMap;
-
friend class SystemToolsManager;
};