2009-09-28 19:43:28 +04:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
2001-02-12 22:26:25 +03:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
|
|
see accompanying file Copyright.txt for details.
|
2001-02-12 22:26:25 +03:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the License for more information.
|
|
|
|
============================================================================*/
|
2001-02-12 22:26:25 +03:00
|
|
|
#ifndef cmCacheManager_h
|
|
|
|
#define cmCacheManager_h
|
|
|
|
|
|
|
|
#include "cmStandardIncludes.h"
|
2009-03-10 18:10:42 +03:00
|
|
|
#include "cmPropertyMap.h"
|
2001-02-19 23:13:48 +03:00
|
|
|
class cmMakefile;
|
2007-04-11 00:03:10 +04:00
|
|
|
class cmMarkAsAdvancedCommand;
|
2009-03-13 17:53:47 +03:00
|
|
|
class cmake;
|
2001-02-12 22:26:25 +03:00
|
|
|
|
|
|
|
/** \class cmCacheManager
|
|
|
|
* \brief Control class for cmake's cache
|
|
|
|
*
|
|
|
|
* Load and Save CMake cache files.
|
2012-08-13 21:42:58 +04:00
|
|
|
*
|
2001-02-12 22:26:25 +03:00
|
|
|
*/
|
|
|
|
class cmCacheManager
|
|
|
|
{
|
2001-04-24 00:40:29 +04:00
|
|
|
public:
|
2009-03-13 17:53:47 +03:00
|
|
|
cmCacheManager(cmake* cm);
|
2002-09-12 16:56:32 +04:00
|
|
|
class CacheIterator;
|
|
|
|
friend class cmCacheManager::CacheIterator;
|
2012-08-13 21:42:58 +04:00
|
|
|
enum CacheEntryType{ BOOL=0, PATH, FILEPATH, STRING, INTERNAL,STATIC,
|
2006-03-10 19:13:15 +03:00
|
|
|
UNINITIALIZED };
|
2002-09-11 22:05:45 +04:00
|
|
|
|
|
|
|
private:
|
2001-04-26 22:53:44 +04:00
|
|
|
struct CacheEntry
|
2001-04-24 00:40:29 +04:00
|
|
|
{
|
2006-03-15 19:02:08 +03:00
|
|
|
std::string Value;
|
|
|
|
CacheEntryType Type;
|
2009-03-10 18:10:42 +03:00
|
|
|
cmPropertyMap Properties;
|
2013-09-03 00:27:32 +04:00
|
|
|
const char* GetProperty(const std::string&) const;
|
|
|
|
void SetProperty(const std::string& property, const char* value);
|
|
|
|
void AppendProperty(const std::string& property, const char* value,
|
2011-07-14 01:14:41 +04:00
|
|
|
bool asString=false);
|
2006-03-15 19:02:08 +03:00
|
|
|
bool Initialized;
|
|
|
|
CacheEntry() : Value(""), Type(UNINITIALIZED), Initialized(false)
|
2003-08-02 17:33:23 +04:00
|
|
|
{}
|
2001-04-24 00:40:29 +04:00
|
|
|
};
|
2002-09-11 22:05:45 +04:00
|
|
|
|
|
|
|
public:
|
2002-08-21 19:57:12 +04:00
|
|
|
class CacheIterator
|
|
|
|
{
|
|
|
|
public:
|
2002-08-24 00:13:34 +04:00
|
|
|
void Begin();
|
2014-02-05 01:06:56 +04:00
|
|
|
bool Find(const std::string&);
|
2003-02-05 22:55:46 +03:00
|
|
|
bool IsAtEnd() const;
|
2002-08-24 00:13:34 +04:00
|
|
|
void Next();
|
2002-09-11 22:05:45 +04:00
|
|
|
const char *GetName() const {
|
2012-08-13 21:42:58 +04:00
|
|
|
return this->Position->first.c_str(); }
|
2013-09-03 00:27:32 +04:00
|
|
|
const char* GetProperty(const std::string&) const ;
|
|
|
|
bool GetPropertyAsBool(const std::string&) const ;
|
|
|
|
bool PropertyExists(const std::string&) const;
|
|
|
|
void SetProperty(const std::string& property, const char* value);
|
|
|
|
void AppendProperty(const std::string& property, const char* value,
|
2011-07-14 01:14:41 +04:00
|
|
|
bool asString=false);
|
2013-09-03 00:27:32 +04:00
|
|
|
void SetProperty(const std::string& property, bool value);
|
2006-03-15 19:02:08 +03:00
|
|
|
const char* GetValue() const { return this->GetEntry().Value.c_str(); }
|
2003-08-08 17:22:56 +04:00
|
|
|
bool GetValueAsBool() const;
|
2002-09-11 22:05:45 +04:00
|
|
|
void SetValue(const char*);
|
2006-03-15 19:02:08 +03:00
|
|
|
CacheEntryType GetType() const { return this->GetEntry().Type; }
|
2008-03-07 19:43:47 +03:00
|
|
|
void SetType(CacheEntryType ty) { this->GetEntry().Type = ty; }
|
2006-03-15 19:02:08 +03:00
|
|
|
bool Initialized() { return this->GetEntry().Initialized; }
|
|
|
|
cmCacheManager &Container;
|
|
|
|
std::map<cmStdString, CacheEntry>::iterator Position;
|
|
|
|
CacheIterator(cmCacheManager &cm) : Container(cm) {
|
2002-08-21 19:57:12 +04:00
|
|
|
this->Begin();
|
|
|
|
}
|
2012-08-13 21:42:58 +04:00
|
|
|
CacheIterator(cmCacheManager &cm, const char* key) : Container(cm)
|
2003-03-06 19:18:58 +03:00
|
|
|
{
|
|
|
|
if ( key )
|
|
|
|
{
|
|
|
|
this->Find(key);
|
|
|
|
}
|
2013-05-02 18:46:57 +04:00
|
|
|
}
|
2002-09-11 22:05:45 +04:00
|
|
|
private:
|
2006-03-15 19:02:08 +03:00
|
|
|
CacheEntry const& GetEntry() const { return this->Position->second; }
|
|
|
|
CacheEntry& GetEntry() { return this->Position->second; }
|
2002-08-21 19:57:12 +04:00
|
|
|
};
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2002-08-21 19:57:12 +04:00
|
|
|
///! return an iterator to iterate through the cache map
|
2012-08-13 21:42:58 +04:00
|
|
|
cmCacheManager::CacheIterator NewIterator()
|
2002-08-21 19:57:12 +04:00
|
|
|
{
|
|
|
|
return CacheIterator(*this);
|
2012-08-13 21:42:58 +04:00
|
|
|
}
|
|
|
|
|
2001-02-12 22:26:25 +03:00
|
|
|
/**
|
|
|
|
* Types for the cache entries. These are useful as
|
|
|
|
* hints for a cache editor program. Path should bring
|
2012-08-13 21:42:58 +04:00
|
|
|
* up a file chooser, BOOL a check box, and STRING a
|
2001-02-19 23:13:48 +03:00
|
|
|
* text entry box, FILEPATH is a full path to a file which
|
|
|
|
* can be different than just a path input
|
2001-02-12 22:26:25 +03:00
|
|
|
*/
|
|
|
|
static CacheEntryType StringToType(const char*);
|
2003-04-29 18:02:53 +04:00
|
|
|
static const char* TypeToString(CacheEntryType);
|
2009-03-10 18:10:59 +03:00
|
|
|
static bool IsType(const char*);
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Load a cache for given makefile. Loads from ouput home.
|
2012-08-13 21:42:58 +04:00
|
|
|
bool LoadCache(cmMakefile*);
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Load a cache for given makefile. Loads from path/CMakeCache.txt.
|
2002-08-24 00:13:34 +04:00
|
|
|
bool LoadCache(const char* path);
|
|
|
|
bool LoadCache(const char* path, bool internal);
|
2012-08-13 21:42:58 +04:00
|
|
|
bool LoadCache(const char* path, bool internal,
|
2004-09-30 00:07:07 +04:00
|
|
|
std::set<cmStdString>& excludes,
|
|
|
|
std::set<cmStdString>& includes);
|
2001-05-02 00:28:32 +04:00
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Save cache for given makefile. Saves to ouput home CMakeCache.txt.
|
2002-08-24 00:13:34 +04:00
|
|
|
bool SaveCache(cmMakefile*) ;
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Save cache for given makefile. Saves to ouput path/CMakeCache.txt
|
2002-08-24 00:13:34 +04:00
|
|
|
bool SaveCache(const char* path) ;
|
2001-08-08 19:54:46 +04:00
|
|
|
|
2004-05-20 23:08:18 +04:00
|
|
|
///! Delete the cache given
|
|
|
|
bool DeleteCache(const char* path);
|
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Print the cache to a stream
|
|
|
|
void PrintCache(std::ostream&) const;
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2002-09-11 22:05:45 +04:00
|
|
|
///! Get the iterator for an entry with a given key.
|
2003-03-06 19:18:58 +03:00
|
|
|
cmCacheManager::CacheIterator GetCacheIterator(const char *key=0);
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
///! Remove an entry from the cache
|
2014-02-05 01:06:56 +04:00
|
|
|
void RemoveCacheEntry(const std::string& key);
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2002-08-21 19:57:12 +04:00
|
|
|
///! Get the number of entries in the cache
|
2002-08-24 00:13:34 +04:00
|
|
|
int GetSize() {
|
2006-03-15 19:02:08 +03:00
|
|
|
return static_cast<int>(this->Cache.size()); }
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2001-11-21 01:51:03 +03:00
|
|
|
///! Break up a line like VAR:type="value" into var, type and value
|
2012-08-13 21:42:58 +04:00
|
|
|
static bool ParseEntry(const char* entry,
|
2001-11-21 01:51:03 +03:00
|
|
|
std::string& var,
|
|
|
|
std::string& value,
|
|
|
|
CacheEntryType& type);
|
2002-09-04 23:46:25 +04:00
|
|
|
|
|
|
|
///! Get a value from the cache given a key
|
2014-02-05 01:06:56 +04:00
|
|
|
const char* GetCacheValue(const std::string& key) const;
|
2002-09-04 23:46:25 +04:00
|
|
|
|
2008-01-24 15:37:08 +03:00
|
|
|
/** Get the version of CMake that wrote the cache. */
|
2014-01-21 18:23:27 +04:00
|
|
|
unsigned int GetCacheMajorVersion() const
|
|
|
|
{ return this->CacheMajorVersion; }
|
|
|
|
unsigned int GetCacheMinorVersion() const
|
|
|
|
{ return this->CacheMinorVersion; }
|
2008-01-24 15:37:08 +03:00
|
|
|
bool NeedCacheCompatibility(int major, int minor);
|
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
protected:
|
|
|
|
///! Add an entry into the cache
|
2014-02-05 01:06:56 +04:00
|
|
|
void AddCacheEntry(const std::string& key, const char* value,
|
2001-08-08 19:54:46 +04:00
|
|
|
const char* helpString, CacheEntryType type);
|
|
|
|
|
2002-09-11 22:05:45 +04:00
|
|
|
///! Get a cache entry object for a key
|
2014-02-05 01:06:56 +04:00
|
|
|
CacheEntry *GetCacheEntry(const std::string& key);
|
2006-03-09 23:47:18 +03:00
|
|
|
///! Clean out the CMakeFiles directory if no CMakeCache.txt
|
|
|
|
void CleanCMakeFiles(const char* path);
|
2008-01-24 15:37:08 +03:00
|
|
|
|
|
|
|
// Cache version info
|
|
|
|
unsigned int CacheMajorVersion;
|
|
|
|
unsigned int CacheMinorVersion;
|
2001-02-12 22:26:25 +03:00
|
|
|
private:
|
2009-03-13 17:53:47 +03:00
|
|
|
cmake* CMakeInstance;
|
2002-09-11 22:05:45 +04:00
|
|
|
typedef std::map<cmStdString, CacheEntry> CacheEntryMap;
|
2009-03-12 17:49:05 +03:00
|
|
|
static void OutputHelpString(std::ostream& fout,
|
2001-04-26 22:53:44 +04:00
|
|
|
const std::string& helpString);
|
2009-03-12 17:49:05 +03:00
|
|
|
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);
|
|
|
|
|
2006-03-15 19:02:08 +03:00
|
|
|
CacheEntryMap Cache;
|
2001-08-08 19:54:46 +04:00
|
|
|
// Only cmake and cmMakefile should be able to add cache values
|
|
|
|
// the commands should never use the cmCacheManager directly
|
|
|
|
friend class cmMakefile; // allow access to add cache values
|
|
|
|
friend class cmake; // allow access to add cache values
|
2007-04-11 00:03:10 +04:00
|
|
|
friend class cmMarkAsAdvancedCommand; // allow access to add cache values
|
2001-02-12 22:26:25 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|