mirror of
https://github.com/EQEmu/Server.git
synced 2026-03-04 12:32:25 +00:00
[Commands] Cleanup #ginfo Command. (#1788)
- Cleanup message and logic.
This commit is contained in:
parent
40edefa6f4
commit
39b39970f6
@ -3,49 +3,78 @@
|
|||||||
|
|
||||||
void command_ginfo(Client *c, const Seperator *sep)
|
void command_ginfo(Client *c, const Seperator *sep)
|
||||||
{
|
{
|
||||||
Client *t;
|
Client *target = c;
|
||||||
|
|
||||||
if (c->GetTarget() && c->GetTarget()->IsClient()) {
|
if (c->GetTarget() && c->GetTarget()->IsClient()) {
|
||||||
t = c->GetTarget()->CastToClient();
|
target = c->GetTarget()->CastToClient();
|
||||||
}
|
|
||||||
else {
|
|
||||||
t = c;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Group *g = t->GetGroup();
|
auto target_group = target->GetGroup();
|
||||||
if (!g) {
|
if (!target_group) {
|
||||||
c->Message(Chat::White, "This client is not in a group");
|
c->Message(
|
||||||
|
Chat::White,
|
||||||
|
fmt::format(
|
||||||
|
"{} {} not in a group.",
|
||||||
|
c == target ? "You" : target->GetCleanName(),
|
||||||
|
c == target ? "are" : "is"
|
||||||
|
).c_str()
|
||||||
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
c->Message(
|
c->Message(
|
||||||
Chat::White,
|
Chat::White,
|
||||||
"Player: %s is in Group #%lu: with %i members",
|
fmt::format(
|
||||||
t->GetName(),
|
"Group Info for {} | ID: {} Members: {}",
|
||||||
(unsigned long) g->GetID(),
|
c == target ? "Yourself" : target->GetCleanName(),
|
||||||
g->GroupCount());
|
target_group->GetID(),
|
||||||
|
target_group->GroupCount()
|
||||||
|
).c_str()
|
||||||
|
);
|
||||||
|
|
||||||
uint32 r;
|
for (int group_member = 0; group_member < MAX_GROUP_MEMBERS; group_member++) {
|
||||||
for (r = 0; r < MAX_GROUP_MEMBERS; r++) {
|
if (target_group->membername[group_member][0] == '\0') {
|
||||||
if (g->members[r] == nullptr) {
|
continue;
|
||||||
if (g->membername[r][0] == '\0') {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
c->Message(
|
|
||||||
Chat::White, "...Zoned Member: %s, Roles: %s %s %s", g->membername[r],
|
|
||||||
(g->MemberRoles[r] & RoleAssist) ? "Assist" : "",
|
|
||||||
(g->MemberRoles[r] & RoleTank) ? "Tank" : "",
|
|
||||||
(g->MemberRoles[r] & RolePuller) ? "Puller" : ""
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
c->Message(
|
int member_number = (group_member + 1);
|
||||||
Chat::White, "...In-Zone Member: %s (0x%x) Roles: %s %s %s", g->membername[r], g->members[r],
|
bool is_assist = target_group->MemberRoles[group_member] & RoleAssist;
|
||||||
(g->MemberRoles[r] & RoleAssist) ? "Assist" : "",
|
bool is_puller = target_group->MemberRoles[group_member] & RolePuller;
|
||||||
(g->MemberRoles[r] & RoleTank) ? "Tank" : "",
|
bool is_tank = target_group->MemberRoles[group_member] & RoleTank;
|
||||||
(g->MemberRoles[r] & RolePuller) ? "Puller" : ""
|
auto member_string = (
|
||||||
);
|
strcmp(target_group->membername[group_member], c->GetCleanName()) ?
|
||||||
|
(
|
||||||
|
fmt::format(
|
||||||
|
"Name: {} In Zone: {}",
|
||||||
|
target_group->membername[group_member],
|
||||||
|
target_group->members[group_member] ? "Yes" : "No"
|
||||||
|
)
|
||||||
|
) :
|
||||||
|
"You"
|
||||||
|
);
|
||||||
|
c->Message(
|
||||||
|
Chat::White,
|
||||||
|
fmt::format(
|
||||||
|
"Member {} | {}",
|
||||||
|
member_number,
|
||||||
|
member_string
|
||||||
|
).c_str()
|
||||||
|
);
|
||||||
|
|
||||||
|
if (
|
||||||
|
is_assist ||
|
||||||
|
is_puller ||
|
||||||
|
is_tank
|
||||||
|
) {
|
||||||
|
c->Message(
|
||||||
|
Chat::White,
|
||||||
|
fmt::format(
|
||||||
|
"Member {} Roles | Assist: {} Puller: {} Tank: {}",
|
||||||
|
member_number,
|
||||||
|
is_assist ? "Yes" : "No",
|
||||||
|
is_puller ? "Yes" : "No",
|
||||||
|
is_tank ? "Yes" : "No"
|
||||||
|
).c_str()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user