#include "args.hpp" #include "build.hpp" #include "gen.hpp" #include "help.hpp" #include "fs.hpp" #include #include #include #include #include namespace cmkr { namespace args { const char *handle_args(int argc, char **argv) { std::vector args; for (int i = 0; i < argc; ++i) args.push_back(argv[i]); if (args.size() < 2) throw std::runtime_error(cmkr::help::message()); std::string main_arg = args[1]; if (main_arg == "gen") { auto ret = cmkr::gen::generate_cmake(fs::current_path().string().c_str()); if (ret) return "CMake generation error!"; return "CMake generation successful!"; } else if (main_arg == "help") { return cmkr::help::message(); } else if (main_arg == "version") { return cmkr::help::version(); } else if (main_arg == "init") { std::string type = "executable"; if (args.size() > 2) type = args[2]; auto ret = cmkr::gen::generate_project(type.c_str()); if (ret) return "Initialization failure!"; return "Directory initialized!"; } else if (main_arg == "build") { auto ret = build::run(argc, argv); if (ret) return "CMake build error!"; return "CMake run completed!"; } else if (main_arg == "install") { auto ret = build::install(); if (ret) return "CMake install error!"; return "CMake install completed!"; } else if (main_arg == "clean") { auto ret = build::clean(); if (ret) return "CMake clean error!"; return "Cleaned build directory!"; } else { throw std::runtime_error(cmkr::help::message()); } } } // namespace args } // namespace cmkr const char *cmkr_args_handle_args(int argc, char **argv) { try { return cmkr::args::handle_args(argc, argv); } catch (const std::exception &e) { return e.what(); } catch (...) { return "Unknown error!"; } }