diff options
author | Ben Boeckel <ben.boeckel@kitware.com> | 2021-06-08 15:27:39 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2021-06-09 14:50:41 (GMT) |
commit | 82c867ad85785cdf6efed98f8fdef27419375f29 (patch) | |
tree | 5d423e0b600adbb1a19ddf517902e70c6e7e6ba4 | |
parent | 5e26887c35be116a83ba049098f5780309ced073 (diff) | |
download | CMake-82c867ad85785cdf6efed98f8fdef27419375f29.zip CMake-82c867ad85785cdf6efed98f8fdef27419375f29.tar.gz CMake-82c867ad85785cdf6efed98f8fdef27419375f29.tar.bz2 |
cmScanDepFormat: P1689R4: Flatten future-compile members into parent
-rw-r--r-- | Help/dev/experimental.rst | 1 | ||||
-rw-r--r-- | Source/cmScanDepFormat.cxx | 102 |
2 files changed, 49 insertions, 54 deletions
diff --git a/Help/dev/experimental.rst b/Help/dev/experimental.rst index 3db8177..52feec3 100644 --- a/Help/dev/experimental.rst +++ b/Help/dev/experimental.rst @@ -43,6 +43,7 @@ by the `P1689r3`_ paper, with the following updates: * Omit the ``outputs``, ``inputs``, and ``depends`` fields from each entry in the ``rules`` array. They are unused. +* Flatten ``future-compile`` members directly into each rule. Compiler writers may try out their scanning functionality using the `cxx-modules-sandbox`_ test project, modified to set variables diff --git a/Source/cmScanDepFormat.cxx b/Source/cmScanDepFormat.cxx index e66f96d..8e09a78 100644 --- a/Source/cmScanDepFormat.cxx +++ b/Source/cmScanDepFormat.cxx @@ -117,65 +117,61 @@ bool cmScanDepFormat_P1689_Parse(std::string const& arg_pp, return false; } - if (rule.isMember("future-compile")) { - Json::Value const& future_compile = rule["future-compile"]; - - if (future_compile.isMember("outputs")) { - Json::Value const& outputs = future_compile["outputs"]; - if (outputs.isArray()) { - if (outputs.empty()) { - cmSystemTools::Error( - cmStrCat("-E cmake_ninja_dyndep failed to parse ", arg_pp, - ": expected at least one 1 output")); - return false; - } - - PARSE_FILENAME(outputs[0], info->PrimaryOutput); + if (rule.isMember("outputs")) { + Json::Value const& outputs = rule["outputs"]; + if (outputs.isArray()) { + if (outputs.empty()) { + cmSystemTools::Error( + cmStrCat("-E cmake_ninja_dyndep failed to parse ", arg_pp, + ": expected at least one 1 output")); + return false; } + + PARSE_FILENAME(outputs[0], info->PrimaryOutput); } + } - if (future_compile.isMember("provides")) { - Json::Value const& provides = future_compile["provides"]; - if (provides.isArray()) { - for (auto const& provide : provides) { - cmSourceReqInfo provide_info; - - Json::Value const& logical_name = provide["logical-name"]; - PARSE_BLOB(logical_name, provide_info.LogicalName); - - if (provide.isMember("compiled-module-path")) { - Json::Value const& compiled_module_path = - provide["compiled-module-path"]; - PARSE_FILENAME(compiled_module_path, - provide_info.CompiledModulePath); - } else { - provide_info.CompiledModulePath = - cmStrCat(provide_info.LogicalName, ".mod"); - } - - info->Provides.push_back(provide_info); + if (rule.isMember("provides")) { + Json::Value const& provides = rule["provides"]; + if (provides.isArray()) { + for (auto const& provide : provides) { + cmSourceReqInfo provide_info; + + Json::Value const& logical_name = provide["logical-name"]; + PARSE_BLOB(logical_name, provide_info.LogicalName); + + if (provide.isMember("compiled-module-path")) { + Json::Value const& compiled_module_path = + provide["compiled-module-path"]; + PARSE_FILENAME(compiled_module_path, + provide_info.CompiledModulePath); + } else { + provide_info.CompiledModulePath = + cmStrCat(provide_info.LogicalName, ".mod"); } + + info->Provides.push_back(provide_info); } } + } - if (future_compile.isMember("requires")) { - Json::Value const& reqs = future_compile["requires"]; - if (reqs.isArray()) { - for (auto const& require : reqs) { - cmSourceReqInfo require_info; - - Json::Value const& logical_name = require["logical-name"]; - PARSE_BLOB(logical_name, require_info.LogicalName); + if (rule.isMember("requires")) { + Json::Value const& reqs = rule["requires"]; + if (reqs.isArray()) { + for (auto const& require : reqs) { + cmSourceReqInfo require_info; - if (require.isMember("compiled-module-path")) { - Json::Value const& compiled_module_path = - require["compiled-module-path"]; - PARSE_FILENAME(compiled_module_path, - require_info.CompiledModulePath); - } + Json::Value const& logical_name = require["logical-name"]; + PARSE_BLOB(logical_name, require_info.LogicalName); - info->Requires.push_back(require_info); + if (require.isMember("compiled-module-path")) { + Json::Value const& compiled_module_path = + require["compiled-module-path"]; + PARSE_FILENAME(compiled_module_path, + require_info.CompiledModulePath); } + + info->Requires.push_back(require_info); } } } @@ -196,12 +192,10 @@ bool cmScanDepFormat_P1689_Write(std::string const& path, Json::Value rule(Json::objectValue); - Json::Value& future_compile = rule["future-compile"] = Json::objectValue; - - Json::Value& outputs = future_compile["outputs"] = Json::arrayValue; + Json::Value& outputs = rule["outputs"] = Json::arrayValue; outputs.append(info.PrimaryOutput); - Json::Value& provides = future_compile["provides"] = Json::arrayValue; + Json::Value& provides = rule["provides"] = Json::arrayValue; for (auto const& provide : info.Provides) { Json::Value provide_obj(Json::objectValue); auto const encoded = EncodeFilename(provide.LogicalName); @@ -218,7 +212,7 @@ bool cmScanDepFormat_P1689_Write(std::string const& path, provides.append(provide_obj); } - Json::Value& reqs = future_compile["requires"] = Json::arrayValue; + Json::Value& reqs = rule["requires"] = Json::arrayValue; for (auto const& require : info.Requires) { Json::Value require_obj(Json::objectValue); auto const encoded = EncodeFilename(require.LogicalName); |