summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmCacheManager.cxx74
1 files changed, 48 insertions, 26 deletions
diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx
index 9014216..b07ab5f 100644
--- a/Source/cmCacheManager.cxx
+++ b/Source/cmCacheManager.cxx
@@ -151,9 +151,9 @@ bool cmCacheManager::LoadCache(const char* path,
(*realbuffer == ' ' ||
*realbuffer == '\t' ||
*realbuffer == '\n'))
- {
+ {
realbuffer++;
- }
+ }
// skip blank lines and comment lines
if(realbuffer[0] == '#' || realbuffer[0] == 0)
{
@@ -202,38 +202,38 @@ bool cmCacheManager::LoadCache(const char* path,
{
entryKey = reg.match(1);
if ( excludes.find(entryKey) == excludes.end() )
- {
- e.m_Type = cmCacheManager::StringToType(reg.match(2).c_str());
- // only load internal values if internal is set
- // Load internal values if internal is set.
- // If the entry is not internal to the cache being loaded
- // or if it is in the list of internal entries to be
- // imported, load it.
- if ( internal || (e.m_Type != INTERNAL) ||
- (includes.find(entryKey) != includes.end()) )
- {
- // If we are loading the cache from another project,
- // make all loaded entries internal so that it is
- // not visible in the gui
- if (!internal)
- {
- e.m_Type = INTERNAL;
- e.m_HelpString = "DO NOT EDIT, ";
+ {
+ e.m_Type = cmCacheManager::StringToType(reg.match(2).c_str());
+ // only load internal values if internal is set
+ // Load internal values if internal is set.
+ // If the entry is not internal to the cache being loaded
+ // or if it is in the list of internal entries to be
+ // imported, load it.
+ if ( internal || (e.m_Type != INTERNAL) ||
+ (includes.find(entryKey) != includes.end()) )
+ {
+ // If we are loading the cache from another project,
+ // make all loaded entries internal so that it is
+ // not visible in the gui
+ if (!internal)
+ {
+ e.m_Type = INTERNAL;
+ e.m_HelpString = "DO NOT EDIT, ";
e.m_HelpString += entryKey;
e.m_HelpString += " loaded from external file. "
"To change this value edit this file: ";
e.m_HelpString += path;
e.m_HelpString += "/CMakeCache.txt";
- }
- e.m_Value = reg.match(3);
- m_Cache[entryKey] = e;
- }
- }
+ }
+ e.m_Value = reg.match(3);
+ m_Cache[entryKey] = e;
+ }
+ }
}
else
{
- cmSystemTools::Error("Parse error in cache file ", cacheFile.c_str(),
- ". Offending entry: ", realbuffer);
+ cmSystemTools::Error("Parse error in cache file ", cacheFile.c_str(),
+ ". Offending entry: ", realbuffer);
}
}
// if CMAKE version not found in the list file
@@ -248,6 +248,19 @@ bool cmCacheManager::LoadCache(const char* path,
"current loaded cache", cmCacheManager::INTERNAL);
}
+ std::string currentcwd = path;
+ cmSystemTools::ConvertToUnixSlashes(currentcwd);
+ if(internal && this->GetCacheValue("CMAKE_CACHE_CWD") &&
+ std::string(this->GetCacheValue("CMAKE_CACHE_CWD")) != currentcwd)
+ {
+ cmSystemTools::Error("The current directory is different"
+ " than the one CMake was run before."
+ " The binary files will be created "
+ "in the previous directory. If that "
+ "is not what you want, reedit the "
+ "CMakeCache.txt");
+ }
+
return true;
}
@@ -297,6 +310,15 @@ bool cmCacheManager::SaveCache(const char* path)
this->AddCacheEntry("CMAKE_CACHE_MAJOR_VERSION", temp,
"Major version of cmake used to create the "
"current loaded cache", cmCacheManager::INTERNAL);
+
+ // Let us store the current working directory so that if somebody
+ // Copies it, he will not be surprised
+ std::string currentcwd = path;
+ cmSystemTools::ConvertToUnixSlashes(currentcwd);
+ this->AddCacheEntry("CMAKE_CACHE_CWD", currentcwd.c_str(),
+ "This is the directory where cmake was running the"
+ " last time", cmCacheManager::INTERNAL);
+
fout << "# This is the CMakeCache file.\n"
<< "# For build in directory: " << path << "\n"
<< "# You can edit this file to change values found and used by cmake.\n"