Some cleanups in clientextras.mm

FossilOrigin-Name: 62d66029002055c67734e9b584beb9b7f674d96e34ef1464c4a2163ba904f245
This commit is contained in:
Jonathan Schleifer 2025-03-06 01:42:11 +00:00
parent b8b9ef2e79
commit 386b00a0d1

View file

@ -92,72 +92,83 @@ showscores(bool on)
{ {
scoreson = on; scoreson = on;
menuset(((int)on) - 1); menuset(((int)on) - 1);
}; }
struct sline { static OFMutableArray<OFString *> *scoreLines;
string s;
};
vector<sline> scorelines;
void void
renderscore(dynent *d) renderscore(dynent *d)
{ {
sprintf_sd(lag)("%d", d->plag);
sprintf_sd(name)("(%s)", d->name);
sprintf_s(scorelines.add().s)("%d\t%s\t%d\t%s\t%s", d->frags,
d->state == CS_LAGGED ? "LAG" : lag, d->ping, d->team,
d->state == CS_DEAD ? name : d->name);
@autoreleasepool { @autoreleasepool {
menumanual(0, scorelines.length() - 1, @(scorelines.last().s)); OFString *lag = [OFString stringWithFormat:@"%d", d->plag];
OFString *name = [OFString stringWithFormat:@"(%s)", d->name];
OFString *line = [OFString
stringWithFormat:@"%d\t%@\t%d\t%s\t%@", d->frags,
(d->state == CS_LAGGED ? @"LAG" : lag), d->ping, d->team,
(d->state == CS_DEAD ? name : @(d->name))];
if (scoreLines == nil)
scoreLines = [[OFMutableArray alloc] init];
[scoreLines addObject:line];
menumanual(0, scoreLines.count - 1, line);
} }
} }
const int maxteams = 4; static const int maxTeams = 4;
char *teamname[maxteams]; static OFString *teamName[maxTeams];
int teamscore[maxteams], teamsused; static int teamScore[maxTeams], teamsUsed;
string teamscores;
int timeremain = 0;
void void
addteamscore(dynent *d) addteamscore(dynent *d)
{ {
if (!d) if (d == NULL)
return; return;
loopi(teamsused) if (strcmp(teamname[i], d->team) == 0)
{ @autoreleasepool {
teamscore[i] += d->frags; OFString *team = @(d->team);
return;
}; loopi(teamsUsed)
if (teamsused == maxteams) {
return; if ([teamName[i] isEqual:team]) {
teamname[teamsused] = d->team; teamScore[i] += d->frags;
teamscore[teamsused++] = d->frags; return;
}; }
}
if (teamsUsed == maxTeams)
return;
teamName[teamsUsed] = @(d->team);
teamScore[teamsUsed++] = d->frags;
}
}
void void
renderscores() renderscores()
{ {
if (!scoreson) if (!scoreson)
return; return;
scorelines.setsize(0); [scoreLines removeAllObjects];
if (!demoplayback) if (!demoplayback)
renderscore(player1); renderscore(player1);
loopv(players) if (players[i]) renderscore(players[i]); loopv(players) if (players[i]) renderscore(players[i]);
sortmenu(); sortmenu();
if (m_teammode) { if (m_teammode) {
teamsused = 0; teamsUsed = 0;
loopv(players) addteamscore(players[i]); loopv(players) addteamscore(players[i]);
if (!demoplayback) if (!demoplayback)
addteamscore(player1); addteamscore(player1);
teamscores[0] = 0; OFMutableString *teamScores = [[OFMutableString alloc] init];
loopj(teamsused) loopj(teamsUsed)
{ {
sprintf_sd(sc)("[ %s: %d ]", teamname[j], teamscore[j]); [teamScores appendFormat:@"[ %@: %d ]", teamName[j],
strcat_s(teamscores, sc); teamScore[j]];
} }
menumanual(0, scorelines.length(), @""); menumanual(0, scoreLines.count, @"");
@autoreleasepool { @autoreleasepool {
menumanual(0, scorelines.length() + 1, @(teamscores)); menumanual(0, scoreLines.count + 1, teamScores);
} }
} }
} }
@ -172,24 +183,23 @@ sendmap(OFString *mapname)
save_world(mapname); save_world(mapname);
changemap(mapname); changemap(mapname);
mapname = getclientmap(); mapname = getclientmap();
int mapsize;
OFData *mapdata = readmap(mapname); OFData *mapdata = readmap(mapname);
if (mapdata == nil) if (mapdata == nil)
return; return;
ENetPacket *packet = enet_packet_create( ENetPacket *packet = enet_packet_create(
NULL, MAXTRANS + mapsize, ENET_PACKET_FLAG_RELIABLE); NULL, MAXTRANS + mapdata.count, ENET_PACKET_FLAG_RELIABLE);
uchar *start = packet->data; uchar *start = packet->data;
uchar *p = start + 2; uchar *p = start + 2;
putint(p, SV_SENDMAP); putint(p, SV_SENDMAP);
sendstring(mapname.UTF8String, p); sendstring(mapname.UTF8String, p);
putint(p, mapsize); putint(p, mapdata.count);
if (65535 - (p - start) < mapdata.count) { if (65535 - (p - start) < mapdata.count) {
conoutf(@"map %@ is too large to send", mapname); conoutf(@"map %@ is too large to send", mapname);
enet_packet_destroy(packet); enet_packet_destroy(packet);
return; return;
} }
memcpy(p, mapdata.items, mapdata.count); memcpy(p, mapdata.items, mapdata.count);
p += mapsize; p += mapdata.count;
*(ushort *)start = ENET_HOST_TO_NET_16(p - start); *(ushort *)start = ENET_HOST_TO_NET_16(p - start);
enet_packet_resize(packet, p - start); enet_packet_resize(packet, p - start);
sendpackettoserv(packet); sendpackettoserv(packet);