mirror of
https://github.com/reactos/CMake.git
synced 2024-12-14 23:29:57 +00:00
Merge topic 'ninja-mingw-TARGET_PDB'
9e30289
Ninja: Cannot pass a reference to an anonymous object.0a3d6a1
Ninja: make debug symbol suffix configurable by CMAKE_DEBUG_SYMBOL_SUFFIX75bbffb
Ninja: make TARGET_PDB a real .gdb file namee5a27a4
Ninja: line lengthae8124a
Ninja: also mingw needs TARGET_PDB
This commit is contained in:
commit
0f87f32fe3
@ -174,7 +174,14 @@ cmNinjaNormalTargetGenerator
|
|||||||
}
|
}
|
||||||
|
|
||||||
vars.ObjectDir = "$OBJECT_DIR";
|
vars.ObjectDir = "$OBJECT_DIR";
|
||||||
|
|
||||||
|
// TODO:
|
||||||
|
// Makefile generator expands <TARGET> to the plain target name
|
||||||
|
// with suffix. $out expands to a relative path. This difference
|
||||||
|
// could make trouble when switching to Ninja generator. Maybe
|
||||||
|
// using TARGET_NAME and RuleVariables::TargetName is a fix.
|
||||||
vars.Target = "$out";
|
vars.Target = "$out";
|
||||||
|
|
||||||
vars.SONameFlag = "$SONAME_FLAG";
|
vars.SONameFlag = "$SONAME_FLAG";
|
||||||
vars.TargetSOName = "$SONAME";
|
vars.TargetSOName = "$SONAME";
|
||||||
vars.TargetInstallNameDir = "$INSTALLNAME_DIR";
|
vars.TargetInstallNameDir = "$INSTALLNAME_DIR";
|
||||||
@ -423,7 +430,6 @@ void cmNinjaNormalTargetGenerator::WriteLinkStatement()
|
|||||||
EnsureParentDirectoryExists(path);
|
EnsureParentDirectoryExists(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO move to GetTargetPDB
|
|
||||||
cmMakefile* mf = this->GetMakefile();
|
cmMakefile* mf = this->GetMakefile();
|
||||||
if (mf->GetDefinition("MSVC_C_ARCHITECTURE_ID") ||
|
if (mf->GetDefinition("MSVC_C_ARCHITECTURE_ID") ||
|
||||||
mf->GetDefinition("MSVC_CXX_ARCHITECTURE_ID"))
|
mf->GetDefinition("MSVC_CXX_ARCHITECTURE_ID"))
|
||||||
@ -434,6 +440,20 @@ void cmNinjaNormalTargetGenerator::WriteLinkStatement()
|
|||||||
cmLocalGenerator::SHELL);
|
cmLocalGenerator::SHELL);
|
||||||
EnsureParentDirectoryExists(path);
|
EnsureParentDirectoryExists(path);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// It is common to place debug symbols at a specific place,
|
||||||
|
// so we need a plain target name in the rule available.
|
||||||
|
std::string prefix;
|
||||||
|
std::string base;
|
||||||
|
std::string suffix;
|
||||||
|
this->GetTarget()->GetFullNameComponents(prefix, base, suffix);
|
||||||
|
std::string dbg_suffix = ".dbg";
|
||||||
|
// TODO: Where to document?
|
||||||
|
if (mf->GetDefinition("CMAKE_DEBUG_SYMBOL_SUFFIX"))
|
||||||
|
dbg_suffix = mf->GetDefinition("CMAKE_DEBUG_SYMBOL_SUFFIX");
|
||||||
|
vars["TARGET_PDB"] = base + suffix + dbg_suffix;
|
||||||
|
}
|
||||||
|
|
||||||
if (mf->IsOn("CMAKE_COMPILER_IS_MINGW"))
|
if (mf->IsOn("CMAKE_COMPILER_IS_MINGW"))
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user