mirror of
https://github.com/EQEmu/Server.git
synced 2026-06-20 09:38:21 +00:00
convert find
This commit is contained in:
@@ -0,0 +1,143 @@
|
||||
#include "../../client.h"
|
||||
#include "../../../common/content/world_content_service.h"
|
||||
|
||||
void FindZone(Client* c, const Seperator* sep)
|
||||
{
|
||||
std::string where_filter = std::string();
|
||||
|
||||
const bool is_expansion_search = !strcasecmp(sep->arg[2], "expansion");
|
||||
const bool is_id_search = Strings::IsNumber(sep->arg[2]);
|
||||
const bool is_short_name_search = !is_expansion_search && !is_id_search;
|
||||
|
||||
std::string search_string;
|
||||
std::string search_type;
|
||||
|
||||
if (is_expansion_search) {
|
||||
int expansion_id = Strings::ToInt(sep->arg[3]);
|
||||
|
||||
if (
|
||||
!EQ::ValueWithin(expansion_id, Expansion::Classic, Expansion::MaxId - 1) &&
|
||||
expansion_id != Expansion::EXPANSION_FILTER_MAX
|
||||
) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Invalid expansion ID: {}. Please enter a value between 0 and {}, or 99.",
|
||||
expansion_id,
|
||||
Expansion::MaxId - 1
|
||||
).c_str()
|
||||
);
|
||||
return;
|
||||
}
|
||||
|
||||
where_filter = fmt::format("expansion = {}", expansion_id);
|
||||
|
||||
if (expansion_id == Expansion::EXPANSION_FILTER_MAX) {
|
||||
search_string = "Test Zones";
|
||||
} else {
|
||||
search_string = Expansion::ExpansionName[expansion_id];
|
||||
}
|
||||
|
||||
search_type = "expansion";
|
||||
} else if (is_id_search) {
|
||||
where_filter = fmt::format("zoneidnumber = {}", Strings::ToUnsignedInt(sep->arg[2]));
|
||||
|
||||
search_string = sep->arg[2];
|
||||
search_type = "ID";
|
||||
} else if (is_short_name_search) {
|
||||
where_filter = fmt::format(
|
||||
"LOWER(`long_name`) LIKE '%%{}%%' OR LOWER(`short_name`) LIKE '%%{}%%'",
|
||||
Strings::Escape(Strings::ToLower(sep->argplus[2])),
|
||||
Strings::Escape(Strings::ToLower(sep->argplus[2]))
|
||||
);
|
||||
|
||||
search_string = sep->argplus[2];
|
||||
search_type = "name";
|
||||
}
|
||||
|
||||
where_filter += " ORDER BY `zoneidnumber` ASC LIMIT 50";
|
||||
|
||||
const auto& l = ZoneRepository::GetWhere(content_db, where_filter);
|
||||
|
||||
if (l.empty()) {
|
||||
c->Message(Chat::White, "No zones were found matching your search criteria.");
|
||||
return;
|
||||
}
|
||||
|
||||
uint32 found_count = 0;
|
||||
|
||||
for (const auto& e : l) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{}{} {} ({}) (ID {}){}",
|
||||
(
|
||||
e.version == 0 ?
|
||||
fmt::format(
|
||||
"{} | ",
|
||||
Saylink::Silent(
|
||||
fmt::format(
|
||||
"#zone {}",
|
||||
e.short_name
|
||||
),
|
||||
"Zone"
|
||||
)
|
||||
) :
|
||||
""
|
||||
),
|
||||
fmt::format(
|
||||
"{} |",
|
||||
Saylink::Silent(
|
||||
fmt::format(
|
||||
"#gmzone {} {}",
|
||||
e.short_name,
|
||||
e.version
|
||||
),
|
||||
"GM Zone"
|
||||
)
|
||||
),
|
||||
e.long_name,
|
||||
e.short_name,
|
||||
e.zoneidnumber,
|
||||
(
|
||||
e.version != 0 ?
|
||||
fmt::format(
|
||||
" (Version {})",
|
||||
e.version
|
||||
) :
|
||||
""
|
||||
)
|
||||
).c_str()
|
||||
);
|
||||
|
||||
found_count++;
|
||||
|
||||
if (found_count == 50) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (found_count == 50) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"50 Zones found matching '{}' of '{}', max reached.",
|
||||
search_type,
|
||||
search_string
|
||||
).c_str()
|
||||
);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} Zone{} found matching '{}' of '{}'.",
|
||||
found_count,
|
||||
found_count != 1 ? "s" : "",
|
||||
search_type,
|
||||
search_string
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user