From 96cdf1b07655e51d547e80c9b8b4d940b902b468 Mon Sep 17 00:00:00 2001 From: Kinglykrab <89047260+Kinglykrab@users.noreply.github.com> Date: Sat, 27 Nov 2021 18:18:27 -0500 Subject: [PATCH] [Commands] Cleanup #title Command. (#1833) - Cleanup message and logic. --- zone/command.cpp | 2 +- zone/gm_commands/title.cpp | 107 +++++++++++++++++++------------------ 2 files changed, 56 insertions(+), 53 deletions(-) diff --git a/zone/command.cpp b/zone/command.cpp index 1a254eda1..17a594f06 100755 --- a/zone/command.cpp +++ b/zone/command.cpp @@ -364,7 +364,7 @@ int command_init(void) command_add("time", "[HH] [MM] - Set EQ time", AccountStatus::EQSupport, command_time) || command_add("timers", "- Display persistent timers for target", AccountStatus::GMMgmt, command_timers) || command_add("timezone", "[HH] [MM] - Set timezone. Minutes are optional", AccountStatus::EQSupport, command_timezone) || - command_add("title", "[text] [1 = create title table row] - Set your or your player target's title", AccountStatus::Guide, command_title) || + command_add("title", "[Remove|Title] [Save (0 = False, 1 = True)] - Set your or your player target's title (use remove to remove title, Save defaults to false if not used)", AccountStatus::Guide, command_title) || command_add("titlesuffix", "[text] [1 = create title table row] - Set your or your player target's title suffix", AccountStatus::Guide, command_titlesuffix) || command_add("traindisc", "[level] - Trains all the disciplines usable by the target, up to level specified. (may freeze client for a few seconds)", AccountStatus::GMLeadAdmin, command_traindisc) || command_add("trapinfo", "- Gets infomation about the traps currently spawned in the zone.", AccountStatus::QuestTroupe, command_trapinfo) || diff --git a/zone/gm_commands/title.cpp b/zone/gm_commands/title.cpp index 0be244d44..48b935b3c 100755 --- a/zone/gm_commands/title.cpp +++ b/zone/gm_commands/title.cpp @@ -3,63 +3,66 @@ void command_title(Client *c, const Seperator *sep) { - if (sep->arg[1][0] == 0) { + int arguments = sep->argnum; + if (!arguments) { c->Message( Chat::White, - "Usage: #title [remove|text] [1 = Create row in title table] - remove or set title to 'text'" + "Usage: #title [Remove|Title] [Save (0 = False, 1 = True)]" ); + return; } - else { - bool Save = (atoi(sep->arg[2]) == 1); - - Mob *target_mob = c->GetTarget(); - if (!target_mob) { - target_mob = c; - } - if (!target_mob->IsClient()) { - c->Message(Chat::Red, "#title only works on players."); - return; - } - Client *t = target_mob->CastToClient(); - - if (strlen(sep->arg[1]) > 31) { - c->Message(Chat::Red, "Title must be 31 characters or less."); - return; - } - - bool removed = false; - if (!strcasecmp(sep->arg[1], "remove")) { - t->SetAATitle(""); - removed = true; - } - else { - for (unsigned int i = 0; i < strlen(sep->arg[1]); i++) - if (sep->arg[1][i] == '_') { - sep->arg[1][i] = ' '; - } - if (!Save) { - t->SetAATitle(sep->arg[1]); - } - else { - title_manager.CreateNewPlayerTitle(t, sep->arg[1]); - } - } - - t->Save(); - - if (removed) { - c->Message(Chat::Red, "%s's title has been removed.", t->GetName(), sep->arg[1]); - if (t != c) { - t->Message(Chat::Red, "Your title has been removed.", sep->arg[1]); - } - } - else { - c->Message(Chat::Red, "%s's title has been changed to '%s'.", t->GetName(), sep->arg[1]); - if (t != c) { - t->Message(Chat::Red, "Your title has been changed to '%s'.", sep->arg[1]); - } - } + + bool is_remove = !strcasecmp(sep->arg[1], "remove"); + std::string title = is_remove ? "" : sep->arg[1]; + bool save_title = sep->IsNumber(2) ? atobool(sep->arg[2]) : false; + + auto target = c; + if (c->GetTarget() && c->GetTarget()->IsClient()) { + target = c->GetTarget()->CastToClient(); } + + if (title.size() > 31) { + c->Message(Chat::White, "Title must be 31 characters or less."); + return; + } + + if (!title.empty()) { + find_replace(title, "_", " "); + } + + if (!save_title || is_remove) { + target->SetAATitle(title.c_str()); + } else if (save_title) { + title_manager.CreateNewPlayerTitle(target, title.c_str()); + } + + target->Save(); + + c->Message( + Chat::White, + fmt::format( + "Title has been {}{} for {}{}", + is_remove ? "removed" : "changed", + !is_remove && save_title ? " and saved" : "", + ( + c == target ? + "yourself" : + fmt::format( + "{} ({})", + target->GetCleanName(), + target->GetID() + ) + ), + ( + is_remove ? + "." : + fmt::format( + " to '{}'.", + title + ) + ) + ).c_str() + ); }