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.34 by pippijn, Thu Mar 1 12:28:17 2007 UTC vs.
Revision 1.37 by root, Mon Apr 2 19:56:11 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 },
416 return; 416 return;
417 417
418 if (len + outputbuffer.len > SOCKETBUFSIZE) 418 if (len + outputbuffer.len > SOCKETBUFSIZE)
419 { 419 {
420 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);
421 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);
422 return; 424 return;
423 } 425 }
424 426
425 int avail, end; 427 int avail, end;
426 428
502 va_end (ap); 504 va_end (ap);
503 505
504 send_packet (sl); 506 send_packet (sl);
505} 507}
506 508
509void
510client::send_drawinfo (const char *msg, int flags)
511{
512 send_packet_printf ("drawinfo %d %s", flags, msg);
513}
514
507/*********************************************************************** 515/***********************************************************************
508 * 516 *
509 * packet functions/utilities 517 * packet functions/utilities
510 * 518 *
511 **********************************************************************/ 519 **********************************************************************/
515 reset (); 523 reset ();
516 524
517 int len = strlen (name); 525 int len = strlen (name);
518 memcpy (cur, name, len); cur += len; 526 memcpy (cur, name, len); cur += len;
519 *cur++ = ' '; 527 *cur++ = ' ';
528}
529
530packet &packet::operator <<(const ber32 v)
531{
532 enum { maxlen = 32 / 7 + 1};
533 uint8 buf[maxlen];
534 uint8 *p = buf + maxlen;
535 uint32 val = v.val;
536
537 while (val > 0x7F)
538 {
539 *--p = (val & 0x7F) | 0x80;
540 val >>= 7;
541 }
542
543 *--p = val;
544
545 return *this << data (p, buf + maxlen - p);
520} 546}
521 547
522packet &packet::operator <<(const data &v) 548packet &packet::operator <<(const data &v)
523{ 549{
524 if (room () < v.len) 550 if (room () < v.len)

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines