Archived
1
Fork 0

Add string handling to console arguments

This commit is contained in:
redstrate 2021-10-12 10:22:38 -04:00
parent 2524213f01
commit 5ba4285776
3 changed files with 11 additions and 2 deletions

View file

@ -14,6 +14,8 @@ namespace prism::console {
}; };
struct console_argument { struct console_argument {
explicit console_argument(std::string_view string) : data(string.data()) {}
explicit console_argument(bool data) : data(data) {} explicit console_argument(bool data) : data(data) {}
explicit console_argument(int data) : data(data) {} explicit console_argument(int data) : data(data) {}

View file

@ -88,6 +88,8 @@ void prism::console::parse_and_invoke_command(const std::string_view command) {
return console_argument(false); return console_argument(false);
} else if(is_numeric(arg)) { } else if(is_numeric(arg)) {
return console_argument(std::stoi(arg.data())); return console_argument(std::stoi(arg.data()));
} else {
return console_argument(arg);
} }
return std::nullopt; return std::nullopt;

View file

@ -27,9 +27,14 @@ using prism::engine;
engine::engine(const int argc, char* argv[]) { engine::engine(const int argc, char* argv[]) {
log("Prism Engine loading..."); log("Prism Engine loading...");
console::register_command("echo", console::argument_format(1), [](const console::arguments& args) {
log(std::get<std::string>(args[0].data));
});
console::register_command("test_cmd", console::argument_format(0), [](const console::arguments&) { console::register_command("platform_info", console::argument_format(0), [this](const console::arguments&) {
log("Test cmd!"); log("Platform: {}", platform::get_name());
log("GFX: {}", gfx->get_name());
}); });
console::register_variable("rs_dynamic_resolution", render_options.dynamic_resolution); console::register_variable("rs_dynamic_resolution", render_options.dynamic_resolution);