diff options
| author | Amlal El Mahrouss <amlal@nekernel.org> | 2025-11-24 02:33:21 +0100 |
|---|---|---|
| committer | Amlal El Mahrouss <amlal@nekernel.org> | 2025-11-24 02:34:02 +0100 |
| commit | 64b8a6bf04095d80b1ca52415ea954b933f47098 (patch) | |
| tree | 0fdeb080c08113558b6550cf06b81ba67d9c9348 /dev/src | |
| parent | fab2f2a4b616b9bd763b154605685733c74d7321 (diff) | |
feat! breaking changes, merging to stable.
Signed-off-by: Amlal El Mahrouss <amlal@nekernel.org>
Diffstat (limited to 'dev/src')
| -rw-r--r-- | dev/src/IManifestBuilder.cc | 6 | ||||
| -rw-r--r-- | dev/src/JSONManifestBuilder.cc | 111 | ||||
| -rw-r--r-- | dev/src/TOMLManifestBuilder.cc | 115 |
3 files changed, 0 insertions, 232 deletions
diff --git a/dev/src/IManifestBuilder.cc b/dev/src/IManifestBuilder.cc deleted file mode 100644 index 745e81d..0000000 --- a/dev/src/IManifestBuilder.cc +++ /dev/null @@ -1,6 +0,0 @@ -// ============================================================= // -// nebuild -// Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under BSD-3 license. -// ============================================================= // - -#include <BuildKit/IManifestBuilder.h> diff --git a/dev/src/JSONManifestBuilder.cc b/dev/src/JSONManifestBuilder.cc deleted file mode 100644 index d54653b..0000000 --- a/dev/src/JSONManifestBuilder.cc +++ /dev/null @@ -1,111 +0,0 @@ -// ============================================================= // -// nebuild -// Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under BSD-3 license. -// ============================================================= // - -#include <BuildKit/JSONManifestBuilder.h> - -using namespace NeBuild; -using namespace nlohmann; - -using JSON = json; -namespace FS = std::filesystem; - -/// =========================================================== /// -/// @brief Builds a JSON target from a JSON file. -/// @param arg_sz filename size (must be 1 or greater). -/// @param arg_val filename path (must be a valid JSON file). -/// @retval true building has succeeded. -/// @retval false fail to build, see error message. -/// =========================================================== /// -bool JSONManifestBuilder::BuildTarget(const std::string& argv_val, const bool dry_run) { - std::string path; - - if (argv_val.empty()) { - NeBuild::Logger::info() << "nebuild: error: file path is empty" << std::endl; - return false; - } else { - path = argv_val; - - if (!FS::exists(path)) { - NeBuild::Logger::info() << "nebuild: error: file '" << path << "' does not exist" - << std::endl; - return false; - } - } - - try { - std::ifstream json(path); - - if (!json.good()) { - NeBuild::Logger::info() << "nebuild: error: file '" << path << "' is not a valid JSON" - << std::endl; - return false; - } - - JSON json_obj = JSON::parse(json); - - std::string compiler = json_obj["compiler_path"].get<std::string>(); - - std::string command = compiler + " "; - - JSON header_search_path = json_obj["compiler_headers_path"]; - - for (auto& headers : header_search_path) { - command += "-I" + headers.get<std::string>() + " "; - } - - JSON headers_path = json_obj["headers_path"]; - - for (auto& headers : headers_path) { - command += "-I" + headers.get<std::string>() + " "; - } - - JSON sources_files = json_obj["sources_path"]; - - for (auto& sources : sources_files) { - command += sources.get<std::string>() + " "; - } - - JSON macros_list = json_obj["cpp_macros"]; - - for (auto& macro : macros_list) { - command += "-D" + macro.get<std::string>() + " "; - } - - JSON compiler_flags = json_obj["compiler_flags"]; - - for (auto& flag : compiler_flags) { - command += flag.get<std::string>() + " "; - } - - if (json_obj["compiler_std"].is_string()) - command += "-std=" + json_obj["compiler_std"].get<std::string>() + " "; - - command += "-o " + json_obj["output_name"].get<std::string>(); - - auto target = json_obj["output_name"].get<std::string>(); - - NeBuild::Logger::info() << "output path: " << target << "\n"; - - auto ret_exec = std::system(command.c_str()); - - if (ret_exec > 0) { - NeBuild::Logger::info() << "error: exit with message: " << std::strerror(ret_exec) << "" - << std::endl; - return false; - } - } catch (std::runtime_error& err) { - NeBuild::Logger::info() << "error: exit with message: " << err.what() << "" << std::endl; - return false; - } - - return true; -} - -/// =========================================================== /// -/// @brief Returns the build system name. -/// =========================================================== /// -const char* JSONManifestBuilder::BuildSystem() { - return "NeBuild (JSON)"; -} diff --git a/dev/src/TOMLManifestBuilder.cc b/dev/src/TOMLManifestBuilder.cc deleted file mode 100644 index 49de8eb..0000000 --- a/dev/src/TOMLManifestBuilder.cc +++ /dev/null @@ -1,115 +0,0 @@ -// ============================================================= // -// nebuild -// Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under BSD-3 license. -// ============================================================= // - -#include <BuildKit/TOMLManifestBuilder.h> -#include <filesystem> - -using namespace NeBuild; - -namespace FS = std::filesystem; - -/// =========================================================== /// -/// @brief Builds a TOML target from a TOML file. -/// @param arg_sz filename size (must be 1 or greater). -/// @param arg_val filename path (must be a valid TOML file). -/// @retval true building has succeeded. -/// @retval false fail to build, see error message. -/// =========================================================== /// -bool TOMLManifestBuilder::BuildTarget(const std::string& argv_val, const bool dry_run) { - std::string path; - - if (argv_val.empty()) { - NeBuild::Logger::info() << "nebuild: error: file path is empty" << std::endl; - return false; - } else { - path = argv_val; - - if (!FS::exists(path)) { - NeBuild::Logger::info() << "nebuild: error: file '" << path << "' does not exist" - << std::endl; - return false; - } - } - - try { - auto toml_file = toml::parse_file(path); - - std::string compiler = toml_file["compiler_path"].as_string()->get(); - - std::string command = compiler + " "; - - auto header_search_path = toml_file["compiler_headers_path"].as_array(); - - if (header_search_path) { - for (auto& headers : *header_search_path) { - command += "-I" + headers.as_string()->get() + " "; - } - } - - auto headers_path = toml_file["headers_path"].as_array(); - - if (headers_path) { - for (auto& headers : *headers_path) { - command += "-I" + headers.as_string()->get() + " "; - } - } - - auto sources_files = toml_file["sources_path"].as_array(); - - if (sources_files) { - for (auto& sources : *sources_files) { - command += sources.as_string()->get() + " "; - } - } - - auto macros_list = toml_file["cpp_macros"].as_array(); - - if (macros_list) { - for (auto& macro : *macros_list) { - command += "-D" + macro.as_string()->get() + " "; - } - } - - auto compiler_flags = toml_file["compiler_flags"].as_array(); - - if (compiler_flags) { - for (auto& flag : *compiler_flags) { - command += flag.as_string()->get() + " "; - } - } - - if (!toml_file["compiler_std"].is_string()) return false; - - command += "-std=" + toml_file["compiler_std"].as_string()->get() + " "; - - if (toml_file["output_name"].as_string() == nullptr) return false; - - command += "-o " + toml_file["output_name"].as_string()->get(); - - auto target = toml_file["output_name"].as_string()->get(); - - NeBuild::Logger::info() << "output: " << target << "\n"; - - auto ret_exec = std::system(command.c_str()); - - if (ret_exec > 0) { - NeBuild::Logger::info() << "error: exit with message: " << std::strerror(ret_exec) << "" - << std::endl; - return false; - } - } catch (std::runtime_error& err) { - NeBuild::Logger::info() << "error: exit with message: " << err.what() << "" << std::endl; - return false; - } - - return true; -} - -/// =========================================================== /// -/// @brief Returns the build system name. -/// =========================================================== /// -const char* TOMLManifestBuilder::BuildSystem() { - return "NeBuild (TOML)"; -} |
