2020-01-25 17:42:36 -05:00
|
|
|
#include <src/query/command3.h>
|
2019-06-26 16:11:22 -04:00
|
|
|
#include <codecvt>
|
|
|
|
#include <locale>
|
|
|
|
#include <string>
|
|
|
|
#include <cassert>
|
|
|
|
#include <src/misc/base64.h>
|
|
|
|
#include <sstream>
|
|
|
|
#include <src/License.h>
|
|
|
|
#include <functional>
|
|
|
|
#include "PermissionManager.h"
|
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
#include "src/query/command_handler.h"
|
2019-06-26 16:11:22 -04:00
|
|
|
#include "src/query/command_constants.h"
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace ts;
|
|
|
|
using namespace license::teamspeak;
|
|
|
|
|
|
|
|
template <class key_t, typename value_type_t>
|
2020-01-25 17:42:36 -05:00
|
|
|
using field = ts::command_handler::field<key_t, value_type_t>;
|
2019-06-26 16:11:22 -04:00
|
|
|
|
|
|
|
template <class key_t>
|
2020-01-25 17:42:36 -05:00
|
|
|
using trigger = ts::command_handler::trigger<key_t>;
|
2020-01-24 14:17:29 -05:00
|
|
|
|
2019-06-26 16:11:22 -04:00
|
|
|
void handleCommand(
|
2020-01-25 17:42:36 -05:00
|
|
|
ts::command_parser& parser,
|
2020-01-23 20:49:59 -05:00
|
|
|
const cconstants::return_code::optional& return_code,
|
|
|
|
const field<tl("key_a"), int>& key_a,
|
|
|
|
const field<tl("key_b"), string>::optional& key_b,
|
|
|
|
const field<tl("key_c"), uint64_t>::optional::bulked& key_c,
|
|
|
|
const trigger<tl("test")>& switch_test
|
2019-06-26 16:11:22 -04:00
|
|
|
) {
|
2020-01-24 16:27:54 -05:00
|
|
|
if(key_a.value() < 10) {
|
|
|
|
__asm__("nop");
|
|
|
|
}
|
|
|
|
__asm__("nop");
|
2020-01-23 20:49:59 -05:00
|
|
|
auto c = key_b.has_value();
|
2019-06-26 16:11:22 -04:00
|
|
|
|
2020-01-24 16:27:54 -05:00
|
|
|
__asm__("nop");
|
2020-01-25 17:42:36 -05:00
|
|
|
(void) key_c.value(1);
|
2020-01-24 16:27:54 -05:00
|
|
|
__asm__("nop");
|
2020-01-25 17:42:36 -05:00
|
|
|
(void) return_code.value_or("XXX");
|
|
|
|
cout << key_b.has_value() << endl;
|
|
|
|
cout << "Return code: " << return_code.value_or("XXX") << endl;
|
2020-01-23 20:49:59 -05:00
|
|
|
__asm__("nop");
|
2019-06-26 16:11:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
command_result test() {
|
2020-01-23 20:49:59 -05:00
|
|
|
return command_result{error::vs_critical};
|
2019-06-26 16:11:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
command_result test2() {
|
2020-01-23 20:49:59 -05:00
|
|
|
return command_result{permission::b_virtualserver_select_godmode};
|
2019-06-26 16:11:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
command_result test3() {
|
2020-01-23 20:49:59 -05:00
|
|
|
return command_result{error::vs_critical, "unknown error"};
|
2019-06-26 16:11:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void eval_test(command_result x) {
|
2020-01-23 20:49:59 -05:00
|
|
|
if(x.is_detailed()) {
|
|
|
|
cout << "Detailed!" << endl;
|
2020-01-24 14:17:29 -05:00
|
|
|
x.release_details();
|
2020-01-23 20:49:59 -05:00
|
|
|
} else {
|
|
|
|
auto a = x.permission_id();
|
|
|
|
auto b = x.error_code();
|
|
|
|
cout << (void*) a << " - " << (void*) b << endl;
|
|
|
|
}
|
2019-06-26 16:11:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int main() {
|
2020-01-25 17:42:36 -05:00
|
|
|
ts::command_handler::impl::field<tl("A"), int>::as_bulked<false> a;
|
|
|
|
std::cout << "Optional: " << a.is_optional() << "\n";
|
|
|
|
//test<"abs">();
|
2020-01-23 20:49:59 -05:00
|
|
|
//for(const auto& error : avariableErrors)
|
|
|
|
// cout << error.name << " = " << hex << "0x" << error.errorId << "," << endl;
|
2019-06-26 16:11:22 -04:00
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
//eval_test(test());
|
|
|
|
//eval_test(test2());
|
|
|
|
//eval_test(test3());
|
2020-01-23 20:49:59 -05:00
|
|
|
/*
|
|
|
|
ios_base::sync_with_stdio(false); // Avoids synchronization with C stdio on gcc
|
|
|
|
// (either localize both or disable sync)
|
2019-06-26 16:11:22 -04:00
|
|
|
|
2020-01-23 20:49:59 -05:00
|
|
|
wcout.imbue(locale("de_DE.ISO-8859-1")); // change default locale
|
2019-06-26 16:11:22 -04:00
|
|
|
|
2020-01-23 20:49:59 -05:00
|
|
|
//░█▀▀▀█░░░░▄█░░░░░░░░░▄█░░░░░▄█░░
|
|
|
|
const auto message = "\221\210\200\200\200\210\221\221\221\221\204\210\221\221\221\221\221\221\221\221\221\204\210\221\221\221\221\221\204\210\221\221";
|
|
|
|
const auto auto_message = "░█▀▀▀█░░░░▄█░░░░░░░░░▄█░░░░░▄█░░";
|
|
|
|
cout << " -> " << message << endl;
|
|
|
|
cout << " -> " << utf8_check_is_valid(message) << endl;
|
|
|
|
cout << " -> " << utf8_check_is_valid("░█▀▀▀█░░░░▄█░░░░░░░░░▄█░░░░░▄█░░") << endl;
|
2019-06-26 16:11:22 -04:00
|
|
|
|
|
|
|
Command cmd = Command::parse("test -mapping test=░█▀▀▀█░░░░▄█░░░░░░░░░▄█░░░░░▄█░░_ -x");
|
|
|
|
cout << "Build: " << cmd.build() << endl;
|
|
|
|
cout << "X: " << cmd["test"] << endl;
|
2020-01-23 20:49:59 -05:00
|
|
|
cout << " -> " << endl;
|
|
|
|
for(const auto& e : cmd.parms())
|
|
|
|
cout << e << endl;
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
auto handle = make_shared<ts::impl::command_value>();
|
|
|
|
|
|
|
|
ts::command_entry entry(handle);
|
|
|
|
entry = 255;
|
|
|
|
cout << "Value: " << entry.as<int>() << endl;
|
|
|
|
cout << "Value: " << entry.melt().as<uint32_t>() << endl;
|
|
|
|
|
|
|
|
cout << "Str: " << entry.string() << endl;
|
|
|
|
cout << "U8: " << (int) entry.melt().as<uint8_t>() << endl;
|
|
|
|
*/
|
|
|
|
|
|
|
|
//register_function(handleCommand);
|
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
/*
|
2020-01-23 20:49:59 -05:00
|
|
|
cout << sizeof(command_result) << endl;
|
|
|
|
ts::command cmd("notify");
|
2020-01-25 17:42:36 -05:00
|
|
|
*/
|
2020-01-23 20:49:59 -05:00
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
/*
|
2020-01-23 20:49:59 -05:00
|
|
|
cout << ts::command::parse("test a=b ").build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("test a=").build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("test a").build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("a=c", false).build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("a=c | a=c -x", false).build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("a a=c|a=c").build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
|
|
|
cout << ts::command::parse("a a=c a=c2 -z | -? a=c").build(ts::command::format::BRACE_ESCAPED_QUERY) << endl;
|
2020-01-25 17:42:36 -05:00
|
|
|
*/
|
2020-01-23 20:49:59 -05:00
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
std::cout << "Command v3:\n";
|
|
|
|
{
|
|
|
|
auto command = ts::command_parser{"a a=c a=c2 -z | -? a=2 key_c=c"};
|
|
|
|
if(!command.parse(true)) return 1;
|
|
|
|
|
|
|
|
std::cout << command.bulk_count() << "\n";
|
|
|
|
std::cout << command.bulk(1).value("a") << "\n";
|
|
|
|
std::cout << command.has_switch("?") << "\n";
|
|
|
|
};
|
2020-01-23 20:49:59 -05:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
cmd[0]["key_a"] = 2;
|
|
|
|
cmd["b"] = 3;
|
|
|
|
cmd["c"] = "Hello World";
|
|
|
|
cmd["c"] = "Hello World" + string();
|
|
|
|
cmd["c"] = 2;
|
|
|
|
cmd.set_trigger("test");
|
|
|
|
cmd.set_trigger("test2");
|
|
|
|
cout << "Key_A => " << cmd[0]["key_a"].string() << endl;
|
|
|
|
*/
|
|
|
|
|
2020-01-25 17:42:36 -05:00
|
|
|
auto result = ts::command_handler::describe_function(handleCommand);
|
|
|
|
auto cmd_handler = ts::command_handler::parse_function(handleCommand);
|
|
|
|
|
|
|
|
auto cmd = ts::command_parser{"a key_a=77 a=c a=c2 -z | -? key_c=3333 c=22 a=c return_code=234"};
|
|
|
|
if(!cmd.parse(true)) return 1;
|
2020-01-23 20:49:59 -05:00
|
|
|
|
|
|
|
cmd_handler->invoke(cmd);
|
|
|
|
|
|
|
|
//auto v = ts::descriptor::entry::bulked::val;
|
2019-06-26 16:11:22 -04:00
|
|
|
return 0;
|
|
|
|
}
|