ENH: nmake generator much closer to working with spaces
This commit is contained in:
parent
1944e1887d
commit
0180d3156f
|
@ -48,6 +48,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include "cmGeneratedFileStream.h"
|
#include "cmGeneratedFileStream.h"
|
||||||
#include "windows.h"
|
#include "windows.h"
|
||||||
|
|
||||||
|
// convert to windows short paths if there are spaces
|
||||||
|
// in path
|
||||||
inline std::string ShortPath(const char* path)
|
inline std::string ShortPath(const char* path)
|
||||||
{
|
{
|
||||||
std::string ret = path;
|
std::string ret = path;
|
||||||
|
@ -75,6 +77,34 @@ inline std::string ShortPath(const char* path)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// convert a command to a short path if it has spaces
|
||||||
|
// this separates the arguments from the command and puts
|
||||||
|
// them back together
|
||||||
|
inline std::string ShortPathCommand(const char* command)
|
||||||
|
{
|
||||||
|
if(!strchr(command, ' '))
|
||||||
|
{
|
||||||
|
return command;
|
||||||
|
}
|
||||||
|
cmRegularExpression reg("^\"([^\"]*)\"(.*)");
|
||||||
|
if(reg.find(command))
|
||||||
|
{
|
||||||
|
std::string c = reg.match(1);
|
||||||
|
cmRegularExpression removeIntDir("(.*)/\\$\\(IntDir\\)(.*)");
|
||||||
|
if(removeIntDir.find(c))
|
||||||
|
{
|
||||||
|
c = removeIntDir.match(1) + removeIntDir.match(2);
|
||||||
|
}
|
||||||
|
c = ShortPath(c.c_str());
|
||||||
|
std::string ret = c;
|
||||||
|
std::string args = reg.match(2);
|
||||||
|
ret += args;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
return command;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
cmNMakeMakefileGenerator::cmNMakeMakefileGenerator()
|
cmNMakeMakefileGenerator::cmNMakeMakefileGenerator()
|
||||||
{
|
{
|
||||||
this->SetObjectFileExtension(".obj");
|
this->SetObjectFileExtension(".obj");
|
||||||
|
@ -89,6 +119,7 @@ cmNMakeMakefileGenerator::~cmNMakeMakefileGenerator()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void cmNMakeMakefileGenerator::ComputeSystemInfo()
|
void cmNMakeMakefileGenerator::ComputeSystemInfo()
|
||||||
{
|
{
|
||||||
// now load the settings
|
// now load the settings
|
||||||
|
@ -184,6 +215,9 @@ void cmNMakeMakefileGenerator::BuildInSubDirectory(std::ostream& fout,
|
||||||
fout << "\tcd " << cmSystemTools::EscapeSpaces(currentDir.c_str()) << "\n";
|
fout << "\tcd " << cmSystemTools::EscapeSpaces(currentDir.c_str()) << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// This needs to be overriden because nmake requires commands to be quoted
|
// This needs to be overriden because nmake requires commands to be quoted
|
||||||
// if the are full paths to the executable????
|
// if the are full paths to the executable????
|
||||||
|
|
||||||
|
@ -232,25 +266,25 @@ void cmNMakeMakefileGenerator::OutputMakeRule(std::ostream& fout,
|
||||||
}
|
}
|
||||||
if(command)
|
if(command)
|
||||||
{
|
{
|
||||||
replace = command;
|
replace = ShortPathCommand(command);
|
||||||
m_Makefile->ExpandVariablesInString(replace);
|
m_Makefile->ExpandVariablesInString(replace);
|
||||||
fout << startCommand << replace.c_str() << endCommand;
|
fout << startCommand << replace.c_str() << endCommand;
|
||||||
}
|
}
|
||||||
if(command2)
|
if(command2)
|
||||||
{
|
{
|
||||||
replace = command2;
|
replace = ShortPathCommand(command2);
|
||||||
m_Makefile->ExpandVariablesInString(replace);
|
m_Makefile->ExpandVariablesInString(replace);
|
||||||
fout << startCommand << replace.c_str() << endCommand;
|
fout << startCommand << replace.c_str() << endCommand;
|
||||||
}
|
}
|
||||||
if(command3)
|
if(command3)
|
||||||
{
|
{
|
||||||
replace = command3;
|
replace = ShortPathCommand(command3);
|
||||||
m_Makefile->ExpandVariablesInString(replace);
|
m_Makefile->ExpandVariablesInString(replace);
|
||||||
fout << startCommand << replace.c_str() << endCommand;
|
fout << startCommand << replace.c_str() << endCommand;
|
||||||
}
|
}
|
||||||
if(command4)
|
if(command4)
|
||||||
{
|
{
|
||||||
replace = command4;
|
replace = ShortPathCommand(command4);
|
||||||
m_Makefile->ExpandVariablesInString(replace);
|
m_Makefile->ExpandVariablesInString(replace);
|
||||||
fout << startCommand << replace.c_str() << endCommand;
|
fout << startCommand << replace.c_str() << endCommand;
|
||||||
}
|
}
|
||||||
|
@ -339,7 +373,8 @@ void cmNMakeMakefileGenerator::OutputSharedLibraryRule(std::ostream& fout,
|
||||||
depend += "_SRC_OBJS) $(" + std::string(name) + "_DEPEND_LIBS)";
|
depend += "_SRC_OBJS) $(" + std::string(name) + "_DEPEND_LIBS)";
|
||||||
std::string command = "link /dll @<<\n";
|
std::string command = "link /dll @<<\n";
|
||||||
command += "$(" + std::string(name) + "_SRC_OBJS) /out:";
|
command += "$(" + std::string(name) + "_SRC_OBJS) /out:";
|
||||||
command += m_LibraryOutputPath + std::string(name) + ".dll ";
|
std::string dllpath = m_LibraryOutputPath + std::string(name) + ".dll ";
|
||||||
|
command += cmSystemTools::EscapeSpaces(dllpath.c_str());
|
||||||
std::strstream linklibs;
|
std::strstream linklibs;
|
||||||
this->OutputLinkLibraries(linklibs, name, t);
|
this->OutputLinkLibraries(linklibs, name, t);
|
||||||
linklibs << std::ends;
|
linklibs << std::ends;
|
||||||
|
@ -378,9 +413,9 @@ void cmNMakeMakefileGenerator::OutputStaticLibraryRule(std::ostream& fout,
|
||||||
std::string depend = "$(";
|
std::string depend = "$(";
|
||||||
depend += std::string(name) + "_SRC_OBJS)";
|
depend += std::string(name) + "_SRC_OBJS)";
|
||||||
std::string command = "link -lib @<<\n\t/nologo /out:";
|
std::string command = "link -lib @<<\n\t/nologo /out:";
|
||||||
command += m_LibraryOutputPath;
|
std::string libpath = m_LibraryOutputPath + std::string(name) + ".lib";
|
||||||
command += name;
|
command += cmSystemTools::EscapeSpaces(libpath.c_str());
|
||||||
command += ".lib $(";
|
command += " $(";
|
||||||
command += std::string(name) + "_SRC_OBJS)";
|
command += std::string(name) + "_SRC_OBJS)";
|
||||||
command += "\n<<\n";
|
command += "\n<<\n";
|
||||||
std::string comment = "rule to build static library: ";
|
std::string comment = "rule to build static library: ";
|
||||||
|
@ -466,16 +501,25 @@ void cmNMakeMakefileGenerator::OutputLinkLibraries(std::ostream& fout,
|
||||||
// skip zero size library entries, this may happen
|
// skip zero size library entries, this may happen
|
||||||
// if a variable expands to nothing.
|
// if a variable expands to nothing.
|
||||||
if (lib->first.size() == 0) continue;
|
if (lib->first.size() == 0) continue;
|
||||||
// if it is a full path break it into -L and -l
|
|
||||||
if(emitted.insert(lib->first).second)
|
if(emitted.insert(lib->first).second)
|
||||||
{
|
{
|
||||||
linkLibs += lib->first;
|
cmRegularExpression reg(".*\\.lib$");
|
||||||
linkLibs += ".lib ";
|
// if it ends in .lib, then it is a full path and should
|
||||||
|
// be escaped, and does not need .lib added
|
||||||
|
if(reg.find(lib->first))
|
||||||
|
{
|
||||||
|
librariesLinked += ShortPath(lib->first.c_str());
|
||||||
|
librariesLinked += " ";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
librariesLinked += lib->first;
|
||||||
|
librariesLinked += ".lib ";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
linkLibs += librariesLinked;
|
|
||||||
|
|
||||||
fout << linkLibs;
|
|
||||||
}
|
}
|
||||||
|
linkLibs += librariesLinked;
|
||||||
|
fout << linkLibs;
|
||||||
fout << "$(CMAKE_STANDARD_WINDOWS_LIBRARIES) ";
|
fout << "$(CMAKE_STANDARD_WINDOWS_LIBRARIES) ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -505,3 +549,19 @@ void cmNMakeMakefileGenerator::OutputIncludeMakefile(std::ostream& fout,
|
||||||
fout << "!include " << file << "\n";
|
fout << "!include " << file << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cmNMakeMakefileGenerator::OutputBuildLibraryInDir(std::ostream& fout,
|
||||||
|
const char* path,
|
||||||
|
const char* ,
|
||||||
|
const char* fullpath)
|
||||||
|
{
|
||||||
|
|
||||||
|
std::string currentDir = m_Makefile->GetCurrentOutputDirectory();
|
||||||
|
cmSystemTools::ConvertToWindowsSlashes(currentDir);
|
||||||
|
fout << cmSystemTools::EscapeSpaces(fullpath)
|
||||||
|
<< ":\n\tcd " << cmSystemTools::EscapeSpaces(path)
|
||||||
|
<< "\n\t$(MAKE) " << cmSystemTools::EscapeSpaces(fullpath)
|
||||||
|
<< "\n\tcd " <<
|
||||||
|
cmSystemTools::EscapeSpaces(currentDir.c_str()) << "\n";
|
||||||
|
}
|
||||||
|
|
|
@ -100,6 +100,10 @@ protected:
|
||||||
const cmTarget &tgt);
|
const cmTarget &tgt);
|
||||||
virtual std::string GetOutputExtension(const char* sourceExtension);
|
virtual std::string GetOutputExtension(const char* sourceExtension);
|
||||||
virtual void OutputIncludeMakefile(std::ostream&, const char* file);
|
virtual void OutputIncludeMakefile(std::ostream&, const char* file);
|
||||||
|
virtual void OutputBuildLibraryInDir(std::ostream& fout,
|
||||||
|
const char* path,
|
||||||
|
const char* library,
|
||||||
|
const char* fullpath);
|
||||||
private:
|
private:
|
||||||
bool m_QuoteNextCommand; // if this is true, OutputMakeRule
|
bool m_QuoteNextCommand; // if this is true, OutputMakeRule
|
||||||
// will not quote the next commands
|
// will not quote the next commands
|
||||||
|
|
|
@ -794,13 +794,23 @@ void cmUnixMakefileGenerator::OutputDependLibs(std::ostream& fout)
|
||||||
}
|
}
|
||||||
libpath += library;
|
libpath += library;
|
||||||
// put out a rule to build the library if it does not exist
|
// put out a rule to build the library if it does not exist
|
||||||
fout << cmSystemTools::EscapeSpaces(libpath.c_str())
|
this->OutputBuildLibraryInDir(fout,
|
||||||
<< ":\n\tcd " << cmSystemTools::EscapeSpaces(cacheValue)
|
cacheValue,
|
||||||
<< "; $(MAKE) " << m_LibraryOutputPath << library.c_str() << "\n\n";
|
library.c_str(),
|
||||||
|
libpath.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cmUnixMakefileGenerator::OutputBuildLibraryInDir(std::ostream& fout,
|
||||||
|
const char* path,
|
||||||
|
const char* ,
|
||||||
|
const char* fullpath)
|
||||||
|
{
|
||||||
|
fout << cmSystemTools::EscapeSpaces(fullpath)
|
||||||
|
<< ":\n\tcd " << cmSystemTools::EscapeSpaces(path)
|
||||||
|
<< "; $(MAKE) " << fullpath << "\n\n";
|
||||||
|
}
|
||||||
void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
|
void cmUnixMakefileGenerator::OutputLibDepend(std::ostream& fout,
|
||||||
const char* name)
|
const char* name)
|
||||||
{
|
{
|
||||||
|
@ -1005,7 +1015,7 @@ void cmUnixMakefileGenerator::OutputObjectDepends(std::ostream& fout)
|
||||||
source->GetDepends().begin();
|
source->GetDepends().begin();
|
||||||
dep != source->GetDepends().end(); ++dep)
|
dep != source->GetDepends().end(); ++dep)
|
||||||
{
|
{
|
||||||
fout << " \\\n" << dep->c_str();
|
fout << " \\\n" << cmSystemTools::EscapeSpaces(dep->c_str());
|
||||||
}
|
}
|
||||||
fout << "\n\n";
|
fout << "\n\n";
|
||||||
}
|
}
|
||||||
|
|
|
@ -151,6 +151,10 @@ protected:
|
||||||
const char* command2 = 0,
|
const char* command2 = 0,
|
||||||
const char* command3 = 0,
|
const char* command3 = 0,
|
||||||
const char* command4 = 0);
|
const char* command4 = 0);
|
||||||
|
virtual void OutputBuildLibraryInDir(std::ostream& fout,
|
||||||
|
const char* path,
|
||||||
|
const char* library,
|
||||||
|
const char* fullpath);
|
||||||
virtual std::string GetOutputExtension(const char* sourceExtension);
|
virtual std::string GetOutputExtension(const char* sourceExtension);
|
||||||
virtual void OutputIncludeMakefile(std::ostream&, const char* file);
|
virtual void OutputIncludeMakefile(std::ostream&, const char* file);
|
||||||
void SetObjectFileExtension(const char* e) { m_ObjectFileExtension = e;}
|
void SetObjectFileExtension(const char* e) { m_ObjectFileExtension = e;}
|
||||||
|
|
Loading…
Reference in New Issue