summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalUnixMakefileGenerator2.h
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2005-02-10 21:18:27 (GMT)
committerBrad King <brad.king@kitware.com>2005-02-10 21:18:27 (GMT)
commit6173dea153c2318e3a4ce7b4924e71543b03bc5f (patch)
treed9d522920f71124a7f363821bee2112a86f50c8a /Source/cmLocalUnixMakefileGenerator2.h
parent23276ca3a29a4a6a79b54d77a1ec5bfd8f0f381a (diff)
downloadCMake-6173dea153c2318e3a4ce7b4924e71543b03bc5f.zip
CMake-6173dea153c2318e3a4ce7b4924e71543b03bc5f.tar.gz
CMake-6173dea153c2318e3a4ce7b4924e71543b03bc5f.tar.bz2
ENH: Split cmLocalUnixMakefileGenerator2 away from cmLocalUnixMakefileGenerator to be a stand-alone generator.
Diffstat (limited to 'Source/cmLocalUnixMakefileGenerator2.h')
-rw-r--r--Source/cmLocalUnixMakefileGenerator2.h69
1 files changed, 66 insertions, 3 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator2.h b/Source/cmLocalUnixMakefileGenerator2.h
index 9127910..0aad83a 100644
--- a/Source/cmLocalUnixMakefileGenerator2.h
+++ b/Source/cmLocalUnixMakefileGenerator2.h
@@ -17,7 +17,7 @@
#ifndef cmLocalUnixMakefileGenerator2_h
#define cmLocalUnixMakefileGenerator2_h
-#include "cmLocalUnixMakefileGenerator.h"
+#include "cmLocalGenerator.h"
class cmCustomCommand;
class cmDependInformation;
@@ -32,7 +32,7 @@ class cmSourceFile;
* cmLocalUnixMakefileGenerator2 produces a LocalUnix makefile from its
* member m_Makefile.
*/
-class cmLocalUnixMakefileGenerator2 : public cmLocalUnixMakefileGenerator
+class cmLocalUnixMakefileGenerator2 : public cmLocalGenerator
{
public:
///! Set cache only and recurse to false by default.
@@ -46,6 +46,42 @@ public:
void SetEmptyCommand(const char* cmd);
/**
+ * Set to true if the shell being used is the windows shell.
+ * This controls if statements in the makefile and the SHELL variable.
+ * The default is false.
+ */
+ void SetWindowsShell(bool v) {m_WindowsShell = v;}
+
+ /**
+ * Set the string used to include one makefile into another default
+ * is include.
+ */
+ void SetIncludeDirective(const char* s) { m_IncludeDirective = s; }
+
+ /**
+ * Set the flag used to keep the make program silent.
+ */
+ void SetMakeSilentFlag(const char* s) { m_MakeSilentFlag = s; }
+
+ /**
+ * Set max makefile variable size, default is 0 which means unlimited.
+ */
+ void SetMakefileVariableSize(int s) { m_MakefileVariableSize = s; }
+
+ /**
+ * If ignore lib prefix is true, then do not strip lib from the name
+ * of a library.
+ */
+ void SetIgnoreLibPrefix(bool s) { m_IgnoreLibPrefix = s; }
+
+ /**
+ * If true, then explicitly pass MAKEFLAGS on the make all target for makes
+ * that do not use environment variables.
+ *
+ */
+ void SetPassMakeflags(bool s){m_PassMakeflags = s;}
+
+ /**
* Generate the makefile for this directory. fromTheTop indicates if this
* is being invoked as part of a global Generate or specific to this
* directory. The difference is that when done from the Top we might skip
@@ -165,7 +201,8 @@ protected:
std::string ConvertToFullPath(const std::string& localPath);
std::string ConvertToRelativePath(const char* p);
std::string ConvertToRelativeOutputPath(const char* p);
- virtual void ConfigureOutputPaths();
+ void ConfigureOutputPaths();
+ void FormatOutputPath(std::string& path, const char* name);
bool ComparePath(const char* c1, const char* c2);
void AppendTargetDepends(std::vector<std::string>& depends,
@@ -181,6 +218,19 @@ protected:
const cmCustomCommand& cc);
void AppendCleanCommand(std::vector<std::string>& commands,
const std::vector<std::string>& files);
+
+ //==========================================================================
+ void OutputEcho(std::ostream& fout, const char* msg);
+ bool SamePath(const char* path1, const char* path2);
+ std::string GetBaseTargetName(const cmTarget& t);
+ void GetLibraryNames(const cmTarget& t,
+ std::string& name, std::string& soName,
+ std::string& realName, std::string& baseName);
+ std::string ConvertToMakeTarget(const char* tgt);
+ std::string& CreateSafeUniqueObjectFileName(const char* sin);
+ std::string CreateMakeVariable(const char* sin, const char* s2in);
+ //==========================================================================
+
std::string GetRecursiveMakeCall(const char* tgt);
void WriteJumpAndBuildRules(std::ostream& makefileStream);
@@ -207,6 +257,19 @@ private:
// Command used when a rule has no dependencies or commands.
std::vector<std::string> m_EmptyCommands;
+ //==========================================================================
+ // Configuration settings.
+ int m_MakefileVariableSize;
+ std::map<cmStdString, cmStdString> m_MakeVariableMap;
+ std::map<cmStdString, cmStdString> m_ShortMakeVariableMap;
+ std::map<cmStdString, cmStdString> m_UniqueObjectNamesMap;
+ std::string m_IncludeDirective;
+ std::string m_MakeSilentFlag;
+ std::string m_ExecutableOutputPath;
+ std::string m_LibraryOutputPath;
+ bool m_PassMakeflags;
+ //==========================================================================
+
// List of make rule files that need to be included by the makefile.
std::vector<std::string> m_IncludeRuleFiles;