ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/socket/lowlevel.C
(Generate patch)

Comparing deliantra/server/socket/lowlevel.C (file contents):
Revision 1.33 by root, Sun Feb 4 21:02:54 2007 UTC vs.
Revision 1.36 by root, Wed Mar 14 15:44:47 2007 UTC

202 {"mapinfo", PC(MapInfoCmd) 0 }, /* CF+ */ 202 {"mapinfo", PC(MapInfoCmd) 0 }, /* CF+ */
203 203
204 {"reply", SC(ReplyCmd) 0 }, 204 {"reply", SC(ReplyCmd) 0 },
205 {"exti", SC(ExtiCmd) 0 }, /* CF+ */ 205 {"exti", SC(ExtiCmd) 0 }, /* CF+ */
206 {"addme", SC(AddMeCmd) 0 }, 206 {"addme", SC(AddMeCmd) 0 },
207 {"askface", SC(SendFaceCmd) 0 }, /* Added: phil */ 207 {"askface", SC(AskFaceCmd) 0 },
208 {"requestinfo", SC(RequestInfo) 0 }, 208 {"requestinfo", SC(RequestInfo) 0 },
209 {"setfacemode", SC(SetFaceMode) 0 }, 209 {"setfacemode", SC(SetFaceMode) 0 },
210 {"setsound", SC(SetSound) 0 }, 210 {"setsound", SC(SetSound) 0 },
211 {"setup", SC(SetUp) 0 }, 211 {"setup", SC(SetUp) 0 },
212 {"version", SC(VersionCmd) 0 }, 212 {"version", SC(VersionCmd) 0 },
409 */ 409 */
410void 410void
411client::send (void *buf_, int len) 411client::send (void *buf_, int len)
412{ 412{
413 char *buf = (char *)buf_; 413 char *buf = (char *)buf_;
414 char *pos = buf;
415 int amt = 0;
416 414
417 if (destroyed () || !buf) 415 if (destroyed () || !buf)
418 return; 416 return;
419 417
420 if (len + outputbuffer.len > SOCKETBUFSIZE) 418 if (len + outputbuffer.len > SOCKETBUFSIZE)
421 { 419 {
422 LOG (llevDebug, "socket on fd %d has overrun internal buffer - marking as dead\n", fd); 420 LOG (llevDebug, "socket on fd %d has overrun internal buffer - marking as dead\n", fd);
423 destroy (); 421 // shutdown the socket, this is safer than destroying it immediately
422 // as lots of code in the callchain might still access the map etc.
423 shutdown (fd, SHUT_RDWR);
424 return; 424 return;
425 } 425 }
426 426
427 int avail, end; 427 int avail, end;
428 428
504 va_end (ap); 504 va_end (ap);
505 505
506 send_packet (sl); 506 send_packet (sl);
507} 507}
508 508
509void
510client::send_drawinfo (const char *msg, int flags)
511{
512 send_packet_printf ("drawinfo %d %s", flags, msg);
513}
514
509/*********************************************************************** 515/***********************************************************************
510 * 516 *
511 * packet functions/utilities 517 * packet functions/utilities
512 * 518 *
513 **********************************************************************/ 519 **********************************************************************/

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines