Implement help information loader

This commit is contained in:
Salanto 2021-09-15 00:44:00 +02:00
parent 45036a9b6c
commit fb4c3481d2
4 changed files with 78 additions and 1 deletions

View File

@ -0,0 +1,7 @@
[
{
"name": "foo",
"usage": "/foo <bar> [baz|qux]",
"text": "A sample explanation."
}
]

View File

@ -77,6 +77,13 @@ class ConfigManager {
*/
static QStringList musiclist();
/**
* @brief Loads help information into m_help_information.
*
* @return See short description.
*/
static void loadcommandHelp();
/**
* @brief Returns the duration of a song in the songlist.
* @param The name of the song where duration is requested
@ -422,6 +429,22 @@ class ConfigManager {
*/
static qint64 uptime();
/**
* @brief A struct that contains the help information for a command.
* It's split in the syntax and the explanation text.
*/
struct help {
QString usage;
QString text;
};
/**
* @brief Returns a struct with the help information of the command.
*
* @return See short description.
*/
static help commandHelp(QString f_command_name);
/**
* @brief Sets the server's authorization type.
*
@ -500,6 +523,11 @@ private:
*/
static QHash<QString,float>* m_musicList;
/**
* @brief QHash containing the help information for all commands registered to the server.
*/
static QHash<QString,help>* m_commands_help;
/**
* @brief Returns a stringlist with the contents of a .txt file from config/text/.
*

View File

@ -25,6 +25,7 @@ QSettings* ConfigManager::m_areas = new QSettings("config/areas.ini", QSettings:
ConfigManager::CommandSettings* ConfigManager::m_commands = new CommandSettings();
QElapsedTimer* ConfigManager::m_uptimeTimer = new QElapsedTimer;
QHash<QString,float>* ConfigManager::m_musicList = new QHash<QString,float>;
QHash<QString,ConfigManager::help>* ConfigManager::m_commands_help = new QHash<QString,ConfigManager::help>;
bool ConfigManager::verifyServerConfig()
{
@ -39,7 +40,8 @@ bool ConfigManager::verifyServerConfig()
// Verify config files
QStringList l_config_files{"config/config.ini", "config/areas.ini", "config/backgrounds.txt", "config/characters.txt", "config/music.json",
"config/discord.ini", "config/text/8ball.txt", "config/text/gimp.txt", "config/text/praise.txt", "config/text/reprimands.txt"};
"config/discord.ini", "config/text/8ball.txt", "config/text/gimp.txt", "config/text/praise.txt",
"config/text/reprimands.txt","config/text/commandhelp.json"};
for (const QString &l_file : l_config_files) {
if (!fileExists(QFileInfo(l_file))) {
qCritical() << l_file + " does not exist!";
@ -173,6 +175,38 @@ QStringList ConfigManager::musiclist()
return l_musiclist;
}
void ConfigManager::loadcommandHelp()
{
QFile l_music_json("config/text/commandhelp.json");
l_music_json.open(QIODevice::ReadOnly | QIODevice::Text);
QJsonParseError l_error;
QJsonDocument l_music_list_json = QJsonDocument::fromJson(l_music_json.readAll(), &l_error);
if (!(l_error.error == QJsonParseError::NoError)) { //Non-Terminating error.
qWarning() << "Unable to help information. The following error was encounted : " + l_error.errorString();
}
// Akashi expects the helpfile to contain multiple entires, so it always checks for an array first.
QJsonArray l_Json_root_array = l_music_list_json.array();
QJsonObject l_child_obj;
for (int i = 0; i <= l_Json_root_array.size() -1; i++){
l_child_obj = l_Json_root_array.at(i).toObject();
QString l_name = l_child_obj["name"].toString();
QString l_usage = l_child_obj["usage"].toString();
QString l_text = l_child_obj["text"].toString();
if (!l_name.isEmpty()) {
help l_help_information;
l_help_information.usage = l_usage;
l_help_information.text = l_text;
m_commands_help->insert(l_name,l_help_information);
qDebug() << commandHelp("foo").text;
}
}
}
int ConfigManager::songInformation(const QString &f_songName)
{
return m_musicList->value(f_songName);
@ -540,6 +574,11 @@ qint64 ConfigManager::uptime()
return m_uptimeTimer->elapsed();
}
ConfigManager::help ConfigManager::commandHelp(QString f_command_name)
{
return m_commands_help->value(f_command_name);
}
void ConfigManager::setMotd(const QString f_motd)
{
m_settings->setValue("Options/motd", f_motd);

View File

@ -97,6 +97,9 @@ void Server::start()
this, QOverload<AOPacket,int>::of(&Server::broadcast));
}
//Loads the command help information. This is not stored inside the server.
ConfigManager::loadcommandHelp();
//Rate-Limiter for IC-Chat
connect(&next_message_timer, SIGNAL(timeout()), this, SLOT(allowMessage()));
}