summaryrefslogtreecommitdiffhomepage
path: root/cli/CommandLine.cc
diff options
context:
space:
mode:
Diffstat (limited to 'cli/CommandLine.cc')
-rw-r--r--cli/CommandLine.cc79
1 files changed, 79 insertions, 0 deletions
diff --git a/cli/CommandLine.cc b/cli/CommandLine.cc
new file mode 100644
index 0000000..231ee0b
--- /dev/null
+++ b/cli/CommandLine.cc
@@ -0,0 +1,79 @@
+
+// ============================================================= //
+// btb
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#include <JSONManifestBuilder.h>
+#include <Includes.h>
+
+static bool kFailed = false;
+static bool kDryRun = false;
+
+int main(int argc, char** argv)
+{
+ if (argc <= 1)
+ return 1;
+
+ for (size_t index = 1; index < argc; ++index)
+ {
+ std::string index_path = argv[index];
+
+ if (index_path == "-v" ||
+ index_path == "--version")
+ {
+ std::cout << "Usage: btb <file>\n";
+ std::cout << "Check for issues at: theater-quality.com/developer/issues\n";
+
+ std::cout << "Brought to you by Amlal El Mahrouss.\n";
+ std::cout << "© 2024-2025 Amlal El Mahrouss, all rights reserved.\n";
+
+ return EXIT_SUCCESS;
+ }
+ else if (index_path == "--dry-run")
+ {
+ kDryRun = true;
+ continue;
+ }
+ else if (index_path == "-h" ||
+ index_path == "--help")
+ {
+ std::cout << "btb: Build a JSON file: btb <json_path>.json\n";
+ return EXIT_SUCCESS;
+ }
+
+ std::thread job_build_thread([](std::string index_path) -> void {
+ IManifestBuilder* builder = nullptr;
+
+ const auto kJsonExtension = ".json";
+
+ if (index_path.ends_with(kJsonExtension))
+ {
+ builder = new JSONManifestBuilder();
+ }
+ else
+ {
+ kFailed = true;
+ return;
+ }
+
+ std::cout << "btb: building: " << index_path << std::endl;
+
+ if (builder && !builder->buildTarget(index_path.size(), index_path.c_str(), kDryRun))
+ {
+ kFailed = true;
+ }
+ else if (!builder)
+ {
+ kFailed = true;
+ }
+
+ delete builder;
+ builder = nullptr;
+ }, index_path);
+
+ job_build_thread.join();
+ }
+
+ return kFailed ? EXIT_FAILURE : EXIT_SUCCESS;
+}