BUG: keep more of the case information
This commit is contained in:
parent
79c23436d3
commit
09ba0a0a31
@ -73,11 +73,6 @@ std::string cmLocalGenerator::ConvertToRelativeOutputPath(const char* p)
|
|||||||
m_CurrentOutputDirectory = m_Makefile->GetCurrentOutputDirectory();
|
m_CurrentOutputDirectory = m_Makefile->GetCurrentOutputDirectory();
|
||||||
m_HomeOutputDirectory = m_Makefile->GetHomeOutputDirectory();
|
m_HomeOutputDirectory = m_Makefile->GetHomeOutputDirectory();
|
||||||
m_HomeDirectory = m_Makefile->GetHomeDirectory();
|
m_HomeDirectory = m_Makefile->GetHomeDirectory();
|
||||||
#if defined(_WIN32) || defined(__APPLE__)
|
|
||||||
m_CurrentOutputDirectory = cmSystemTools::LowerCase(m_CurrentOutputDirectory);
|
|
||||||
m_HomeOutputDirectory = cmSystemTools::LowerCase(m_HomeOutputDirectory);
|
|
||||||
m_HomeDirectory = cmSystemTools::LowerCase(m_HomeDirectory);
|
|
||||||
#endif
|
|
||||||
if(m_RelativePathToSourceDir.size() == 0)
|
if(m_RelativePathToSourceDir.size() == 0)
|
||||||
{
|
{
|
||||||
m_RelativePathToSourceDir = cmSystemTools::RelativePath(
|
m_RelativePathToSourceDir = cmSystemTools::RelativePath(
|
||||||
@ -102,16 +97,53 @@ std::string cmLocalGenerator::ConvertToRelativeOutputPath(const char* p)
|
|||||||
|
|
||||||
// Do the work of converting to a relative path
|
// Do the work of converting to a relative path
|
||||||
std::string pathIn = p;
|
std::string pathIn = p;
|
||||||
#if defined(_WIN32) || defined(__APPLE__)
|
|
||||||
pathIn = cmSystemTools::LowerCase(pathIn);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
std::string ret = pathIn;
|
std::string ret = pathIn;
|
||||||
cmSystemTools::ReplaceString(ret, m_CurrentOutputDirectory.c_str(), "");
|
if(m_CurrentOutputDirectory.size() <= ret.size())
|
||||||
cmSystemTools::ReplaceString(ret, m_HomeDirectory.c_str(),
|
{
|
||||||
m_RelativePathToSourceDir.c_str());
|
std::string sub = ret.substr(0, m_CurrentOutputDirectory.size());
|
||||||
cmSystemTools::ReplaceString(ret, m_HomeOutputDirectory.c_str(),
|
if(
|
||||||
m_RelativePathToBinaryDir.c_str());
|
#if defined(_WIN32) || defined(__APPLE__)
|
||||||
|
cmSystemTools::LowerCase(sub) ==
|
||||||
|
cmSystemTools::LowerCase(m_CurrentOutputDirectory)
|
||||||
|
#else
|
||||||
|
sub == m_CurrentOutputDirectory
|
||||||
|
#endif
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ret = ret.substr(m_CurrentOutputDirectory.size(), ret.npos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(m_HomeDirectory.size() <= ret.size())
|
||||||
|
{
|
||||||
|
std::string sub = ret.substr(0, m_HomeDirectory.size());
|
||||||
|
if(
|
||||||
|
#if defined(_WIN32) || defined(__APPLE__)
|
||||||
|
cmSystemTools::LowerCase(sub) ==
|
||||||
|
cmSystemTools::LowerCase(m_HomeDirectory)
|
||||||
|
#else
|
||||||
|
sub == m_HomeDirectory
|
||||||
|
#endif
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ret = m_RelativePathToSourceDir + ret.substr(m_HomeDirectory.size(), ret.npos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(m_HomeOutputDirectory.size() <= ret.size())
|
||||||
|
{
|
||||||
|
std::string sub = ret.substr(0, m_HomeOutputDirectory.size());
|
||||||
|
if(
|
||||||
|
#if defined(_WIN32) || defined(__APPLE__)
|
||||||
|
cmSystemTools::LowerCase(sub) ==
|
||||||
|
cmSystemTools::LowerCase(m_HomeOutputDirectory)
|
||||||
|
#else
|
||||||
|
sub == m_HomeOutputDirectory
|
||||||
|
#endif
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ret = m_RelativePathToBinaryDir + ret.substr(m_HomeOutputDirectory.size(), ret.npos);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::string relpath = m_RelativePathToBinaryDir;
|
std::string relpath = m_RelativePathToBinaryDir;
|
||||||
if(relpath.size())
|
if(relpath.size())
|
||||||
{
|
{
|
||||||
@ -121,7 +153,14 @@ std::string cmLocalGenerator::ConvertToRelativeOutputPath(const char* p)
|
|||||||
{
|
{
|
||||||
relpath = ".";
|
relpath = ".";
|
||||||
}
|
}
|
||||||
if(ret == m_HomeOutputDirectoryNoSlash)
|
if(
|
||||||
|
#if defined(_WIN32) || defined(__APPLE__)
|
||||||
|
cmSystemTools::LowerCase(ret) ==
|
||||||
|
cmSystemTools::LowerCase(m_HomeOutputDirectoryNoSlash)
|
||||||
|
#else
|
||||||
|
ret == m_HomeOutputDirectoryNoSlash
|
||||||
|
#endif
|
||||||
|
)
|
||||||
{
|
{
|
||||||
ret = relpath;
|
ret = relpath;
|
||||||
}
|
}
|
||||||
|
@ -15,9 +15,9 @@
|
|||||||
|
|
||||||
=========================================================================*/
|
=========================================================================*/
|
||||||
#include "cmTryCompileCommand.h"
|
#include "cmTryCompileCommand.h"
|
||||||
|
#include "cmake.h"
|
||||||
#include "cmCacheManager.h"
|
#include "cmCacheManager.h"
|
||||||
#include "cmListFileCache.h"
|
#include "cmListFileCache.h"
|
||||||
|
|
||||||
#include <cmsys/Directory.hxx>
|
#include <cmsys/Directory.hxx>
|
||||||
|
|
||||||
int cmTryCompileCommand::CoreTryCompileCode(
|
int cmTryCompileCommand::CoreTryCompileCode(
|
||||||
@ -236,9 +236,11 @@ int cmTryCompileCommand::CoreTryCompileCode(
|
|||||||
if (srcFileSignature && clean)
|
if (srcFileSignature && clean)
|
||||||
{
|
{
|
||||||
cmListFileCache::GetInstance()->FlushCache(outFileName.c_str());
|
cmListFileCache::GetInstance()->FlushCache(outFileName.c_str());
|
||||||
cmTryCompileCommand::CleanupFiles(binaryDirectory);
|
if(!mf->GetCMakeInstance()->GetDebugTryCompile())
|
||||||
|
{
|
||||||
|
cmTryCompileCommand::CleanupFiles(binaryDirectory);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -266,6 +268,7 @@ void cmTryCompileCommand::CleanupFiles(const char* binDir)
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string bdir = binDir;
|
std::string bdir = binDir;
|
||||||
if(bdir.find("CMakeTmp") == std::string::npos)
|
if(bdir.find("CMakeTmp") == std::string::npos)
|
||||||
{
|
{
|
||||||
|
@ -64,6 +64,7 @@ void cmNeedBackwardsCompatibility(const std::string& variable,
|
|||||||
|
|
||||||
cmake::cmake()
|
cmake::cmake()
|
||||||
{
|
{
|
||||||
|
m_DebugTryCompile = false;
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
struct rlimit rlp;
|
struct rlimit rlp;
|
||||||
if(!getrlimit(RLIMIT_STACK, &rlp))
|
if(!getrlimit(RLIMIT_STACK, &rlp))
|
||||||
@ -320,6 +321,11 @@ void cmake::SetArgs(const std::vector<std::string>& args)
|
|||||||
{
|
{
|
||||||
// skip for now
|
// skip for now
|
||||||
}
|
}
|
||||||
|
else if(arg.find("--debug-trycompile",0) == 0)
|
||||||
|
{
|
||||||
|
std::cout << "debug trycompile on\n";
|
||||||
|
this->DebugTryCompileOn();
|
||||||
|
}
|
||||||
else if(arg.find("-G",0) == 0)
|
else if(arg.find("-G",0) == 0)
|
||||||
{
|
{
|
||||||
std::string value = arg.substr(2);
|
std::string value = arg.substr(2);
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#ifndef cmake_h
|
||||||
|
#define cmake_h
|
||||||
/*=========================================================================
|
/*=========================================================================
|
||||||
|
|
||||||
Program: CMake - Cross-Platform Makefile Generator
|
Program: CMake - Cross-Platform Makefile Generator
|
||||||
@ -252,6 +254,10 @@ class cmake
|
|||||||
void SetScriptMode(bool mode) { m_ScriptMode = mode; }
|
void SetScriptMode(bool mode) { m_ScriptMode = mode; }
|
||||||
bool GetScriptMode() { return m_ScriptMode; }
|
bool GetScriptMode() { return m_ScriptMode; }
|
||||||
|
|
||||||
|
///! Debug the try compile stuff by not delelting the files
|
||||||
|
bool GetDebugTryCompile(){return m_DebugTryCompile;}
|
||||||
|
void DebugTryCompileOn(){m_DebugTryCompile = true;}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef cmGlobalGenerator* (*CreateGeneratorFunctionType)();
|
typedef cmGlobalGenerator* (*CreateGeneratorFunctionType)();
|
||||||
typedef std::map<cmStdString, CreateGeneratorFunctionType> RegisteredGeneratorsMap;
|
typedef std::map<cmStdString, CreateGeneratorFunctionType> RegisteredGeneratorsMap;
|
||||||
@ -294,6 +300,7 @@ private:
|
|||||||
std::string m_CMakeCommand;
|
std::string m_CMakeCommand;
|
||||||
const char* m_CXXEnvironment;
|
const char* m_CXXEnvironment;
|
||||||
const char* m_CCEnvironment;
|
const char* m_CCEnvironment;
|
||||||
|
bool m_DebugTryCompile;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define CMAKE_STANDARD_OPTIONS_TABLE \
|
#define CMAKE_STANDARD_OPTIONS_TABLE \
|
||||||
@ -323,3 +330,4 @@ private:
|
|||||||
"included in each directory of a source tree with the name CMakeLists.txt. " \
|
"included in each directory of a source tree with the name CMakeLists.txt. " \
|
||||||
"Users build a project by using CMake to generate a build system " \
|
"Users build a project by using CMake to generate a build system " \
|
||||||
"for a native tool on their platform.", 0}
|
"for a native tool on their platform.", 0}
|
||||||
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user