[GM Command] Fix Crash Issue and Validation with #zclip (#2014)

* Fix crash issue and validation with zclip

* Formatting.

Co-authored-by: Kinglykrab <89047260+Kinglykrab@users.noreply.github.com>
This commit is contained in:
Chris Miles 2022-02-21 17:02:48 -05:00 committed by GitHub
parent d86544ff60
commit 3c35e9bbc8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -3,38 +3,41 @@
void command_zclip(Client *c, const Seperator *sep)
{
int arguments = sep->argnum;
if (
!arguments ||
!sep->IsNumber(1) ||
!sep->IsNumber(2)
) {
c->Message(Chat::White, "Usage: #zclip [Minimum Clip] [Maximum Clip] [Fog Minimum Clip] [Fog Maximum Clip] [Permanent (0 = False, 1 = True)]");
if (arguments <= 3) {
c->Message(
Chat::White,
"Usage: #zclip [Minimum Clip] [Maximum Clip] [Fog Minimum Clip] [Fog Maximum Clip] [Permanent (0 = False, 1 = True)]"
);
return;
}
auto minimum_clip = std::stof(sep->arg[1]);
auto maximum_clip = std::stof(sep->arg[2]);
auto minimum_clip = sep->arg[1] ? std::stof(sep->arg[1]) : 0;
auto maximum_clip = sep->arg[2] ? std::stof(sep->arg[2]) : 0;
auto minimum_fog_clip = sep->arg[3] ? std::stof(sep->arg[3]) : 0;
auto maximum_fog_clip = sep->arg[4] ? std::stof(sep->arg[4]) : 0;
auto permanent = sep->arg[5] ? atobool(sep->arg[5]) : false;
if (minimum_clip <= 0 || maximum_clip <= 0) {
c->Message(Chat::White, "Minimum Clip and Maximum Clip must be greater than 0.");
return;
} else if (minimum_clip > maximum_clip) {
}
else if (minimum_clip > maximum_clip) {
c->Message(Chat::White, "Minimum Clip must be less than or equal to Maximum Clip!");
return;
} else {
}
else {
zone->newzone_data.minclip = minimum_clip;
zone->newzone_data.maxclip = maximum_clip;
if (minimum_fog_clip) {
for (int fog_index = 0; fog_index < 4; fog_index++) {
zone->newzone_data.fog_minclip[fog_index] = minimum_fog_clip;
for (float &fog_index: zone->newzone_data.fog_minclip) {
fog_index = minimum_fog_clip;
}
}
if (maximum_fog_clip) {
for (int fog_index = 0; fog_index < 4; fog_index++) {
zone->newzone_data.fog_maxclip[fog_index] = maximum_fog_clip;
for (float &fog_index: zone->newzone_data.fog_maxclip) {
fog_index = maximum_fog_clip;
}
}