Some cleanups in clientextras.mm
FossilOrigin-Name: 62d66029002055c67734e9b584beb9b7f674d96e34ef1464c4a2163ba904f245
This commit is contained in:
parent
b8b9ef2e79
commit
386b00a0d1
1 changed files with 49 additions and 39 deletions
|
@ -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);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue