You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
bomberclone/src/debug.c

146 lines
4.3 KiB

#include "bomberclone.h"
#include "network.h"
#include "packets.h"
int debug;
void d_gamedetail (char *head) {
d_playerdetail (head);
d_printf ("p_nr = %d ", bman.p_nr);
d_printf ("p_servnr = %d \n", bman.p_servnr);
d_printf ("players_nr = %d ", bman.players_nr);
d_printf ("players_nr_s = %d \n", bman.players_nr_s);
d_printf ("gametype = %d ", bman.gametype);
d_printf ("state = %d\n", bman.state);
};
void d_printsdlrect (char *text, SDL_Rect *rect) {
d_printf ("%s [x=%4d, y=%4d, w=%4d, h=%4d]\n", text, rect->x, rect->y, rect->w, rect->h);
};
void d_printf (char *fmt,...) {
va_list args;
if (debug == 0)
return;
va_start (args, fmt);
fprintf (stdout, "[%8d] :", timestamp);
vfprintf (stdout, fmt, args);
va_end (args);
};
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wformat-overflow"
#pragma GCC diagnostic ignored "-Wformat-truncation"
#pragma GCC diagnostic ignored "-Wstringop-overflow"
#define TEXTLEN 255
void d_playerstat (char *head) {
int i, j;
char text1[TEXTLEN];
char text2[TEXTLEN];
d_printf ("---------------> %s nb play: %d\n", head, bman.playnum);
sprintf (text1, "id Name killed Unknown");
for (i = 0; i < MAX_PLAYERS; i++)
if (players[i].gamestats.isaplayer == 1)
snprintf(text2, TEXTLEN, "%s %02d", text1, i);
strncat(text2, "\n", TEXTLEN);
d_printf (text2);
for (i = 0; i < MAX_PLAYERS; i++){
if (players[i].gamestats.isaplayer == 1 ) {
sprintf(text1, "%02d %-16s %2d %d ", i, players[i].name, players[i].gamestats.killed, players[i].gamestats.unknown);
for (j = 0; j < MAX_PLAYERS; j++)
if (players[j].gamestats.isaplayer == 1 )
sprintf(text2, "%s %2d", text1, players[i].gamestats.killedBy[j]);
strncat(text2, "\n", TEXTLEN);
d_printf (text2);
}
}
};
#pragma GCC diagnostic pop
void d_playerdetail (char *head) {
int i;
d_printf ("---------------> %s\n", head);
d_printf ("Nr Name GFX Sta Pkt Win kil Team net_flag [Addr]\n");
for (i = 0; i < MAX_PLAYERS; i++)
// if (players[i].gfx_nr != -1 )
d_printf ("%2d %16s %3d %3d %3d %3d %3d %4d %3d %p[%s:%s]\n",i, players[i].name, players[i].gfx_nr, players[i].state, players[i].points, players[i].wins, players[i].nbrKilled, players[i].team_nr, players[i].net.flags, players[i].net.addr.host, &players[i].net.addr, players[i].net.addr.port);
};
void d_teamdetail (char *head) {
int p;
char name[MAX_TEAMS][LEN_PLAYERNAME];
d_printf ("---------------> %s\n", head);
d_printf ("Teams: | %-10s | %-10s | %-10s | %-10s | Players\n", teams[0].name,teams[1].name,teams[2].name,teams[3].name);
for (p = 0; p < MAX_PLAYERS; p++) {
if (teams[0].players[p] == NULL) name[0][0] = 0;
else strncpy (name[0], teams[0].players[p]->name, LEN_PLAYERNAME);
if (teams[1].players[p] == NULL) name[1][0] = 0;
else strncpy (name[1], teams[1].players[p]->name, LEN_PLAYERNAME);
if (teams[2].players[p] == NULL) name[2][0] = 0;
else strncpy (name[2], teams[2].players[p]->name, LEN_PLAYERNAME);
if (teams[3].players[p] == NULL) name[3][0] = 0;
else strncpy (name[3], teams[3].players[p]->name, LEN_PLAYERNAME);
d_printf (" | %-10s | %-10s | %-10s | %-10s | %-10s Team:%d\n", name[0], name[1], name[2], name[3], players[p].name, players[p].team_nr);
}
};
void d_bitprint (int bits, int nr) {
int i;
for (i = nr-1; i >= 0; i--)
if ((bits & (1 << i)) == 0)
printf ("-");
else
printf ("X");
printf (" ");
};
void d_fatal (char *fmt,...) {
va_list args;
va_start (args, fmt);
fprintf (stdout, "FATAL:");
vfprintf (stdout, fmt, args);
va_end (args);
}
void debug_ingameinfo() {
int i;
char text[2048];
for (i = 0; i < map.size.x; i++)
stonelist_add (i, map.size.y-1);
redraw_logo (0, gfx.res.y-font[0].size.y * 2, gfx.res.y, gfx.res.x);
sprintf (text, "TDiff: %2.3f TFactor: %2.3f", timediff, timefactor);
font_gfxdraw (0, gfx.res.y-font[0].size.y, text, 0, 0, (map.size.y*256)+10);
/* sprintf (text, "P:");
for (i = 0; i < MAX_PLAYERS; i++)
if (PS_IS_playing (players[i].state)) {
sprintf (text, "%s Pos:%f,%f ", text, players[i].pos.x, players[i].pos.y);
}
font_gfxdraw (0, gfx.res.y-font[0].size.y*2, text, 0, 0, (map.size.y*256)+10); */
sprintf (text, "Pl_nr: %d TO: %3.2f", bman.players_nr, bman.timeout);
font_gfxdraw (100, gfx.res.y-font[0].size.y, text, 0, 0, (map.size.y*256)+10);
};