X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=prvm_cmds.c;h=8a0b2321d42309ace545ccb70d197b35ad0742c3;hb=66bb29b421a2e9f9146519a21ea969f3970aaee5;hp=ba52d1213aae636ac8af8128e8fccdfeeac3dc40;hpb=bdee526adfc38dc52821f14d1c76544bc6673dcb;p=xonotic%2Fdarkplaces.git diff --git a/prvm_cmds.c b/prvm_cmds.c index ba52d121..8a0b2321 100644 --- a/prvm_cmds.c +++ b/prvm_cmds.c @@ -42,7 +42,7 @@ entity findchain(.string field, string match) entity findchainfloat(.string field, float match) entity findchainentity(.string field, entity match) - + string precache_file(string) string precache_sound (string sample) coredump() @@ -89,7 +89,7 @@ float mod(float val, float m) const string str_cvar (string) crash() stackdump() - + float search_begin(string pattern, float caseinsensitive, float quiet) void search_end(float handle) float search_getsize(float handle) @@ -104,8 +104,9 @@ float altstr_count(string) string altstr_prepare(string) string altstr_get(string,float) string altstr_set(string altstr, float num, string set) - -perhaps only : Menu : WriteMsg +string altstr_ins(string altstr, float num, string set) + +perhaps only : Menu : WriteMsg =============================== WriteByte(float data, float dest, float desto) @@ -116,12 +117,12 @@ perhaps only : Menu : WriteMsg WriteCoord(float data, float dest, float desto) WriteString(string data, float dest, float desto) WriteEntity(entity data, float dest, float desto) - + Client & Menu : draw functions & video functions =================================================== float iscachedpic(string pic) -string precache_pic(string pic) +string precache_pic(string pic) freepic(string s) float drawcharacter(vector position, float character, vector scale, vector rgb, float alpha, float flag) float drawstring(vector position, string text, vector scale, vector rgb, float alpha, float flag) @@ -134,7 +135,7 @@ vector getimagesize(string pic) float cin_open(string file, string name) void cin_close(string name) void cin_setstate(string name, float type) -float cin_getstate(string name) +float cin_getstate(string name) void cin_restart(string name) ============================================================================== @@ -166,6 +167,8 @@ float stringtokeynum(string key) sethostcachesort(float field, float descending) refreshhostcache() float gethostcachenumber(float fld, float hostnr) +float gethostcacheindexforkey(string key) + addwantedhostcachekey(string key) */ #include "quakedef.h" @@ -412,7 +415,7 @@ void VM_sprint (void) Con_Printf("VM_sprint: %s: invalid client or server is not active !\n", PRVM_NAME); return; } - + client = svs.clients + clientnum; VM_VarString(1, string, sizeof(string)); MSG_WriteChar(&client->message,svc_print); @@ -639,7 +642,7 @@ localsound(string sample) void VM_localsound(void) { char *s; - + VM_SAFEPARMCOUNT(1,VM_localsound); s = PRVM_G_STRING(OFS_PARM0); @@ -649,7 +652,7 @@ void VM_localsound(void) Con_Printf("VM_localsound: Failed to play %s for %s !\n", s, PRVM_NAME); PRVM_G_FLOAT(OFS_RETURN) = -4; return; - } + } PRVM_G_FLOAT(OFS_RETURN) = 1; } @@ -706,7 +709,7 @@ VM_str_cvar const string str_cvar (string) ================= */ -void VM_str_cvar(void) +void VM_str_cvar(void) { char *out, *name; const char *cvar_string; @@ -719,10 +722,10 @@ void VM_str_cvar(void) VM_CheckEmptyString(name); - out = VM_GetTempString(); + out = VM_GetTempString(); cvar_string = Cvar_VariableString(name); - + strcpy(out, cvar_string); PRVM_G_INT(OFS_RETURN) = PRVM_SetString(out); @@ -882,7 +885,7 @@ void VM_ftoi(void) ent = PRVM_G_FLOAT(OFS_PARM0); if(PRVM_PROG_TO_EDICT(ent)->p.e->free) PRVM_ERROR ("VM_ftoe: %s tried to access a freed entity (entity %i)!\n", PRVM_NAME, ent); - + PRVM_G_INT(OFS_RETURN) = ent; } @@ -1198,7 +1201,7 @@ crash() ========= */ -void VM_crash(void) +void VM_crash(void) { VM_SAFEPARMCOUNT(0, VM_crash); @@ -1437,7 +1440,7 @@ void VM_changelevel (void) if(!sv.active) { - Con_Printf("VM_changelevel: game is not server (%s)\n", PRVM_NAME); + Con_Printf("VM_changelevel: game is not server (%s)\n", PRVM_NAME); return; } @@ -1773,9 +1776,9 @@ void VM_fopen(void) PRVM_G_FLOAT(OFS_RETURN) = -4; return; } - VM_FILES[filenum] = FS_Open(va("data/%s", filename), modestring, false); + VM_FILES[filenum] = FS_Open(va("data/%s", filename), modestring, false, false); if (VM_FILES[filenum] == NULL && mode == 0) - VM_FILES[filenum] = FS_Open(va("%s", filename), modestring, false); + VM_FILES[filenum] = FS_Open(va("%s", filename), modestring, false, false); if (VM_FILES[filenum] == NULL) PRVM_G_FLOAT(OFS_RETURN) = -1; @@ -1851,7 +1854,11 @@ void VM_fgets(void) string[end] = 0; // remove \n following \r if (c == '\r') + { c = FS_Getc(VM_FILES[filenum]); + if (c != '\n') + FS_UnGetc(VM_FILES[filenum], (unsigned char)c); + } if (developer.integer >= 3) Con_Printf("fgets: %s: %s\n", PRVM_NAME, string); if (c >= 0 || end) @@ -1929,9 +1936,9 @@ void VM_strcat(void) { char *s; - if(prog->argc < 1) + if(prog->argc < 1) PRVM_ERROR("VM_strcat wrong parameter count (min. 1 expected ) !\n"); - + s = VM_GetTempString(); VM_VarString(0, s, VM_STRINGTEMP_LENGTH); PRVM_G_INT(OFS_RETURN) = PRVM_SetString(s); @@ -2242,7 +2249,7 @@ void VM_getmousepos(void) { VM_SAFEPARMCOUNT(0,VM_getmousepos); - + PRVM_G_VECTOR(OFS_RETURN)[0] = in_mouse_x; PRVM_G_VECTOR(OFS_RETURN)[1] = in_mouse_y; PRVM_G_VECTOR(OFS_RETURN)[2] = 0; @@ -2289,7 +2296,7 @@ void VM_M_parseentitydata(void) const char *data; VM_SAFEPARMCOUNT(2, VM_parseentitydata); - + // get edict and test it ent = PRVM_G_EDICT(OFS_PARM0); if (ent->p.e->free) @@ -2315,9 +2322,9 @@ void VM_loadfromfile(void) { char *filename; qbyte *data; - + VM_SAFEPARMCOUNT(1,VM_loadfromfile); - + filename = PRVM_G_STRING(OFS_PARM0); // .. is parent directory on many platforms // / is parent directory on Amiga @@ -2334,7 +2341,7 @@ void VM_loadfromfile(void) data = FS_LoadFile(filename, tempmempool, false); if (data == NULL) PRVM_G_FLOAT(OFS_RETURN) = -1; - + PRVM_ED_LoadFromFile(data); if(data) @@ -2396,7 +2403,7 @@ void VM_search_begin(void) caseinsens = PRVM_G_FLOAT(OFS_PARM1); quiet = PRVM_G_FLOAT(OFS_PARM2); - + for(handle = 0; handle < MAX_VMSEARCHES; handle++) if(!VM_SEARCHLIST[handle]) break; @@ -2427,7 +2434,7 @@ void VM_search_end(void) VM_SAFEPARMCOUNT(1, VM_search_end); handle = PRVM_G_FLOAT(OFS_PARM0); - + if(handle < 0 || handle >= MAX_VMSEARCHES) { Con_Printf("VM_search_end: invalid handle %i used in %s\n", handle, PRVM_NAME); @@ -2467,7 +2474,7 @@ void VM_search_getsize(void) Con_Printf("VM_search_getsize: no such handle %i in %s\n", handle, PRVM_NAME); return; } - + PRVM_G_FLOAT(OFS_RETURN) = VM_SEARCHLIST[handle]->numfilenames; } @@ -2502,7 +2509,7 @@ void VM_search_getfilename(void) Con_Printf("VM_search_getfilename: invalid filenum %i in %s\n", filenum, PRVM_NAME); return; } - + tmp = VM_GetTempString(); strcpy(tmp, VM_SEARCHLIST[handle]->filenames[filenum]); @@ -2542,7 +2549,7 @@ void VM_iscachedpic(void) { VM_SAFEPARMCOUNT(1,VM_iscachedpic); - // drawq hasnt such a function, thus always return true + // drawq hasnt such a function, thus always return true PRVM_G_FLOAT(OFS_RETURN) = false; } @@ -2550,25 +2557,25 @@ void VM_iscachedpic(void) ========= VM_precache_pic -string precache_pic(string pic) +string precache_pic(string pic) ========= */ void VM_precache_pic(void) { char *s; - + VM_SAFEPARMCOUNT(1, VM_precache_pic); - + s = PRVM_G_STRING(OFS_PARM0); PRVM_G_INT(OFS_RETURN) = PRVM_G_INT(OFS_PARM0); - + if(!s) PRVM_ERROR ("VM_precache_pic: %s: NULL\n", PRVM_NAME); VM_CheckEmptyString (s); - + if(!Draw_CachePic(s)) - PRVM_G_INT(OFS_RETURN) = PRVM_SetString(""); + PRVM_G_INT(OFS_RETURN) = PRVM_SetString(""); } /* @@ -2585,12 +2592,12 @@ void VM_freepic(void) VM_SAFEPARMCOUNT(1,VM_freepic); s = PRVM_G_STRING(OFS_PARM0); - + if(!s) PRVM_ERROR ("VM_freepic: %s: NULL\n"); - + VM_CheckEmptyString (s); - + Draw_FreePic(s); } @@ -2615,21 +2622,21 @@ void VM_drawcharacter(void) PRVM_G_FLOAT(OFS_RETURN) = -1; return; } - + pos = PRVM_G_VECTOR(OFS_PARM0); scale = PRVM_G_VECTOR(OFS_PARM2); rgb = PRVM_G_VECTOR(OFS_PARM3); flag = (int)PRVM_G_FLOAT(OFS_PARM5); - + if(flag < DRAWFLAG_NORMAL || flag >=DRAWFLAG_NUMFLAGS) { Con_Printf("VM_drawcharacter: %s: wrong DRAWFLAG %i !\n",PRVM_NAME,flag); PRVM_G_FLOAT(OFS_RETURN) = -2; return; } - + if(pos[2] || scale[2]) - Con_Printf("VM_drawcharacter: z value%c from %s discarded\n",(pos[2] && scale[2]) ? 's' : 0,((pos[2] && scale[2]) ? "pos and scale" : (pos[2] ? "pos" : "scale"))); + Con_Printf("VM_drawcharacter: z value%c from %s discarded\n",(pos[2] && scale[2]) ? 's' : 0,((pos[2] && scale[2]) ? "pos and scale" : (pos[2] ? "pos" : "scale"))); if(!scale[0] || !scale[1]) { @@ -2640,7 +2647,7 @@ void VM_drawcharacter(void) DrawQ_String (pos[0], pos[1], &character, 1, scale[0], scale[1], rgb[0], rgb[1], rgb[2], PRVM_G_FLOAT(OFS_PARM4), flag); PRVM_G_FLOAT(OFS_RETURN) = 1; -} +} /* ========= @@ -2655,7 +2662,7 @@ void VM_drawstring(void) char *string; int flag; VM_SAFEPARMCOUNT(6,VM_drawstring); - + string = PRVM_G_STRING(OFS_PARM1); if(!string) { @@ -2663,21 +2670,21 @@ void VM_drawstring(void) PRVM_G_FLOAT(OFS_RETURN) = -1; return; } - + //VM_CheckEmptyString(string); Why should it be checked - perhaps the menu wants to support the precolored letters, too? - + pos = PRVM_G_VECTOR(OFS_PARM0); scale = PRVM_G_VECTOR(OFS_PARM2); rgb = PRVM_G_VECTOR(OFS_PARM3); flag = (int)PRVM_G_FLOAT(OFS_PARM5); - + if(flag < DRAWFLAG_NORMAL || flag >=DRAWFLAG_NUMFLAGS) { Con_Printf("VM_drawstring: %s: wrong DRAWFLAG %i !\n",PRVM_NAME,flag); PRVM_G_FLOAT(OFS_RETURN) = -2; return; } - + if(!scale[0] || !scale[1]) { Con_Printf("VM_drawstring: scale %s is null !\n", (scale[0] == 0) ? ((scale[1] == 0) ? "x and y" : "x") : "y"); @@ -2686,8 +2693,8 @@ void VM_drawstring(void) } if(pos[2] || scale[2]) - Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && scale[2]) ? 's' : 0,((pos[2] && scale[2]) ? "pos and scale" : (pos[2] ? "pos" : "scale"))); - + Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && scale[2]) ? 's' : 0,((pos[2] && scale[2]) ? "pos and scale" : (pos[2] ? "pos" : "scale"))); + DrawQ_String (pos[0], pos[1], string, 0, scale[0], scale[1], rgb[0], rgb[1], rgb[2], PRVM_G_FLOAT(OFS_PARM4), flag); PRVM_G_FLOAT(OFS_RETURN) = 1; } @@ -2711,7 +2718,7 @@ void VM_drawpic(void) if(!pic) { Con_Printf("VM_drawpic: %s passed null picture name !\n", PRVM_NAME); - PRVM_G_FLOAT(OFS_RETURN) = -1; + PRVM_G_FLOAT(OFS_RETURN) = -1; return; } @@ -2724,7 +2731,7 @@ void VM_drawpic(void) PRVM_G_FLOAT(OFS_RETURN) = -4; return; } - + pos = PRVM_G_VECTOR(OFS_PARM0); size = PRVM_G_VECTOR(OFS_PARM2); rgb = PRVM_G_VECTOR(OFS_PARM3); @@ -2738,8 +2745,8 @@ void VM_drawpic(void) } if(pos[2] || size[2]) - Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && size[2]) ? 's' : 0,((pos[2] && size[2]) ? "pos and size" : (pos[2] ? "pos" : "size"))); - + Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && size[2]) ? 's' : 0,((pos[2] && size[2]) ? "pos and size" : (pos[2] ? "pos" : "size"))); + DrawQ_Pic(pos[0], pos[1], pic, size[0], size[1], rgb[0], rgb[1], rgb[2], PRVM_G_FLOAT(OFS_PARM4), flag); PRVM_G_FLOAT(OFS_RETURN) = 1; } @@ -2755,25 +2762,25 @@ void VM_drawfill(void) { float *size, *pos, *rgb; int flag; - + VM_SAFEPARMCOUNT(5,VM_drawfill); - - + + pos = PRVM_G_VECTOR(OFS_PARM0); size = PRVM_G_VECTOR(OFS_PARM1); rgb = PRVM_G_VECTOR(OFS_PARM2); flag = (int) PRVM_G_FLOAT(OFS_PARM4); - + if(flag < DRAWFLAG_NORMAL || flag >=DRAWFLAG_NUMFLAGS) { Con_Printf("VM_drawstring: %s: wrong DRAWFLAG %i !\n",PRVM_NAME,flag); PRVM_G_FLOAT(OFS_RETURN) = -2; return; } - + if(pos[2] || size[2]) - Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && size[2]) ? 's' : 0,((pos[2] && size[2]) ? "pos and size" : (pos[2] ? "pos" : "size"))); - + Con_Printf("VM_drawstring: z value%c from %s discarded\n",(pos[2] && size[2]) ? 's' : 0,((pos[2] && size[2]) ? "pos and size" : (pos[2] ? "pos" : "size"))); + DrawQ_Pic(pos[0], pos[1], 0, size[0], size[1], rgb[0], rgb[1], rgb[2], PRVM_G_FLOAT(OFS_PARM3), flag); PRVM_G_FLOAT(OFS_RETURN) = 1; } @@ -2793,7 +2800,7 @@ void VM_drawsetcliparea(void) x = bound(0, PRVM_G_FLOAT(OFS_PARM0), vid.conwidth); y = bound(0, PRVM_G_FLOAT(OFS_PARM1), vid.conheight); w = bound(0, PRVM_G_FLOAT(OFS_PARM2) + PRVM_G_FLOAT(OFS_PARM0) - x, (vid.conwidth - x)); - h = bound(0, PRVM_G_FLOAT(OFS_PARM3) + PRVM_G_FLOAT(OFS_PARM1) - y, (vid.conheight - y)); + h = bound(0, PRVM_G_FLOAT(OFS_PARM3) + PRVM_G_FLOAT(OFS_PARM1) - y, (vid.conheight - y)); DrawQ_SetClipArea(x, y, w, h); } @@ -2825,12 +2832,12 @@ void VM_getimagesize(void) cachepic_t *pic; VM_SAFEPARMCOUNT(1,VM_getimagesize); - + p = PRVM_G_STRING(OFS_PARM0); if(!p) PRVM_ERROR("VM_getimagepos: %s passed null picture name !\n", PRVM_NAME); - + VM_CheckEmptyString (p); pic = Draw_CachePic (p); @@ -2853,9 +2860,9 @@ void VM_cin_open( void ) { char *file; char *name; - + VM_SAFEPARMCOUNT( 2, VM_cin_open ); - + file = PRVM_G_STRING( OFS_PARM0 ); name = PRVM_G_STRING( OFS_PARM1 ); @@ -2884,7 +2891,7 @@ void VM_cin_close( void ) name = PRVM_G_STRING( OFS_PARM0 ); VM_CheckEmptyString( name ); - CL_CloseVideo( CL_GetVideo( name ) ); + CL_CloseVideo( CL_GetVideo( name ) ); } /* @@ -2908,7 +2915,7 @@ void VM_cin_setstate( void ) video = CL_GetVideo( name ); if( video && state > CLVIDEO_UNUSED && state < CLVIDEO_STATECOUNT ) - CL_SetVideoState( video, state ); + CL_SetVideoState( video, state ); } /* @@ -3040,7 +3047,7 @@ void VM_altstr_get( void ) for( pos = altstr ; *pos && count ; pos++ ) if( *pos == '\\' && !*++pos ) - break; + break; else if( *pos == '\'' ) count--; @@ -3104,9 +3111,9 @@ void VM_altstr_set( void ) for( ; *str; *out++ = *str++ ); // now jump over the old contents for( ; *in ; in++ ) - if( *in == '\'' || *in == '\\' && !*++in ) + if( *in == '\'' || (*in == '\\' && !*++in) ) break; - + if( !in ) { PRVM_G_INT( OFS_RETURN ) = PRVM_SetString( "" ); return; @@ -3116,6 +3123,40 @@ void VM_altstr_set( void ) PRVM_G_INT( OFS_RETURN ) = PRVM_SetString( outstr ); } +/* +======================== +VM_altstr_ins +insert after num +string altstr_ins(string altstr, float num, string set) +======================== +*/ +void VM_altstr_ins(void) +{ + int num; + char *setstr; + char *set; + char *instr; + char *in; + char *outstr; + char *out; + + in = instr = PRVM_G_STRING( OFS_PARM0 ); + num = PRVM_G_FLOAT( OFS_PARM1 ); + set = setstr = PRVM_G_STRING( OFS_PARM2 ); + + out = outstr = VM_GetTempString(); + for( num = num * 2 + 2 ; *in && num > 0 ; *out++ = *in++ ) + if( *in == '\\' && !*++in ) + break; + else if( *in == '\'' ) + num--; + + for( ; *set ; *out++ = *set++ ); + + strcpy( out, in ); + PRVM_G_INT( OFS_RETURN ) = PRVM_SetString( outstr ); +} + void VM_Cmd_Init(void) { // only init the stuff for the current prog @@ -3227,7 +3268,7 @@ void VM_M_getmousetarget(void) else PRVM_G_FLOAT(OFS_RETURN) = 1; } - + /* @@ -3294,7 +3335,7 @@ void VM_M_getkeydest(void) VM_M_callfunction callfunction(...,string function_name) -Extension: pass +Extension: pass ========= */ mfunction_t *PRVM_ED_FindFunction (const char *name); @@ -3311,7 +3352,7 @@ void VM_M_callfunction(void) if(!s) PRVM_ERROR("VM_M_callfunction: null string !\n"); - VM_CheckEmptyString(s); + VM_CheckEmptyString(s); func = PRVM_ED_FindFunction(s); @@ -3333,7 +3374,7 @@ void VM_M_callfunction(void) PRVM_ExecuteProgram(func - prog->functions,""); prog->argc++; } -} +} /* ========= @@ -3347,16 +3388,16 @@ void VM_M_isfunction(void) { mfunction_t *func; char *s; - + VM_SAFEPARMCOUNT(1, VM_M_isfunction); - + s = PRVM_G_STRING(OFS_PARM0); - + if(!s) PRVM_ERROR("VM_M_isfunction: null string !\n"); - - VM_CheckEmptyString(s); - + + VM_CheckEmptyString(s); + func = PRVM_ED_FindFunction(s); if(!func) @@ -3391,7 +3432,7 @@ void VM_M_writetofile(void) return; } - ent = PRVM_G_EDICT(OFS_PARM1); + ent = PRVM_G_EDICT(OFS_PARM1); if(ent->p.e->free) { Con_Printf("VM_M_writetofile: %s: entity %i is free !\n", PRVM_NAME, PRVM_EDICT_NUM(OFS_PARM1)); @@ -3419,7 +3460,7 @@ void VM_M_getresolution(void) PRVM_G_VECTOR(OFS_RETURN)[0] = video_resolutions[nr][0]; PRVM_G_VECTOR(OFS_RETURN)[1] = video_resolutions[nr][1]; - PRVM_G_VECTOR(OFS_RETURN)[2] = 0; + PRVM_G_VECTOR(OFS_RETURN)[2] = 0; } /* @@ -3438,7 +3479,7 @@ void VM_M_keynumtostring(void) keynum = PRVM_G_FLOAT(OFS_PARM0); tmp = VM_GetTempString(); - + strcpy(tmp, Key_KeynumToString(keynum)); PRVM_G_INT(OFS_RETURN) = PRVM_SetString(tmp); @@ -3482,11 +3523,11 @@ void VM_M_findkeysforcommand(void) VM_SAFEPARMCOUNT(1, VM_M_findkeysforcommand); cmd = PRVM_G_STRING(OFS_PARM0); - + VM_CheckEmptyString(cmd); (ret = VM_GetTempString())[0] = 0; - + M_FindKeysForCommand(cmd, keys); for(i = 0; i < NUMKEYS; i++) @@ -3527,7 +3568,7 @@ void VM_M_gethostcachestat( void ) PRVM_G_FLOAT ( OFS_RETURN ) = hostcache_viewcount; return; case 1: - PRVM_G_FLOAT ( OFS_RETURN ) = hostcache_cachecount; + PRVM_G_FLOAT ( OFS_RETURN ) = hostcache_cachecount; case 2: PRVM_G_FLOAT ( OFS_RETURN ) = masterquerycount; return; @@ -3596,7 +3637,7 @@ void VM_M_sethostcachemaskstring( void ) } field = (int) PRVM_G_FLOAT( OFS_PARM1 ); - + switch( field ) { case HCIF_CNAME: strncpy( mask->info.cname, PRVM_G_STRING( OFS_PARM2 ), sizeof(mask->info.cname) ); @@ -3620,7 +3661,7 @@ void VM_M_sethostcachemaskstring( void ) mask->active = true; mask->tests[field] = (int) PRVM_G_FLOAT( OFS_PARM3 ); -} +} /* ======================== @@ -3806,9 +3847,59 @@ refreshhostcache() */ void VM_M_refreshhostcache( void ) { + VM_SAFEPARMCOUNT( 0, VM_M_refreshhostcache ); HostCache_QueryList(); } +/* +======================== +VM_M_gethostcacheindexforkey + +float gethostcacheindexforkey(string key) +======================== +*/ +void VM_M_gethostcacheindexforkey( void ) +{ + char *key; + VM_SAFEPARMCOUNT( 1, VM_M_gethostcacheindexforkey ); + + key = PRVM_G_STRING( OFS_PARM0 ); + VM_CheckEmptyString( key ); + + if( !strcmp( key, "cname" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_CNAME; + else if( !strcmp( key, "ping" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_PING; + else if( !strcmp( key, "game" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_GAME; + else if( !strcmp( key, "mod" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_MOD; + else if( !strcmp( key, "map" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_MAP; + else if( !strcmp( key, "name" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_NAME; + else if( !strcmp( key, "maxplayers" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_MAXPLAYERS; + else if( !strcmp( key, "numplayers" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_NUMPLAYERS; + else if( !strcmp( key, "protocol" ) ) + PRVM_G_FLOAT( OFS_RETURN ) = HCIF_PROTOCOL; + else + PRVM_G_FLOAT( OFS_RETURN ) = -1; +} + +/* +======================== +VM_M_addwantedhostcachekey + +addwantedhostcachekey(string key) +======================== +*/ +void VM_M_addwantedhostcachekey( void ) +{ + VM_SAFEPARMCOUNT( 1, VM_M_addwantedhostcachekey ); +} + prvm_builtin_t vm_m_builtins[] = { 0, // to be consistent with the old vm // common builtings (mostly) @@ -3872,32 +3963,33 @@ prvm_builtin_t vm_m_builtins[] = { VM_tokenize, VM_argv, VM_isserver, // 60 - VM_clientcount, - VM_clientstate, + VM_clientcount, + VM_clientstate, VM_clcommand, VM_changelevel, - VM_localsound, + VM_localsound, VM_getmousepos, VM_gettime, VM_loadfromdata, VM_loadfromfile, VM_modulo, // 70 - VM_str_cvar, + VM_str_cvar, VM_crash, VM_stackdump, // 73 VM_search_begin, VM_search_end, VM_search_getsize, VM_search_getfilename, // 77 - VM_chr, + VM_chr, VM_itof, VM_ftoi, // 80 VM_itof, // isString VM_altstr_count, VM_altstr_prepare, VM_altstr_get, - VM_altstr_set, // 85 - 0,0,0,0,0, // 90 + VM_altstr_set, + VM_altstr_ins, // 86 + 0,0,0,0, // 90 e10, // 100 e100, // 200 e100, // 300 @@ -3924,13 +4016,13 @@ prvm_builtin_t vm_m_builtins[] = { VM_drawcharacter, VM_drawstring, VM_drawpic, - VM_drawfill, + VM_drawfill, VM_drawsetcliparea, VM_drawresetcliparea, VM_getimagesize,// 460 VM_cin_open, VM_cin_close, - VM_cin_setstate, + VM_cin_setstate, VM_cin_getstate, VM_cin_restart, // 465 0,0,0,0,0, // 470 @@ -3959,7 +4051,9 @@ prvm_builtin_t vm_m_builtins[] = { VM_M_resorthostcache, VM_M_sethostcachesort, VM_M_refreshhostcache, - VM_M_gethostcachenumber // 621 + VM_M_gethostcachenumber, + VM_M_gethostcacheindexforkey, + VM_M_addwantedhostcachekey // 623 }; const int vm_m_numbuiltins = sizeof(vm_m_builtins) / sizeof(prvm_builtin_t);