BUG: Add target-level COMPILE_FLAGS to the target not the individual source files. This simplifies the generated files and puts flags in a more logical order (VS6 works, VS7 needs more translation to work).
This commit is contained in:
parent
39e636a4a4
commit
7bdec94154
|
@ -432,15 +432,11 @@ void cmLocalVisualStudio6Generator::WriteGroup(const cmSourceGroup *sg, cmTarget
|
||||||
(*sf)->GetCustomCommand();
|
(*sf)->GetCustomCommand();
|
||||||
std::string compileFlags;
|
std::string compileFlags;
|
||||||
std::vector<std::string> depends;
|
std::vector<std::string> depends;
|
||||||
const char* cflags = (*sf)->GetProperty("COMPILE_FLAGS");
|
|
||||||
if(cflags)
|
// Add per-source file flags.
|
||||||
|
if(const char* cflags = (*sf)->GetProperty("COMPILE_FLAGS"))
|
||||||
{
|
{
|
||||||
compileFlags = cflags;
|
compileFlags += cflags;
|
||||||
}
|
|
||||||
if(target.GetProperty("COMPILE_FLAGS"))
|
|
||||||
{
|
|
||||||
compileFlags += " ";
|
|
||||||
compileFlags += target.GetProperty("COMPILE_FLAGS");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* lang =
|
const char* lang =
|
||||||
|
@ -1247,6 +1243,13 @@ void cmLocalVisualStudio6Generator
|
||||||
flags += " /D \"_MBCS\"";
|
flags += " /D \"_MBCS\"";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add per-target flags.
|
||||||
|
if(const char* targetFlags = target.GetProperty("COMPILE_FLAGS"))
|
||||||
|
{
|
||||||
|
flags += " ";
|
||||||
|
flags += targetFlags;
|
||||||
|
}
|
||||||
|
|
||||||
// The template files have CXX FLAGS in them, that need to be replaced.
|
// The template files have CXX FLAGS in them, that need to be replaced.
|
||||||
// There are not separate CXX and C template files, so we use the same
|
// There are not separate CXX and C template files, so we use the same
|
||||||
// variable names. The previous code sets up flags* variables to contain
|
// variable names. The previous code sets up flags* variables to contain
|
||||||
|
|
|
@ -520,6 +520,13 @@ void cmLocalVisualStudio7Generator::WriteConfiguration(std::ostream& fout,
|
||||||
programDatabase += "\"";
|
programDatabase += "\"";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add the target-specific flags.
|
||||||
|
if(const char* targetFlags = target.GetProperty("COMPILE_FLAGS"))
|
||||||
|
{
|
||||||
|
flags += " ";
|
||||||
|
flags += targetFlags;
|
||||||
|
}
|
||||||
|
|
||||||
// The intermediate directory name consists of a directory for the
|
// The intermediate directory name consists of a directory for the
|
||||||
// target and a subdirectory for the configuration name.
|
// target and a subdirectory for the configuration name.
|
||||||
std::string intermediateDir = this->GetTargetDirectory(target);
|
std::string intermediateDir = this->GetTargetDirectory(target);
|
||||||
|
@ -1084,12 +1091,7 @@ void cmLocalVisualStudio7Generator::WriteGroup(const cmSourceGroup *sg, cmTarget
|
||||||
std::string compileFlags;
|
std::string compileFlags;
|
||||||
std::string additionalDeps;
|
std::string additionalDeps;
|
||||||
|
|
||||||
// Check for extra compiler flags.
|
// Add per-source flags.
|
||||||
if(target.GetProperty("COMPILE_FLAGS"))
|
|
||||||
{
|
|
||||||
compileFlags += " ";
|
|
||||||
compileFlags += target.GetProperty("COMPILE_FLAGS");
|
|
||||||
}
|
|
||||||
const char* cflags = (*sf)->GetProperty("COMPILE_FLAGS");
|
const char* cflags = (*sf)->GetProperty("COMPILE_FLAGS");
|
||||||
if(cflags)
|
if(cflags)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue