ENH: Added support for UNIX compilers. GCC and MIPSpro are supported.

This commit is contained in:
Brad King 2001-07-23 11:54:25 -04:00
parent 572ecc9b8a
commit 4a52b0e6c3
2 changed files with 115 additions and 2 deletions

View File

@ -78,6 +78,25 @@ bool cmConfigureGccXmlCommand::InitialPass(std::vector<std::string>& args)
#else #else
// On UNIX, we have to determine which compiler is being used, and // On UNIX, we have to determine which compiler is being used, and
// attempt to use that compiler's support directory. // attempt to use that compiler's support directory.
if(this->CompilerIsGCC())
{
if(!this->FindGccIncludeFlags())
{
return false;
}
}
else if(this->CompilerIsMipsPro())
{
if(!this->FindMproIncludeFlags())
{
return false;
}
}
else
{
this->SetError("Compiler is not supported by GCC-XML!");
return false;
}
#endif #endif
// Add the cache entry with the flags found. // Add the cache entry with the flags found.
@ -121,6 +140,7 @@ std::string cmConfigureGccXmlCommand::GetSupportDirectory(const char* exeLoc)
return dir; return dir;
} }
/** /**
* Find the flags needed to use the Visual C++ support library. * Find the flags needed to use the Visual C++ support library.
*/ */
@ -131,7 +151,7 @@ bool cmConfigureGccXmlCommand::FindVcIncludeFlags()
if(!flagsFile) if(!flagsFile)
{ {
std::string err = "Cannot open GCC-XML flags file \""+fname+"\""; std::string err = "Cannot open GCC-XML flags file \""+fname+"\".";
this->SetError(err.c_str()); this->SetError(err.c_str());
return false; return false;
} }
@ -141,7 +161,7 @@ bool cmConfigureGccXmlCommand::FindVcIncludeFlags()
flagsFile.getline(buf, 4096); flagsFile.getline(buf, 4096);
if(!flagsFile) if(!flagsFile)
{ {
std::string err = "Error reading from GCC-XML flags file \""+fname+"\""; std::string err = "Error reading from GCC-XML flags file \""+fname+"\".";
this->SetError(err.c_str()); this->SetError(err.c_str());
return false; return false;
} }
@ -150,3 +170,92 @@ bool cmConfigureGccXmlCommand::FindVcIncludeFlags()
return true; return true;
} }
/**
* Find the flags needed to use the GCC support library.
*/
bool cmConfigureGccXmlCommand::FindGccIncludeFlags()
{
std::string supportDir = m_SupportDir+"/GccInclude";
if(!cmSystemTools::FileIsDirectory(supportDir.c_str()))
{
std::string err = "No GCC support library for GCC-XML. Couldn't find directory \""+supportDir+"\".";
this->SetError(err.c_str());
return false;
}
// Try to run the find_gcc_options command.
std::string command = supportDir+"/find_gcc_options";
std::string flags;
if(!cmSystemTools::RunCommand(command.c_str(), flags))
{
this->SetError("Could not run find_gcc_options!");
return false;
}
// Use the result of the command as the flags.
m_Flags = flags;
return true;
}
/**
* Find the flags needed to use the MIPSpro support library.
*/
bool cmConfigureGccXmlCommand::FindMproIncludeFlags()
{
std::string supportDir = m_SupportDir+"/MproInclude";
if(!cmSystemTools::FileIsDirectory(supportDir.c_str()))
{
std::string err = "No MIPSpro support library for GCC-XML. Couldn't find directory \""+supportDir+"\".";
this->SetError(err.c_str());
return false;
}
// Try to run the find_mpro_options command.
std::string command = supportDir+"/find_mpro_options";
std::string flags;
if(!cmSystemTools::RunCommand(command.c_str(), flags))
{
this->SetError("Could not run find_mpro_options!");
return false;
}
// Use the result of the command as the flags. Also prefix on the
// include path flag for the support directory.
m_Flags = "-I"+supportDir+" "+flags;
return true;
}
/**
* Determine whether the compiler is GCC.
*/
bool cmConfigureGccXmlCommand::CompilerIsGCC() const
{
const char* isGNU = m_Makefile->GetDefinition("CMAKE_COMPILER_IS_GNUCXX");
return (isGNU && !cmSystemTools::IsOff(isGNU));
}
/**
* Determine whether the compiler is MipsPro.
*/
bool cmConfigureGccXmlCommand::CompilerIsMipsPro() const
{
const char* compiler = m_Makefile->GetDefinition("CMAKE_CXX_COMPILER");
if(!compiler) { return false; }
std::string command = compiler;
command += " -version";
std::string output;
if(!cmSystemTools::RunCommand(command.c_str(), output, false))
{ return false; }
if(output.find("MIPSpro") != std::string::npos)
{
return true;
}
return false;
}

View File

@ -99,6 +99,10 @@ public:
protected: protected:
std::string GetSupportDirectory(const char*); std::string GetSupportDirectory(const char*);
bool FindVcIncludeFlags(); bool FindVcIncludeFlags();
bool FindGccIncludeFlags();
bool FindMproIncludeFlags();
bool CompilerIsGCC() const;
bool CompilerIsMipsPro() const;
private: private:
std::string m_SupportDir; std::string m_SupportDir;