From 37be901c97e89f6ebb24e87933ddf57cd57371d5 Mon Sep 17 00:00:00 2001 From: Amlal Date: Tue, 22 Oct 2024 20:49:53 +0200 Subject: IMP: Refactor of the source code. Signed-off-by: Amlal --- cli/CliApp.cc | 91 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ cli/CliApp.cxx | 91 ---------------------------------------------------------- 2 files changed, 91 insertions(+), 91 deletions(-) create mode 100644 cli/CliApp.cc delete mode 100644 cli/CliApp.cxx (limited to 'cli') diff --git a/cli/CliApp.cc b/cli/CliApp.cc new file mode 100644 index 0000000..f8fd999 --- /dev/null +++ b/cli/CliApp.cc @@ -0,0 +1,91 @@ +// ============================================================= // +// btb +// Copyright ZKA Web Services. +// ============================================================= // + +#include +#include +#include +#include +#include +#include +#include + +static int cJobIndex = 0; +static bool cFailed = false; + +int main(int argc, char** argv) +{ + cJobIndex = argc - 1; + + for (size_t index = 1; index < argc; ++index) + { + std::string index_path = argv[index]; + + if (index_path == "/Ver" || + index_path == "/Version") + { + std::cout << "Usage: btb \n"; + std::cout << "Check for issues at: www.el-mahrouss-logic.com/btb/issues\n"; + + std::cout << "Brought to you by Amlal El Mahrouss.\n"; + std::cout << "© ZKA Web Services, all rights reserved.\n"; + + return 0; + } + else if (index_path == "/?" || + index_path == "/Help") + { + std::cout << "btb: Build a JSON file: btb .json\n"; + std::cout << "btb: Build a TOML file: btb .toml\n"; + + return 0; + } + + std::thread job_build_thread([](std::string index_path) -> void { + IManifestBuilder* builder = nullptr; + + const auto cJsonExt = ".json"; + + if (index_path.ends_with(cJsonExt)) + { + builder = new JSONManifestBuilder(); + } + else + { + cFailed = true; + return; + } + + std::cout << "btb: building: " << index_path << std::endl; + + if (builder && !builder->Build(index_path.size(), index_path.c_str())) + { + cFailed = true; + } + else if (!builder) + { + cFailed = true; + } + + delete builder; + + --cJobIndex; + }, + index_path); + + job_build_thread.detach(); + } + + // wait for completion of all jobs. + while (cJobIndex) + { + if (cFailed) + { + std::cout << "btb: build failed: " << errno << "." << std::endl; + return EXIT_FAILURE; + } + } + + return cFailed ? EXIT_FAILURE : EXIT_SUCCESS; +} diff --git a/cli/CliApp.cxx b/cli/CliApp.cxx deleted file mode 100644 index c2f9aad..0000000 --- a/cli/CliApp.cxx +++ /dev/null @@ -1,91 +0,0 @@ -// ============================================================= // -// btb -// Copyright ZKA Technologies. -// ============================================================= // - -#include -#include -#include -#include -#include -#include -#include - -static int cJobIndex = 0; -static bool cFailed = false; - -int main(int argc, char** argv) -{ - cJobIndex = argc - 1; - - for (size_t index = 1; index < argc; ++index) - { - std::string index_path = argv[index]; - - if (index_path == "/Ver" || - index_path == "/Version") - { - std::cout << "Usage: btb \n"; - std::cout << "Check for issues at: www.el-mahrouss-logic.com/btb/issues\n"; - - std::cout << "Brought to you by Amlal El Mahrouss.\n"; - std::cout << "© ZKA Technologies, all rights reserved.\n"; - - return 0; - } - else if (index_path == "/?" || - index_path == "/Help") - { - std::cout << "btb: Build a JSON file: btb .json\n"; - std::cout << "btb: Build a TOML file: btb .toml\n"; - - return 0; - } - - std::thread job_build_thread([](std::string index_path) -> void { - IManifestBuilder* builder = nullptr; - - const auto cJsonExt = ".json"; - - if (index_path.ends_with(cJsonExt)) - { - builder = new JSONManifestBuilder(); - } - else - { - cFailed = true; - return; - } - - std::cout << "btb: building: " << index_path << std::endl; - - if (builder && !builder->Build(index_path.size(), index_path.c_str())) - { - cFailed = true; - } - else if (!builder) - { - cFailed = true; - } - - delete builder; - - --cJobIndex; - }, - index_path); - - job_build_thread.detach(); - } - - // wait for completion of all jobs. - while (cJobIndex) - { - if (cFailed) - { - std::cout << "btb: build failed: " << errno << "." << std::endl; - return EXIT_FAILURE; - } - } - - return cFailed ? EXIT_FAILURE : EXIT_SUCCESS; -} -- cgit v1.2.3