summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
Diffstat (limited to 'Source')
-rw-r--r--Source/cmMakefile.cxx93
-rw-r--r--Source/cmMakefile.h21
2 files changed, 29 insertions, 85 deletions
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx
index a3f532d..e8da4dc 100644
--- a/Source/cmMakefile.cxx
+++ b/Source/cmMakefile.cxx
@@ -53,7 +53,6 @@ cmMakefile::cmMakefile()
this->AddSourceGroup("", "^.*$");
this->AddSourceGroup("Source Files", "\\.(cpp|C|c|cxx|rc|def|r|odl|idl|hpj|bat)$");
this->AddSourceGroup("Header Files", "\\.(h|hh|hpp|hxx|hm|inl)$");
- this->AddDefaultCommands();
this->AddDefaultDefinitions();
}
@@ -76,30 +75,6 @@ unsigned int cmMakefile::GetCacheMinorVersion()
}
-void cmMakefile::AddDefaultCommands()
-{
- std::list<cmCommand*> commands;
- GetPredefinedCommands(commands);
- for(std::list<cmCommand*>::iterator i = commands.begin();
- i != commands.end(); ++i)
- {
- this->AddCommand(*i);
- }
-#if defined(_WIN32) || defined(__CYGWIN__)
- this->AddDefinition("WIN32", "1");
-#else
- this->AddDefinition("UNIX", "1");
-#endif
- // Cygwin is more like unix so enable the unix commands
-#if defined(__CYGWIN__)
- this->AddDefinition("UNIX", "1");
- this->AddDefinition("CYGWIN", "1");
-#endif
-#if defined(__APPLE__)
- this->AddDefinition("APPLE", "1");
-#endif
-}
-
cmMakefile::~cmMakefile()
{
for(std::vector<cmSourceFile*>::iterator i = m_SourceFiles.begin();
@@ -111,11 +86,6 @@ cmMakefile::~cmMakefile()
{
delete m_UsedCommands[i];
}
- for(RegisteredCommandsMap::iterator j = m_Commands.begin();
- j != m_Commands.end(); ++j)
- {
- delete (*j).second;
- }
for(DataMap::const_iterator d = m_DataMap.begin();
d != m_DataMap.end(); ++d)
{
@@ -184,7 +154,7 @@ void cmMakefile::Print() const
bool cmMakefile::CommandExists(const char* name) const
{
- return (m_Commands.find(name) != m_Commands.end());
+ return m_LocalGenerator->GetGlobalGenerator()->GetCMakeInstance()->CommandExists(name);
}
void cmMakefile::ExecuteCommand(std::string const &name,
@@ -196,10 +166,10 @@ void cmMakefile::ExecuteCommand(std::string const &name,
return;
}
// execute the command
- RegisteredCommandsMap::iterator pos = m_Commands.find(name);
- if(pos != m_Commands.end())
+ cmCommand *rm =
+ m_LocalGenerator->GetGlobalGenerator()->GetCMakeInstance()->GetCommand(name.c_str());
+ if(rm)
{
- cmCommand* rm = (*pos).second;
cmCommand* usedCommand = rm->Clone();
usedCommand->SetMakefile(this);
bool keepCommand = false;
@@ -378,8 +348,7 @@ bool cmMakefile::ReadListFile(const char* filename, const char* external)
void cmMakefile::AddCommand(cmCommand* wg)
{
- std::string name = wg->GetName();
- m_Commands.insert( RegisteredCommandsMap::value_type(name, wg));
+ m_LocalGenerator->GetGlobalGenerator()->GetCMakeInstance()->AddCommand(wg);
}
// Set the make file
@@ -898,32 +867,6 @@ const char* cmMakefile::GetDefinition(const char* name) const
return this->GetCacheManager()->GetCacheValue(name);
}
-int cmMakefile::DumpDocumentationToFile(std::ostream& f)
-{
- // Open the supplied filename
-
- // Loop over all registered commands and print out documentation
- const char *name;
- const char *terse;
- const char *full;
- char tmp[1024];
- sprintf(tmp,"Version %d.%d", cmMakefile::GetMajorVersion(),
- cmMakefile::GetMinorVersion());
- f << "<html>\n";
- f << "<h1>Documentation for commands of CMake " << tmp << "</h1>\n";
- f << "<ul>\n";
- for(RegisteredCommandsMap::iterator j = m_Commands.begin();
- j != m_Commands.end(); ++j)
- {
- name = (*j).second->GetName();
- terse = (*j).second->GetTerseDocumentation();
- full = (*j).second->GetFullDocumentation();
- f << "<li><b>" << name << "</b> - " << terse << std::endl
- << "<br><i>Usage:</i> " << full << "</li>" << std::endl << std::endl;
- }
- f << "</ul></html>\n";
- return 1;
-}
const char *cmMakefile::ExpandVariablesInString(std::string& source) const
@@ -1124,6 +1067,20 @@ void cmMakefile::RemoveVariablesInString(std::string& source,
*/
void cmMakefile::AddDefaultDefinitions()
{
+#if defined(_WIN32) || defined(__CYGWIN__)
+ this->AddDefinition("WIN32", "1");
+#else
+ this->AddDefinition("UNIX", "1");
+#endif
+ // Cygwin is more like unix so enable the unix commands
+#if defined(__CYGWIN__)
+ this->AddDefinition("UNIX", "1");
+ this->AddDefinition("CYGWIN", "1");
+#endif
+#if defined(__APPLE__)
+ this->AddDefinition("APPLE", "1");
+#endif
+
#if defined(_WIN32) && !defined(__CYGWIN__)
this->AddDefinition("CMAKE_CFG_INTDIR","$(IntDir)");
#else
@@ -1373,7 +1330,7 @@ void cmMakefile::ExpandSourceListArguments(
}
int cmMakefile::TryCompile(const char *srcdir, const char *bindir,
- const char *projectName)
+ const char *projectName, const char *targetName)
{
if (!m_LocalGenerator)
{
@@ -1433,17 +1390,13 @@ int cmMakefile::TryCompile(const char *srcdir, const char *bindir,
}
// finally call the generator to actually build the resulting project
- gg->TryCompile(srcdir,bindir,projectName);
+ int ret = gg->TryCompile(srcdir,bindir,projectName, targetName);
cmSystemTools::ChangeDirectory(cwd.c_str());
- return 0;
+ return ret;
}
cmCacheManager *cmMakefile::GetCacheManager() const
{
- if (m_LocalGenerator)
- {
- return m_LocalGenerator->GetGlobalGenerator()->GetCMakeInstance()->GetCacheManager();
- }
- return 0;
+ return m_LocalGenerator->GetGlobalGenerator()->GetCMakeInstance()->GetCacheManager();
}
diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h
index 1deee8e..76ed2a1 100644
--- a/Source/cmMakefile.h
+++ b/Source/cmMakefile.h
@@ -71,11 +71,6 @@ public:
bool ReadListFile(const char* listfile, const char* external= 0);
/**
- * Add a wrapper generator.
- */
- void AddCommand(cmCommand* );
-
- /**
* Add a function blocker to this makefile
*/
void AddFunctionBlocker(cmFunctionBlocker *fb)
@@ -89,7 +84,7 @@ public:
* loaded commands, not as part of the usual build process.
*/
int TryCompile(const char *srcdir, const char *bindir,
- const char *projectName);
+ const char *projectName, const char *targetName);
/**
* Specify the makefile generator. This is platform/compiler
@@ -458,12 +453,6 @@ public:
{ m_ListFiles.push_back(file);}
/**
- * Dump documentation to a file. If 0 is returned, the
- * operation failed.
- */
- int DumpDocumentationToFile(std::ostream&);
-
- /**
* Expand all defined varibles in the string.
* Defined varibles come from the m_Definitions map.
* They are expanded with ${var} where var is the
@@ -503,6 +492,11 @@ public:
/** Check if a command exists. */
bool CommandExists(const char* name) const;
+ /**
+ * Add a command to this cmake instance
+ */
+ void AddCommand(cmCommand* );
+
///! Enable support for the named language, if null then all languages are enabled.
void EnableLanguage(const char* );
@@ -554,10 +548,8 @@ protected:
std::vector<std::string> m_HeaderFileExtensions;
std::string m_DefineFlags;
std::vector<cmSourceGroup> m_SourceGroups;
- typedef std::map<cmStdString, cmCommand*> RegisteredCommandsMap;
typedef std::map<cmStdString, cmStdString> DefinitionMap;
DefinitionMap m_Definitions;
- RegisteredCommandsMap m_Commands;
std::vector<cmCommand*> m_UsedCommands;
cmLocalGenerator* m_LocalGenerator;
bool IsFunctionBlocked(const char *name, std::vector<std::string> const& args);
@@ -573,7 +565,6 @@ private:
friend class cmMakeDepend; // make depend needs direct access
// to the m_Sources array
void PrintStringVector(const char* s, const std::vector<std::string>& v) const;
- void AddDefaultCommands();
void AddDefaultDefinitions();
std::list<cmFunctionBlocker *> m_FunctionBlockers;