summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-03-12 14:49:05 (GMT)
committerBrad King <brad.king@kitware.com>2009-03-12 14:49:05 (GMT)
commit1b43bea91c9b6dd4d83b55631273db648766463d (patch)
tree83dca246e9319af44da5b60b8543c444abad713d /Source
parent0460e31e67a09091fa92d3b7a2ecde14cc81eaee (diff)
downloadCMake-1b43bea91c9b6dd4d83b55631273db648766463d.zip
CMake-1b43bea91c9b6dd4d83b55631273db648766463d.tar.gz
CMake-1b43bea91c9b6dd4d83b55631273db648766463d.tar.bz2
ENH: Refactor cache entry writing and reading
This factors out duplicated code into reusable methods, thus simplifying writing and reading of cache entry help strings, keys, values, and properties.
Diffstat (limited to 'Source')
-rw-r--r--Source/cmCacheManager.cxx266
-rw-r--r--Source/cmCacheManager.h9
2 files changed, 111 insertions, 164 deletions
diff --git a/Source/cmCacheManager.cxx b/Source/cmCacheManager.cxx
index 73b523c..f65c80d 100644
--- a/Source/cmCacheManager.cxx
+++ b/Source/cmCacheManager.cxx
@@ -285,49 +285,7 @@ bool cmCacheManager::LoadCache(const char* path,
helpString += "/CMakeCache.txt" ;
e.SetProperty("HELPSTRING", helpString.c_str());
}
- if ( e.Type == cmCacheManager::INTERNAL &&
- (entryKey.size() > strlen("-ADVANCED")) &&
- strcmp(entryKey.c_str() + (entryKey.size() -
- strlen("-ADVANCED")), "-ADVANCED") == 0 )
- {
- std::string value = e.Value;
- std::string akey =
- entryKey.substr(0, (entryKey.size() - strlen("-ADVANCED")));
- cmCacheManager::CacheIterator it =
- this->GetCacheIterator(akey.c_str());
- if ( it.IsAtEnd() )
- {
- e.Type = cmCacheManager::UNINITIALIZED;
- this->Cache[akey] = e;
- }
- if (!it.Find(akey.c_str()))
- {
- cmSystemTools::Error("Internal CMake error when reading cache");
- }
- it.SetProperty("ADVANCED", value.c_str());
- }
- else if ( e.Type == cmCacheManager::INTERNAL &&
- (entryKey.size() > strlen("-MODIFIED")) &&
- strcmp(entryKey.c_str() + (entryKey.size() -
- strlen("-MODIFIED")), "-MODIFIED") == 0 )
- {
- std::string value = e.Value;
- std::string akey =
- entryKey.substr(0, (entryKey.size() - strlen("-MODIFIED")));
- cmCacheManager::CacheIterator it =
- this->GetCacheIterator(akey.c_str());
- if ( it.IsAtEnd() )
- {
- e.Type = cmCacheManager::UNINITIALIZED;
- this->Cache[akey] = e;
- }
- if (!it.Find(akey.c_str()))
- {
- cmSystemTools::Error("Internal CMake error when reading cache");
- }
- it.SetProperty("MODIFIED", value.c_str());
- }
- else
+ if(!this->ReadPropertyEntry(entryKey, e))
{
e.Initialized = true;
this->Cache[entryKey] = e;
@@ -394,6 +352,75 @@ bool cmCacheManager::LoadCache(const char* path,
return true;
}
+//----------------------------------------------------------------------------
+const char* cmCacheManager::PersistentProperties[] =
+{
+ "ADVANCED",
+ "MODIFIED",
+ 0
+};
+
+//----------------------------------------------------------------------------
+bool cmCacheManager::ReadPropertyEntry(std::string const& entryKey,
+ CacheEntry& e)
+{
+ // All property entries are internal.
+ if(e.Type != cmCacheManager::INTERNAL)
+ {
+ return false;
+ }
+
+ const char* end = entryKey.c_str() + entryKey.size();
+ for(const char** p = this->PersistentProperties; *p; ++p)
+ {
+ std::string::size_type plen = strlen(*p) + 1;
+ if(entryKey.size() > plen && *(end-plen) == '-' &&
+ strcmp(end-plen+1, *p) == 0)
+ {
+ std::string key = entryKey.substr(0, entryKey.size() - plen);
+ cmCacheManager::CacheIterator it = this->GetCacheIterator(key.c_str());
+ if(it.IsAtEnd())
+ {
+ // Create an entry and store the property.
+ CacheEntry& ne = this->Cache[key];
+ ne.Type = cmCacheManager::UNINITIALIZED;
+ ne.SetProperty(*p, e.Value.c_str());
+ }
+ else
+ {
+ // Store this property on its entry.
+ it.SetProperty(*p, e.Value.c_str());
+ }
+ return true;
+ }
+ }
+ return false;
+}
+
+//----------------------------------------------------------------------------
+void cmCacheManager::WritePropertyEntries(std::ostream& os,
+ CacheIterator const& i)
+{
+ for(const char** p = this->PersistentProperties; *p; ++p)
+ {
+ if(const char* value = i.GetProperty(*p))
+ {
+ std::string helpstring = *p;
+ helpstring += " property for variable: ";
+ helpstring += i.GetName();
+ cmCacheManager::OutputHelpString(os, helpstring);
+
+ std::string key = i.GetName();
+ key += "-";
+ key += *p;
+ this->OutputKey(os, key);
+ os << ":INTERNAL=";
+ this->OutputValue(os, value);
+ os << "\n";
+ }
+ }
+}
+
bool cmCacheManager::SaveCache(cmMakefile* mf)
{
return this->SaveCache(mf->GetHomeOutputDirectory());
@@ -495,32 +522,9 @@ bool cmCacheManager::SaveCache(const char* path)
{
cmCacheManager::OutputHelpString(fout, "Missing description");
}
- std::string key;
- // support : in key name by double quoting
- if((*i).first.find(':') != std::string::npos ||
- (*i).first.find("//") == 0)
- {
- key = "\"";
- key += i->first;
- key += "\"";
- }
- else
- {
- key = i->first;
- }
- fout << key.c_str() << ":"
- << cmCacheManagerTypes[t] << "=";
- // if value has trailing space or tab, enclose it in single quotes
- if (ce.Value.size() &&
- (ce.Value[ce.Value.size() - 1] == ' ' ||
- ce.Value[ce.Value.size() - 1] == '\t'))
- {
- fout << '\'' << ce.Value << '\'';
- }
- else
- {
- fout << ce.Value;
- }
+ this->OutputKey(fout, i->first);
+ fout << ":" << cmCacheManagerTypes[t] << "=";
+ this->OutputValue(fout, ce.Value);
fout << "\n\n";
}
}
@@ -540,104 +544,17 @@ bool cmCacheManager::SaveCache(const char* path)
}
CacheEntryType t = i.GetType();
- bool advanced = i.PropertyExists("ADVANCED");
- if ( advanced )
- {
- // Format is key:type=value
- std::string key;
- std::string rkey = i.GetName();
- std::string helpstring;
- // If this is advanced variable, we have to do some magic for
- // backward compatibility
- helpstring = "Advanced flag for variable: ";
- helpstring += i.GetName();
- rkey += "-ADVANCED";
- cmCacheManager::OutputHelpString(fout, helpstring.c_str());
- // support : in key name by double quoting
- if(rkey.find(':') != std::string::npos ||
- rkey.find("//") == 0)
- {
- key = "\"";
- key += rkey;
- key += "\"";
- }
- else
- {
- key = rkey;
- }
- fout << key.c_str() << ":INTERNAL="
- << (i.GetPropertyAsBool("ADVANCED") ? "1" : "0") << "\n";
- }
- bool modified = i.PropertyExists("MODIFIED");
- if ( modified )
- {
- // Format is key:type=value
- std::string key;
- std::string rkey = i.GetName();
- std::string helpstring;
- // If this is advanced variable, we have to do some magic for
- // backward compatibility
- helpstring = "Modified flag for variable: ";
- helpstring += i.GetName();
- rkey += "-MODIFIED";
- cmCacheManager::OutputHelpString(fout, helpstring.c_str());
- // support : in key name by double quoting
- if(rkey.find(':') != std::string::npos ||
- rkey.find("//") == 0)
- {
- key = "\"";
- key += rkey;
- key += "\"";
- }
- else
- {
- key = rkey;
- }
- fout << key.c_str() << ":INTERNAL="
- << (i.GetPropertyAsBool("MODIFIED") ? "1" : "0") << "\n";
- }
+ this->WritePropertyEntries(fout, i);
if(t == cmCacheManager::INTERNAL)
{
// Format is key:type=value
- std::string key;
- std::string rkey = i.GetName();
- std::string helpstring;
- const char* hs = i.GetProperty("HELPSTRING");
- if ( hs )
- {
- helpstring = i.GetProperty("HELPSTRING");
- }
- else
- {
- helpstring = "";
- }
- cmCacheManager::OutputHelpString(fout, helpstring.c_str());
- // support : in key name by double quoting
- if(rkey.find(':') != std::string::npos ||
- rkey.find("//") == 0)
- {
- key = "\"";
- key += rkey;
- key += "\"";
- }
- else
- {
- key = rkey;
- }
- fout << key.c_str() << ":"
- << cmCacheManagerTypes[t] << "=";
- // if value has trailing space or tab, enclose it in single quotes
- std::string value = i.GetValue();
- if (value.size() &&
- (value[value.size() - 1] == ' ' ||
- value[value.size() - 1] == '\t'))
- {
- fout << '\'' << value << '\'';
- }
- else
+ if(const char* help = i.GetProperty("HELPSTRING"))
{
- fout << value;
+ this->OutputHelpString(fout, help);
}
+ this->OutputKey(fout, i.GetName());
+ fout << ":" << cmCacheManagerTypes[t] << "=";
+ this->OutputValue(fout, i.GetValue());
fout << "\n";
}
}
@@ -690,7 +607,30 @@ bool cmCacheManager::DeleteCache(const char* path)
return true;
}
-void cmCacheManager::OutputHelpString(std::ofstream& fout,
+void cmCacheManager::OutputKey(std::ostream& fout, std::string const& key)
+{
+ // support : in key name by double quoting
+ const char* q = (key.find(':') != key.npos ||
+ key.find("//") == 0)? "\"" : "";
+ fout << q << key << q;
+}
+
+void cmCacheManager::OutputValue(std::ostream& fout, std::string const& value)
+{
+ // if value has trailing space or tab, enclose it in single quotes
+ if (value.size() &&
+ (value[value.size() - 1] == ' ' ||
+ value[value.size() - 1] == '\t'))
+ {
+ fout << '\'' << value << '\'';
+ }
+ else
+ {
+ fout << value;
+ }
+}
+
+void cmCacheManager::OutputHelpString(std::ostream& fout,
const std::string& helpString)
{
std::string::size_type end = helpString.size();
diff --git a/Source/cmCacheManager.h b/Source/cmCacheManager.h
index 4bcb982..4d7254d 100644
--- a/Source/cmCacheManager.h
+++ b/Source/cmCacheManager.h
@@ -176,8 +176,15 @@ protected:
unsigned int CacheMinorVersion;
private:
typedef std::map<cmStdString, CacheEntry> CacheEntryMap;
- static void OutputHelpString(std::ofstream& fout,
+ static void OutputHelpString(std::ostream& fout,
const std::string& helpString);
+ static void OutputKey(std::ostream& fout, std::string const& key);
+ static void OutputValue(std::ostream& fout, std::string const& value);
+
+ static const char* PersistentProperties[];
+ bool ReadPropertyEntry(std::string const& key, CacheEntry& e);
+ void WritePropertyEntries(std::ostream& os, CacheIterator const& i);
+
CacheEntryMap Cache;
// Only cmake and cmMakefile should be able to add cache values
// the commands should never use the cmCacheManager directly