mirror of
https://github.com/reactos/CMake.git
synced 2024-11-24 20:19:53 +00:00
VS: Choose flag map based on the toolset name
MSBuild interprets the `.vcxproj` content based on the `PlatformToolset` setting, so our reverse mapping needs to be based on that setting too. For VS 2010 and above, choose the flag map to match the toolset name rather than the generator VS version. Issue: #16153
This commit is contained in:
parent
e2ed9a7092
commit
69fc7bf87d
@ -680,6 +680,8 @@ if (WIN32)
|
||||
cmVisualStudioGeneratorOptions.cxx
|
||||
cmVisualStudio10TargetGenerator.h
|
||||
cmVisualStudio10TargetGenerator.cxx
|
||||
cmVisualStudio10ToolsetOptions.h
|
||||
cmVisualStudio10ToolsetOptions.cxx
|
||||
cmLocalVisualStudio10Generator.cxx
|
||||
cmLocalVisualStudio10Generator.h
|
||||
cmGlobalVisualStudio10Generator.h
|
||||
|
@ -617,25 +617,40 @@ std::string cmGlobalVisualStudio10Generator::GetInstalledNsightTegraVersion()
|
||||
|
||||
cmIDEFlagTable const* cmGlobalVisualStudio10Generator::GetClFlagTable() const
|
||||
{
|
||||
return this->DefaultClFlagTable;
|
||||
cmIDEFlagTable const* table = this->ToolsetOptions.GetClFlagTable(
|
||||
this->GetPlatformName(), this->GetPlatformToolsetString());
|
||||
|
||||
return (table != CM_NULLPTR) ? table : this->DefaultClFlagTable;
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmGlobalVisualStudio10Generator::GetRcFlagTable() const
|
||||
{
|
||||
return this->DefaultRcFlagTable;
|
||||
cmIDEFlagTable const* table = this->ToolsetOptions.GetRcFlagTable(
|
||||
this->GetPlatformName(), this->GetPlatformToolsetString());
|
||||
|
||||
return (table != CM_NULLPTR) ? table : this->DefaultRcFlagTable;
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmGlobalVisualStudio10Generator::GetLibFlagTable() const
|
||||
{
|
||||
return this->DefaultLibFlagTable;
|
||||
cmIDEFlagTable const* table = this->ToolsetOptions.GetLibFlagTable(
|
||||
this->GetPlatformName(), this->GetPlatformToolsetString());
|
||||
|
||||
return (table != CM_NULLPTR) ? table : this->DefaultLibFlagTable;
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmGlobalVisualStudio10Generator::GetLinkFlagTable() const
|
||||
{
|
||||
return this->DefaultLinkFlagTable;
|
||||
cmIDEFlagTable const* table = this->ToolsetOptions.GetLinkFlagTable(
|
||||
this->GetPlatformName(), this->GetPlatformToolsetString());
|
||||
|
||||
return (table != CM_NULLPTR) ? table : this->DefaultLinkFlagTable;
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmGlobalVisualStudio10Generator::GetMasmFlagTable() const
|
||||
{
|
||||
return this->DefaultMasmFlagTable;
|
||||
cmIDEFlagTable const* table = this->ToolsetOptions.GetMasmFlagTable(
|
||||
this->GetPlatformName(), this->GetPlatformToolsetString());
|
||||
|
||||
return (table != CM_NULLPTR) ? table : this->DefaultMasmFlagTable;
|
||||
}
|
||||
|
@ -4,6 +4,7 @@
|
||||
#define cmGlobalVisualStudio10Generator_h
|
||||
|
||||
#include "cmGlobalVisualStudio8Generator.h"
|
||||
#include "cmVisualStudio10ToolsetOptions.h"
|
||||
|
||||
/** \class cmGlobalVisualStudio10Generator
|
||||
* \brief Write a Unix makefiles.
|
||||
@ -146,6 +147,7 @@ private:
|
||||
|
||||
std::string MSBuildCommand;
|
||||
bool MSBuildCommandInitialized;
|
||||
cmVisualStudio10ToolsetOptions ToolsetOptions;
|
||||
virtual std::string FindMSBuildCommand();
|
||||
virtual std::string FindDevEnvCommand();
|
||||
virtual std::string GetVSMakeProgram() { return this->GetMSBuildCommand(); }
|
||||
|
134
Source/cmVisualStudio10ToolsetOptions.cxx
Normal file
134
Source/cmVisualStudio10ToolsetOptions.cxx
Normal file
@ -0,0 +1,134 @@
|
||||
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
||||
file Copyright.txt or https://cmake.org/licensing for details. */
|
||||
#include "cmVisualStudio10ToolsetOptions.h"
|
||||
|
||||
#include "cmAlgorithms.h"
|
||||
#include "cmIDEFlagTable.h"
|
||||
#include "cmVisualStudioGeneratorOptions.h"
|
||||
|
||||
#include "cmVS10CLFlagTable.h"
|
||||
#include "cmVS10LibFlagTable.h"
|
||||
#include "cmVS10LinkFlagTable.h"
|
||||
#include "cmVS10MASMFlagTable.h"
|
||||
#include "cmVS10RCFlagTable.h"
|
||||
#include "cmVS11CLFlagTable.h"
|
||||
#include "cmVS11LibFlagTable.h"
|
||||
#include "cmVS11LinkFlagTable.h"
|
||||
#include "cmVS11MASMFlagTable.h"
|
||||
#include "cmVS11RCFlagTable.h"
|
||||
#include "cmVS12CLFlagTable.h"
|
||||
#include "cmVS12LibFlagTable.h"
|
||||
#include "cmVS12LinkFlagTable.h"
|
||||
#include "cmVS12MASMFlagTable.h"
|
||||
#include "cmVS12RCFlagTable.h"
|
||||
#include "cmVS140CLFlagTable.h"
|
||||
#include "cmVS141CLFlagTable.h"
|
||||
#include "cmVS14LibFlagTable.h"
|
||||
#include "cmVS14LinkFlagTable.h"
|
||||
#include "cmVS14MASMFlagTable.h"
|
||||
#include "cmVS14RCFlagTable.h"
|
||||
|
||||
cmIDEFlagTable const* cmVisualStudio10ToolsetOptions::GetClFlagTable(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
std::string const useToolset = this->GetToolsetName(name, toolset);
|
||||
|
||||
if (toolset == "v141") {
|
||||
return cmVS141CLFlagTable;
|
||||
} else if (useToolset == "v140") {
|
||||
return cmVS140CLFlagTable;
|
||||
} else if (useToolset == "v120") {
|
||||
return cmVS12CLFlagTable;
|
||||
} else if (useToolset == "v110") {
|
||||
return cmVS11CLFlagTable;
|
||||
} else if (useToolset == "v100") {
|
||||
return cmVS10CLFlagTable;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmVisualStudio10ToolsetOptions::GetRcFlagTable(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
std::string const useToolset = this->GetToolsetName(name, toolset);
|
||||
|
||||
if ((useToolset == "v140") || (useToolset == "v141")) {
|
||||
return cmVS14RCFlagTable;
|
||||
} else if (useToolset == "v120") {
|
||||
return cmVS12RCFlagTable;
|
||||
} else if (useToolset == "v110") {
|
||||
return cmVS11RCFlagTable;
|
||||
} else if (useToolset == "v100") {
|
||||
return cmVS10RCFlagTable;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmVisualStudio10ToolsetOptions::GetLibFlagTable(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
std::string const useToolset = this->GetToolsetName(name, toolset);
|
||||
|
||||
if ((useToolset == "v140") || (useToolset == "v141")) {
|
||||
return cmVS14LibFlagTable;
|
||||
} else if (useToolset == "v120") {
|
||||
return cmVS12LibFlagTable;
|
||||
} else if (useToolset == "v110") {
|
||||
return cmVS11LibFlagTable;
|
||||
} else if (useToolset == "v100") {
|
||||
return cmVS10LibFlagTable;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmVisualStudio10ToolsetOptions::GetLinkFlagTable(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
std::string const useToolset = this->GetToolsetName(name, toolset);
|
||||
|
||||
if ((useToolset == "v140") || (useToolset == "v141")) {
|
||||
return cmVS14LinkFlagTable;
|
||||
} else if (useToolset == "v120") {
|
||||
return cmVS12LinkFlagTable;
|
||||
} else if (useToolset == "v110") {
|
||||
return cmVS11LinkFlagTable;
|
||||
} else if (useToolset == "v100") {
|
||||
return cmVS10LinkFlagTable;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
cmIDEFlagTable const* cmVisualStudio10ToolsetOptions::GetMasmFlagTable(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
std::string const useToolset = this->GetToolsetName(name, toolset);
|
||||
|
||||
if ((useToolset == "v140") || (useToolset == "v141")) {
|
||||
return cmVS14MASMFlagTable;
|
||||
} else if (useToolset == "v120") {
|
||||
return cmVS12MASMFlagTable;
|
||||
} else if (useToolset == "v110") {
|
||||
return cmVS11MASMFlagTable;
|
||||
} else if (useToolset == "v100") {
|
||||
return cmVS10MASMFlagTable;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
std::string cmVisualStudio10ToolsetOptions::GetToolsetName(
|
||||
std::string const& name, std::string const& toolset) const
|
||||
{
|
||||
static_cast<void>(name);
|
||||
std::size_t length = toolset.length();
|
||||
|
||||
if (cmHasLiteralSuffix(toolset, "_xp")) {
|
||||
length -= 3;
|
||||
}
|
||||
|
||||
return toolset.substr(0, length);
|
||||
}
|
33
Source/cmVisualStudio10ToolsetOptions.h
Normal file
33
Source/cmVisualStudio10ToolsetOptions.h
Normal file
@ -0,0 +1,33 @@
|
||||
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
||||
file Copyright.txt or https://cmake.org/licensing for details. */
|
||||
#ifndef cmVisualStudio10ToolsetOptions_h
|
||||
#define cmVisualStudio10ToolsetOptions_h
|
||||
|
||||
#include "cmStandardIncludes.h"
|
||||
|
||||
struct cmIDEFlagTable;
|
||||
|
||||
/** \class cmVisualStudio10ToolsetOptions
|
||||
* \brief Retrieves toolset options for MSBuild.
|
||||
*
|
||||
* cmVisualStudio10ToolsetOptions manages toolsets within MSBuild
|
||||
*/
|
||||
class cmVisualStudio10ToolsetOptions
|
||||
{
|
||||
public:
|
||||
cmIDEFlagTable const* GetClFlagTable(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
cmIDEFlagTable const* GetRcFlagTable(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
cmIDEFlagTable const* GetLibFlagTable(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
cmIDEFlagTable const* GetLinkFlagTable(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
cmIDEFlagTable const* GetMasmFlagTable(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
|
||||
private:
|
||||
std::string GetToolsetName(std::string const& name,
|
||||
std::string const& toolset) const;
|
||||
};
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user