Ninja: more searching for windres

search for windres with and without prefix,
and also when only CXX compiler is set.
This commit is contained in:
Peter Kümmel 2012-07-15 19:38:51 +02:00
parent 78588e0343
commit 6547f369e4
1 changed files with 23 additions and 8 deletions

View File

@ -474,15 +474,30 @@ void cmGlobalNinjaGenerator
if(mf->IsOn("CMAKE_COMPILER_IS_MINGW")) if(mf->IsOn("CMAKE_COMPILER_IS_MINGW"))
{ {
UsingMinGW = true; UsingMinGW = true;
if(!mf->GetDefinition("CMAKE_RC_COMPILER") if(!mf->GetDefinition("CMAKE_RC_COMPILER"))
&& mf->GetDefinition("CMAKE_C_COMPILER"))
{ {
std::string windres = "windres"; std::string windres = cmSystemTools::FindProgram("windres");
std::string gcc = mf->GetDefinition("CMAKE_C_COMPILER"); if(windres.empty())
std::string::size_type prefix = gcc.rfind("gcc"); {
std::string path;
std::string::size_type prefix = std::string::npos;
if (mf->GetDefinition("CMAKE_C_COMPILER"))
{
path = mf->GetDefinition("CMAKE_C_COMPILER");
prefix = path.rfind("gcc");
}
else if (mf->GetDefinition("CMAKE_CXX_COMPILER"))
{
path = mf->GetDefinition("CMAKE_CXX_COMPILER");
prefix = path.rfind("++");
prefix--;
}
if (prefix != std::string::npos) if (prefix != std::string::npos)
windres.insert(0, gcc.substr(0, prefix)); {
windres = path.substr(0, prefix) + "windres";
windres = cmSystemTools::FindProgram(windres.c_str()); windres = cmSystemTools::FindProgram(windres.c_str());
}
}
if(!windres.empty()) if(!windres.empty())
mf->AddDefinition("CMAKE_RC_COMPILER", windres.c_str()); mf->AddDefinition("CMAKE_RC_COMPILER", windres.c_str());
} }