diff options
| author | untodesu <kirill@untode.su> | 2025-06-29 22:24:42 +0500 |
|---|---|---|
| committer | untodesu <kirill@untode.su> | 2025-06-29 22:24:42 +0500 |
| commit | 6cd00aacfa22fed6a54a9b812f6b069ad16feec0 (patch) | |
| tree | b77f4e665da3dd235cdb01e7e6ea78c1c02ecf2e /src/core/cmdline.cc | |
| parent | f440914e1ae453768d09383f332bc7844e0a700e (diff) | |
| download | voxelius-6cd00aacfa22fed6a54a9b812f6b069ad16feec0.tar.bz2 voxelius-6cd00aacfa22fed6a54a9b812f6b069ad16feec0.zip | |
Move game sources into src subdirectory
Diffstat (limited to 'src/core/cmdline.cc')
| -rw-r--r-- | src/core/cmdline.cc | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/src/core/cmdline.cc b/src/core/cmdline.cc new file mode 100644 index 0000000..c83f9e6 --- /dev/null +++ b/src/core/cmdline.cc @@ -0,0 +1,81 @@ +#include "core/pch.hh" + +#include "core/cmdline.hh" + +// Valid options always start with OPTION_PREFIX, can contain +// a bunch of OPTION_PREFIX'es inside and never end with one +constexpr static char OPTION_PREFIX = '-'; + +static std::unordered_map<std::string, std::string> options; + +static inline bool is_option_string(const std::string& string) +{ + if(string.find_last_of(OPTION_PREFIX) >= (string.size() - 1)) { + return false; + } + + return string[0] == OPTION_PREFIX; +} + +static inline std::string get_option(const std::string& string) +{ + std::size_t i; + for(i = 0; string[i] == OPTION_PREFIX; ++i) + ; + return std::string(string.cbegin() + i, string.cend()); +} + +void cmdline::create(int argc, char** argv) +{ + for(int idx = 1; idx < argc; ++idx) { + std::string string = argv[idx]; + + if(!is_option_string(string)) { + spdlog::warn("cmdline: non-argument at {}: {}", idx, string); + continue; + } + + auto option_string = get_option(string); + auto next_idx = idx + 1; + + if(next_idx < argc) { + std::string argument = argv[next_idx]; + + if(!is_option_string(argument)) { + options.insert_or_assign(option_string, argument); + idx = next_idx; + continue; + } + } + + // The option is either last or has no + // argument (happens when there is a valid + // option right next to the one we're parsing) + options.insert_or_assign(option_string, std::string()); + } +} + +void cmdline::insert(const char* option, const char* argument) +{ + if(argument == nullptr) { + options.insert_or_assign(option, std::string()); + } else { + options.insert_or_assign(option, argument); + } +} + +const char* cmdline::get(const char* option, const char* fallback) +{ + auto it = options.find(option); + + if(it == options.cend()) { + return fallback; + } + + return it->second.c_str(); +} + +bool cmdline::contains(const char* option) +{ + return options.count(option); +} |
