|
@@ -858,47 +858,69 @@ CompileData Target::BuildCompileData(cmSourceFile* sf)
|
|
fd.Flags.emplace_back(std::move(flags), JBTIndex());
|
|
fd.Flags.emplace_back(std::move(flags), JBTIndex());
|
|
}
|
|
}
|
|
const std::string COMPILE_OPTIONS("COMPILE_OPTIONS");
|
|
const std::string COMPILE_OPTIONS("COMPILE_OPTIONS");
|
|
- if (const char* coptions = sf->GetProperty(COMPILE_OPTIONS)) {
|
|
|
|
- std::string flags;
|
|
|
|
- lg->AppendCompileOptions(
|
|
|
|
- flags, genexInterpreter.Evaluate(coptions, COMPILE_OPTIONS));
|
|
|
|
- fd.Flags.emplace_back(std::move(flags), JBTIndex());
|
|
|
|
|
|
+ for (BT<std::string> tmpOpt : sf->GetCompileOptions()) {
|
|
|
|
+ tmpOpt.Value = genexInterpreter.Evaluate(tmpOpt.Value, COMPILE_OPTIONS);
|
|
|
|
+ // After generator evaluation we need to use the AppendCompileOptions
|
|
|
|
+ // method so we handle situations where backtrace entries have lists
|
|
|
|
+ // and properly escape flags.
|
|
|
|
+ std::string tmp;
|
|
|
|
+ lg->AppendCompileOptions(tmp, tmpOpt.Value);
|
|
|
|
+ BT<std::string> opt(tmp, tmpOpt.Backtrace);
|
|
|
|
+ fd.Flags.emplace_back(this->ToJBT(opt));
|
|
}
|
|
}
|
|
|
|
|
|
// Add include directories from source file properties.
|
|
// Add include directories from source file properties.
|
|
{
|
|
{
|
|
- std::vector<std::string> includes;
|
|
|
|
const std::string INCLUDE_DIRECTORIES("INCLUDE_DIRECTORIES");
|
|
const std::string INCLUDE_DIRECTORIES("INCLUDE_DIRECTORIES");
|
|
- if (const char* cincludes = sf->GetProperty(INCLUDE_DIRECTORIES)) {
|
|
|
|
- const std::string& evaluatedIncludes =
|
|
|
|
- genexInterpreter.Evaluate(cincludes, INCLUDE_DIRECTORIES);
|
|
|
|
- lg->AppendIncludeDirectories(includes, evaluatedIncludes, *sf);
|
|
|
|
-
|
|
|
|
- for (std::string const& include : includes) {
|
|
|
|
- bool const isSystemInclude = this->GT->IsSystemIncludeDirectory(
|
|
|
|
- include, this->Config, fd.Language);
|
|
|
|
- fd.Includes.emplace_back(include, isSystemInclude);
|
|
|
|
|
|
+ for (BT<std::string> tmpInclude : sf->GetIncludeDirectories()) {
|
|
|
|
+ tmpInclude.Value =
|
|
|
|
+ genexInterpreter.Evaluate(tmpInclude.Value, INCLUDE_DIRECTORIES);
|
|
|
|
+
|
|
|
|
+ // After generator evaluation we need to use the AppendIncludeDirectories
|
|
|
|
+ // method so we handle situations where backtrace entries have lists.
|
|
|
|
+ std::vector<std::string> tmp;
|
|
|
|
+ lg->AppendIncludeDirectories(tmp, tmpInclude.Value, *sf);
|
|
|
|
+ for (std::string& i : tmp) {
|
|
|
|
+ bool const isSystemInclude =
|
|
|
|
+ this->GT->IsSystemIncludeDirectory(i, this->Config, fd.Language);
|
|
|
|
+ BT<std::string> include(i, tmpInclude.Backtrace);
|
|
|
|
+ fd.Includes.emplace_back(this->ToJBT(include), isSystemInclude);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
const std::string COMPILE_DEFINITIONS("COMPILE_DEFINITIONS");
|
|
const std::string COMPILE_DEFINITIONS("COMPILE_DEFINITIONS");
|
|
- std::set<std::string> fileDefines;
|
|
|
|
- if (const char* defs = sf->GetProperty(COMPILE_DEFINITIONS)) {
|
|
|
|
- lg->AppendDefines(fileDefines,
|
|
|
|
- genexInterpreter.Evaluate(defs, COMPILE_DEFINITIONS));
|
|
|
|
|
|
+ std::set<BT<std::string>> fileDefines;
|
|
|
|
+ for (BT<std::string> tmpDef : sf->GetCompileDefinitions()) {
|
|
|
|
+ tmpDef.Value =
|
|
|
|
+ genexInterpreter.Evaluate(tmpDef.Value, COMPILE_DEFINITIONS);
|
|
|
|
+
|
|
|
|
+ // After generator evaluation we need to use the AppendDefines method
|
|
|
|
+ // so we handle situations where backtrace entries have lists.
|
|
|
|
+ std::set<std::string> tmp;
|
|
|
|
+ lg->AppendDefines(tmp, tmpDef.Value);
|
|
|
|
+ for (const std::string& i : tmp) {
|
|
|
|
+ BT<std::string> def(i, tmpDef.Backtrace);
|
|
|
|
+ fileDefines.insert(def);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ std::set<std::string> configFileDefines;
|
|
const std::string defPropName =
|
|
const std::string defPropName =
|
|
"COMPILE_DEFINITIONS_" + cmSystemTools::UpperCase(this->Config);
|
|
"COMPILE_DEFINITIONS_" + cmSystemTools::UpperCase(this->Config);
|
|
if (const char* config_defs = sf->GetProperty(defPropName)) {
|
|
if (const char* config_defs = sf->GetProperty(defPropName)) {
|
|
lg->AppendDefines(
|
|
lg->AppendDefines(
|
|
- fileDefines,
|
|
|
|
|
|
+ configFileDefines,
|
|
genexInterpreter.Evaluate(config_defs, COMPILE_DEFINITIONS));
|
|
genexInterpreter.Evaluate(config_defs, COMPILE_DEFINITIONS));
|
|
}
|
|
}
|
|
|
|
|
|
- fd.Defines.reserve(fileDefines.size());
|
|
|
|
- for (std::string const& d : fileDefines) {
|
|
|
|
|
|
+ fd.Defines.reserve(fileDefines.size() + configFileDefines.size());
|
|
|
|
+
|
|
|
|
+ for (BT<std::string> const& def : fileDefines) {
|
|
|
|
+ fd.Defines.emplace_back(this->ToJBT(def));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (std::string const& d : configFileDefines) {
|
|
fd.Defines.emplace_back(d, JBTIndex());
|
|
fd.Defines.emplace_back(d, JBTIndex());
|
|
}
|
|
}
|
|
|
|
|