diff --git a/bin/config_sample/text/commandhelp.json b/bin/config_sample/text/commandhelp.json index f6cbde8..f9642d3 100644 --- a/bin/config_sample/text/commandhelp.json +++ b/bin/config_sample/text/commandhelp.json @@ -3,5 +3,640 @@ "name": "foo", "usage": "/foo [baz|qux]", "text": "A sample explanation." - } + }, + { + "name": "foo", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "foo", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "login", + "usage": "/login", + "text": "Activates the login dialogue to enter your credentials. This command takes no arguments." + }, + { + "name": "getareas", + "usage": "/getareas", + "text": "Lists all clients in all areas. This command takes no arguments." + }, + { + "name": "getarea", + "usage": "/getarea", + "text": "Lists all clients in the area the caller is in. This command takes no arguments." + }, + { + "name": "ban", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "kick", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "changeauth", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "rootpass", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "background", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "bg", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "bglock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "bgunlock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "adduser", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "listperms", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "addperm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "removeperm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "listusers", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "logout", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "pos", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "g", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "need", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "coinflip", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "roll", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "rollp", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "doc", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "cleardoc", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "cm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "uncm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "invite", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "uninvite", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "lock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "area_lock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "spectatable", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "area_spectate", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unlock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "area_unlock", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "timer", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "play", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "areakick", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "area_kick", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "randomchar", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "switch", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "toggleglobal", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "mods", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "commands", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "status", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "forcepos", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "currentmusic", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "pm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "evidence_mod", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "motd", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "announce", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "m", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "gm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "mute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unmute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "bans", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unban", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "removeuser", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "subtheme", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "about", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "evidence_swap", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notecard", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notecardreveal", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notecard_reveal", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notecardclear", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notecard_clear", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "8ball", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "lm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "judgelog", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "allowblankposting", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "allow_blankposting", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "gimp", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "ungimp", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "baninfo", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "testify", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "testimony", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "examine", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "pause", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "delete", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "update", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "add", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "reload", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "disemvovel", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "undisemvovel", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "shake", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unshake", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "forceimmediate", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "force_noint_pres", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "allowiniswap", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "allow_iniswap", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "afk", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "savetestimony", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "loadtestimony", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "permitsaving", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "mutepm", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "oocmute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "ooc_mute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "oocunmute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "ooc_unmute", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "blockwtce", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "block_wtce", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unblockwtce", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unlock_wtce", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "blockdj", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "block_dj", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unblockdj", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "unblock_dj", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "charcurse", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "uncharcurse", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "charselect", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "togglemusic", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "a", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "s", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "kickuid", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "kick_uid", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "firstperson", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "updateban", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "update_ban", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "changepass", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "ignorebglist", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "ignore_bglist", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "notice", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "noticeg", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "togglejukebox", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, + { + "name": "help", + "usage": "/foo [baz|qux]", + "text": "A sample explanation." + }, ] \ No newline at end of file diff --git a/core/include/aoclient.h b/core/include/aoclient.h index d35a914..9169000 100644 --- a/core/include/aoclient.h +++ b/core/include/aoclient.h @@ -1001,6 +1001,13 @@ class AOClient : public QObject { * * @iscommand */ + void cmdCommands(int argc, QStringList argv); + + /** + * @brief Lists help information to the command requested. Includes syntax and brief explanation. + * + * @details Takes the command name as an argument. + */ void cmdHelp(int argc, QStringList argv); /** @@ -2048,7 +2055,7 @@ class AOClient : public QObject { {"switch", {ACLFlags.value("NONE"), 1, &AOClient::cmdSwitch}}, {"toggleglobal", {ACLFlags.value("NONE"), 0, &AOClient::cmdToggleGlobal}}, {"mods", {ACLFlags.value("NONE"), 0, &AOClient::cmdMods}}, - {"help", {ACLFlags.value("NONE"), 0, &AOClient::cmdHelp}}, + {"commands", {ACLFlags.value("NONE"), 0, &AOClient::cmdCommands}}, {"status", {ACLFlags.value("NONE"), 1, &AOClient::cmdStatus}}, {"forcepos", {ACLFlags.value("CM"), 2, &AOClient::cmdForcePos}}, {"currentmusic", {ACLFlags.value("NONE"), 0, &AOClient::cmdCurrentMusic}}, @@ -2130,6 +2137,7 @@ class AOClient : public QObject { {"notice", {ACLFlags.value("SEND_NOTICE"), 1, &AOClient::cmdNotice}}, {"noticeg", {ACLFlags.value("SEND_NOTICE"), 1, &AOClient::cmdNoticeGlobal}}, {"togglejukebox", {ACLFlags.value("None"), 0, &AOClient::cmdToggleJukebox}}, + {"help", {ACLFlags.value("NONE"), 1, &AOClient::cmdHelp}} }; /** diff --git a/core/src/commands/moderation.cpp b/core/src/commands/moderation.cpp index 35019ba..523dee2 100644 --- a/core/src/commands/moderation.cpp +++ b/core/src/commands/moderation.cpp @@ -149,7 +149,7 @@ void AOClient::cmdMods(int argc, QStringList argv) sendServerMessage(l_entries.join("\n")); } -void AOClient::cmdHelp(int argc, QStringList argv) +void AOClient::cmdCommands(int argc, QStringList argv) { Q_UNUSED(argc); Q_UNUSED(argv); @@ -166,6 +166,17 @@ void AOClient::cmdHelp(int argc, QStringList argv) sendServerMessage(l_entries.join("\n")); } +void AOClient::cmdHelp(int argc, QStringList argv) +{ + if(argc > 1) { + sendServerMessage("Too many arguments. Please only use the command name."); + } + + QString l_command_name = argv[0]; + ConfigManager::help l_command_info = ConfigManager::commandHelp(l_command_name); + sendServerMessage("==Help==\n" +l_command_info.usage + "\n" + l_command_info.text); +} + void AOClient::cmdMOTD(int argc, QStringList argv) { if (argc == 0) {