home *** CD-ROM | disk | FTP | other *** search
/ Maximum CD 2007 September / maximum-cd-2007-09.iso / Assets / data / AssaultCube_v0.93.exe / source / src / protocol.cpp < prev    next >
Encoding:
C/C++ Source or Header  |  2007-06-05  |  3.7 KB  |  128 lines

  1. // misc useful functions used by the server
  2.  
  3. #include "cube.h"
  4.  
  5. // all network traffic is in 32bit ints, which are then compressed using the following simple scheme (assumes that most values are small).
  6.  
  7. void putint(ucharbuf &p, int n)
  8. {
  9.     if(n<128 && n>-127) p.put(n);
  10.     else if(n<0x8000 && n>=-0x8000) { p.put(0x80); p.put(n); p.put(n>>8); }
  11.     else { p.put(0x81); p.put(n); p.put(n>>8); p.put(n>>16); p.put(n>>24); }
  12. }
  13.  
  14. int getint(ucharbuf &p)
  15. {
  16.     int c = (char)p.get();
  17.     if(c==-128) { int n = p.get(); n |= char(p.get())<<8; return n; }
  18.     else if(c==-127) { int n = p.get(); n |= p.get()<<8; n |= p.get()<<16; return n|(p.get()<<24); }
  19.     else return c;
  20. }
  21.  
  22. // much smaller encoding for unsigned integers up to 28 bits, but can handle signed
  23. void putuint(ucharbuf &p, int n)
  24. {
  25.     if(n < 0 || n >= (1<<21))
  26.     {
  27.         p.put(0x80 | (n & 0x7F));
  28.         p.put(0x80 | ((n >> 7) & 0x7F));
  29.         p.put(0x80 | ((n >> 14) & 0x7F));
  30.         p.put(n >> 21);
  31.     }
  32.     else if(n < (1<<7)) p.put(n);
  33.     else if(n < (1<<14))
  34.     {
  35.         p.put(0x80 | (n & 0x7F));
  36.         p.put(n >> 7);
  37.     }
  38.     else 
  39.     {
  40.         p.put(0x80 | (n & 0x7F));
  41.         p.put(0x80 | ((n >> 7) & 0x7F));
  42.         p.put(n >> 14);
  43.     }
  44. }
  45.  
  46. int getuint(ucharbuf &p)
  47. {
  48.     int n = p.get();
  49.     if(n & 0x80)
  50.     {
  51.         n += (p.get() << 7) - 0x80;
  52.         if(n & (1<<14)) n += (p.get() << 14) - (1<<14);
  53.         if(n & (1<<21)) n += (p.get() << 21) - (1<<21);
  54.         if(n & (1<<28)) n |= 0xF0000000;
  55.     }
  56.     return n;
  57. }
  58.  
  59. void sendstring(const char *t, ucharbuf &p)
  60. {
  61.     while(*t) putint(p, *t++);
  62.     putint(p, 0);
  63. }
  64.  
  65. void getstring(char *text, ucharbuf &p, int len)
  66. {
  67.     char *t = text;
  68.     do
  69.     {
  70.         if(t>=&text[len]) { text[len-1] = 0; return; }
  71.         if(!p.remaining()) { *t = 0; return; }
  72.         *t = getint(p);
  73.     }
  74.     while(*t++);
  75. }
  76.  
  77. void filtertext(char *dst, const char *src, bool whitespace, int len)
  78. {
  79.     for(int c = *src; c; c = *++src)
  80.     {
  81.         switch(c)
  82.         {
  83.         case '\f': ++src; continue;
  84.         }
  85.         if(isspace(c) ? whitespace : isprint(c))
  86.         {
  87.             *dst++ = c;
  88.             if(!--len) break;
  89.         }
  90.     }
  91.     *dst = '\0';
  92. }
  93.  
  94. const char *modenames[] =
  95. {
  96.     "team deathmatch", "coopedit", "deathmatch", "survivor",
  97.     "team survivor", "ctf", "pistol frenzy", "bot team deathmatch", "bot deathmatch", "last swiss standing", 
  98.     "one shot, one kill", "team one shot, one kill", "bot one shot, one skill"
  99. };
  100.  
  101. const char *modestr(int n) { return (n>=0 && (size_t)n < sizeof(modenames)/sizeof(modenames[0])) ? modenames[n] : "unknown"; }
  102.  
  103. char msgsizesl[] =               // size inclusive message token, 0 for variable or not-checked sizes
  104.     SV_INITS2C, 5, SV_INITC2S, 0, SV_POS, 0, SV_TEXT, 0, SV_TEAMTEXT, 0, SV_SOUND, 2, SV_CDIS, 2,
  105.     SV_GIBDIED, 2, SV_DIED, 2, SV_GIBDAMAGE, 4, SV_DAMAGE, 4, SV_SHOT, 9, SV_FRAGS, 2, SV_RESUME, 4,
  106.     SV_TIMEUP, 2, SV_EDITENT, 10, SV_MAPRELOAD, 2, SV_ITEMACC, 2,
  107.     SV_MAPCHANGE, 0, SV_ITEMSPAWN, 2, SV_ITEMPICKUP, 3,
  108.     SV_PING, 2, SV_PONG, 2, SV_CLIENTPING, 2, SV_GAMEMODE, 2,
  109.     SV_EDITH, 7, SV_EDITT, 7, SV_EDITS, 6, SV_EDITD, 6, SV_EDITE, 6,
  110.     SV_SENDMAP, 0, SV_RECVMAP, 1, SV_SERVMSG, 0, SV_ITEMLIST, 0, SV_WEAPCHANGE, 2,
  111.     SV_MODELSKIN, 2,
  112.     SV_FLAGPICKUP, 2, SV_FLAGDROP, 2, SV_FLAGRETURN, 2, SV_FLAGSCORE, 2, SV_FLAGRESET, 2, SV_FLAGINFO, 0, SV_FLAGS, 2,
  113.     SV_ARENASPAWN, 0, SV_ARENAWIN, 0,
  114.     SV_SETMASTER, 2, SV_SETADMIN, 0, SV_SERVOPINFO, 3, SV_SERVOPCMD, 3, SV_SERVOPCMDDENIED, 2,
  115.     SV_FORCETEAM, 2, SV_AUTOTEAM, 2,
  116.     SV_PWD, 0,
  117.     SV_CLIENT, 0,
  118.     -1
  119. };
  120.  
  121. char msgsizelookup(int msg)
  122. {
  123.     for(char *p = msgsizesl; *p>=0; p += 2) if(*p==msg) return p[1];
  124.     return -1;
  125. }
  126.  
  127.