mvds seem to work again

This commit is contained in:
Bill Currie 2005-05-01 22:13:10 +00:00
parent 281b683e14
commit c6cfcb1a9c
4 changed files with 57 additions and 39 deletions

View file

@ -36,7 +36,9 @@ struct sizebuf_s;
typedef struct recorder_s recorder_t; typedef struct recorder_s recorder_t;
void SVR_Init (void); void SVR_Init (void);
recorder_t *SVR_AddUser (void (*)(struct sizebuf_s *), int (*)(void)); recorder_t *SVR_AddUser (void (*writer)(struct sizebuf_s *),
int (*frame)(void),
void (*finish)(struct sizebuf_s *));
void SVR_RemoveUser (recorder_t *r); void SVR_RemoveUser (recorder_t *r);
struct sizebuf_s *SVR_WriteBegin (byte type, int to, int size); struct sizebuf_s *SVR_WriteBegin (byte type, int to, int size);
struct sizebuf_s *SVR_Datagram (void); struct sizebuf_s *SVR_Datagram (void);

View file

@ -123,6 +123,15 @@ demo_frame (void)
return 1; return 1;
} }
static void
demo_finish (sizebuf_t *msg)
{
// write a disconnect message to the demo file
MSG_WriteByte (msg, svc_disconnect);
MSG_WriteString (msg, "EndOfDemo");
recorder = 0;
}
/* /*
SV_Stop SV_Stop
@ -131,8 +140,6 @@ demo_frame (void)
void void
SV_Stop (int reason) SV_Stop (int reason)
{ {
sizebuf_t *dbuf;
if (!recorder) { if (!recorder) {
Con_Printf ("Not recording a demo.\n"); Con_Printf ("Not recording a demo.\n");
return; return;
@ -148,7 +155,6 @@ SV_Stop (int reason)
demo_file = NULL; demo_file = NULL;
SVR_RemoveUser (recorder); SVR_RemoveUser (recorder);
recorder = 0;
SV_BroadcastPrintf (PRINT_CHAT, SV_BroadcastPrintf (PRINT_CHAT,
"Server recording canceled, demo removed\n"); "Server recording canceled, demo removed\n");
@ -157,30 +163,13 @@ SV_Stop (int reason)
return; return;
} }
// write a disconnect message to the demo file
// clearup to be sure message will fit // clearup to be sure message will fit
dbuf = SVR_WriteBegin (dem_all, 0, 2 + strlen ("EndOfDemo"));
MSG_WriteByte (dbuf, svc_disconnect);
MSG_WriteString (dbuf, "EndOfDemo");
/* XXX
demo.dbuf->sz.cursize = 0;
demo.dbuf->h = NULL;
demo.dbuf->bufsize = 0;
DemoWrite_Begin (
SV_DemoWritePackets (demo.parsecount - demo.lastwritten + 1);
// finish up
if (!demo_disk) {
Qwrite (demo_file, svs.demomem, demo.size - demo_size);
Qflush (demo_file);
}
*/
Qclose (demo_file);
demo_file = NULL;
SVR_RemoveUser (recorder); SVR_RemoveUser (recorder);
Qclose (demo_file);
demo_file = NULL;
recorder = 0; recorder = 0;
if (!reason) if (!reason)
SV_BroadcastPrintf (PRINT_CHAT, "Server recording completed\n"); SV_BroadcastPrintf (PRINT_CHAT, "Server recording completed\n");
@ -417,7 +406,7 @@ SV_Record (char *name)
} else } else
QFS_Remove (demo_text->str); QFS_Remove (demo_text->str);
recorder = SVR_AddUser (demo_write, demo_frame); recorder = SVR_AddUser (demo_write, demo_frame, demo_finish);
demo_time = sv.time; demo_time = sv.time;
/*-------------------------------------------------*/ /*-------------------------------------------------*/

View file

@ -601,13 +601,14 @@ PF_stuffcmd (progs_t *pr)
p = strrchr (buf, '\n'); p = strrchr (buf, '\n');
if (p) { if (p) {
char t = p[1]; char t = p[1];
int len = (p - buf) + 2;
p[1] = 0; p[1] = 0;
MSG_ReliableWrite_Begin (&cl->backbuf, svc_stufftext, 2 + p - buf); MSG_ReliableWrite_Begin (&cl->backbuf, svc_stufftext, len + 1);
MSG_ReliableWrite_String (&cl->backbuf, buf); MSG_ReliableWrite_String (&cl->backbuf, buf);
if (sv.recorders) { if (sv.recorders) {
sizebuf_t *dbuf; sizebuf_t *dbuf;
dbuf = SVR_WriteBegin (dem_single, cl - svs.clients, 2 + p - buf); dbuf = SVR_WriteBegin (dem_single, cl - svs.clients, len + 1);
MSG_WriteByte (dbuf, svc_stufftext); MSG_WriteByte (dbuf, svc_stufftext);
MSG_WriteString (dbuf, buf); MSG_WriteString (dbuf, buf);
} }

View file

@ -103,8 +103,9 @@ typedef struct rec_s {
struct recorder_s { struct recorder_s {
recorder_t *next; recorder_t *next;
void (*writer)(sizebuf_t *); void (*write)(sizebuf_t *);
int (*frame)(void); int (*frame)(void);
void (*finish)(sizebuf_t *);
}; };
static rec_t rec; static rec_t rec;
@ -182,7 +183,8 @@ write_msg (sizebuf_t *msg, int type, int to, float time, sizebuf_t *dst)
MSG_WriteByte (dst, rec.lasttype | (rec.lastto << 3)); MSG_WriteByte (dst, rec.lasttype | (rec.lastto << 3));
break; break;
default: default:
//XXX SV_Stop (0); while (sv.recorders)
SVR_RemoveUser (sv.recorders);
Con_Printf ("bad demo message type:%d", type); Con_Printf ("bad demo message type:%d", type);
return; return;
} }
@ -332,7 +334,8 @@ SVR_Init (void)
} }
recorder_t * recorder_t *
SVR_AddUser (void (*writer)(sizebuf_t *), int (*frame)(void)) SVR_AddUser (void (*write)(sizebuf_t *), int (*frame)(void),
void (*finish)(sizebuf_t *))
{ {
recorder_t *r; recorder_t *r;
@ -350,8 +353,9 @@ SVR_AddUser (void (*writer)(sizebuf_t *), int (*frame)(void))
r->next = sv.recorders; r->next = sv.recorders;
sv.recorders = r; sv.recorders = r;
r->writer = writer; r->write = write;
r->frame = frame; r->frame = frame;
r->finish = finish;
return r; return r;
} }
@ -360,12 +364,34 @@ void
SVR_RemoveUser (recorder_t *r) SVR_RemoveUser (recorder_t *r)
{ {
recorder_t **_r; recorder_t **_r;
sizebuf_t msg;//, *dbuf;
memset (&msg, 0, sizeof (msg));
msg.data = msg_buffer;
msg.maxsize = sizeof (msg_buffer);
// rec.dbuf->sz.cursize = 0;
// rec.dbuf->h = 0;
// rec.dbuf->bufsize = 0;
MSG_WriteByte (&msg, 0);
MSG_WriteByte (&msg, dem_all);
MSG_WriteLong (&msg, 0);
r->finish (&msg);
if (msg.cursize > 6) {
msg.data[2] = ((msg.cursize - 6) >> 0) & 0xff;
msg.data[3] = ((msg.cursize - 6) >> 8) & 0xff;
msg.data[4] = ((msg.cursize - 6) >> 16) & 0xff;
msg.data[5] = ((msg.cursize - 6) >> 24) & 0xff;
r->write (&msg);
}
for (_r = &sv.recorders; *_r; _r = &(*_r)->next) { for (_r = &sv.recorders; *_r; _r = &(*_r)->next) {
if (*_r == r) { if (*_r == r) {
*_r = (*_r)->next; *_r = (*_r)->next;
r->next = free_recorders; r->next = free_recorders;
free_recorders = r; free_recorders = r;
break;
} }
} }
} }
@ -409,14 +435,12 @@ SVR_WritePacket (void)
sizebuf_t msg; sizebuf_t msg;
recorder_t *r; recorder_t *r;
write_datagram ();
memset (&msg, 0, sizeof (msg)); memset (&msg, 0, sizeof (msg));
msg.data = msg_buffer; msg.data = msg_buffer;
msg.maxsize = sizeof (msg_buffer); msg.maxsize = sizeof (msg_buffer);
msg.allowoverflow = true; msg.allowoverflow = true;
frame = &rec.frames[rec.lastwritten & DEMO_FRAMES_MASK]; frame = &rec.frames[rec.lastwritten++ & DEMO_FRAMES_MASK];
time = frame->time; time = frame->time;
rec.dbuf = &frame->buf; rec.dbuf = &frame->buf;
@ -424,13 +448,10 @@ SVR_WritePacket (void)
write_to_msg (0, 0, time, &msg); write_to_msg (0, 0, time, &msg);
for (r = sv.recorders; r; r = r->next) for (r = sv.recorders; r; r = r->next)
r->writer (&msg); r->write (&msg);
rec.dbuf = &rec.frames[rec.parsecount & DEMO_FRAMES_MASK].buf; rec.dbuf = &rec.frames[rec.parsecount & DEMO_FRAMES_MASK].buf;
rec.dbuf->sz.maxsize = MAXSIZE + rec.dbuf->bufsize; rec.dbuf->sz.maxsize = MAXSIZE + rec.dbuf->bufsize;
rec.parsecount++;
set_msgbuf (rec.dbuf, &rec.frames[rec.parsecount & DEMO_FRAMES_MASK].buf);
} }
sizebuf_t * sizebuf_t *
@ -572,5 +593,10 @@ SV_SendDemoMessage (void)
msg.allowoverflow = true; msg.allowoverflow = true;
msg.overflowed = false; msg.overflowed = false;
write_datagram ();
SVR_WritePacket (); SVR_WritePacket ();
rec.parsecount++;
set_msgbuf (rec.dbuf, &rec.frames[rec.parsecount & DEMO_FRAMES_MASK].buf);
} }