X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=prvm_edict.c;h=fa313eff12f2b9a6a0354a60d42ed93a373f78bf;hb=7e1f7d12f57c064a6855d9850d28387ca6092c45;hp=ea8392751e9760f2aff73c0881557e1f7c608557;hpb=f847004b9818defbfd4bf15fe7b891fee2706079;p=xonotic%2Fdarkplaces.git diff --git a/prvm_edict.c b/prvm_edict.c index ea839275..fa313eff 100644 --- a/prvm_edict.c +++ b/prvm_edict.c @@ -297,7 +297,11 @@ prvm_edict_t *PRVM_ED_Alloc(prvm_prog_t *prog) PRVM_ED_Free Marks the edict as free + FIXME: walk all entities and NULL out references to this entity +bones_was_here: do not want, that would break chains immediately! +Currently chains aren't broken by removing an entity, at least with prvm_reuseedicts_neverinsameframe 1 +which is very handy and some QC code will depend on it. ================= */ void PRVM_ED_Free(prvm_prog_t *prog, prvm_edict_t *ed) @@ -3140,6 +3144,8 @@ PRVM_Init */ void PRVM_Init (void) { + unsigned int i; + Cmd_AddCommand(CF_SHARED, "prvm_edict", PRVM_ED_PrintEdict_f, "print all data about an entity number in the selected VM (server, client, menu)"); Cmd_AddCommand(CF_SHARED, "prvm_edicts", PRVM_ED_PrintEdicts_f, "prints all data about all entities in the selected VM (server, client, menu)"); Cmd_AddCommand(CF_SHARED, "prvm_edictcount", PRVM_ED_Count_f, "prints number of active entities in the selected VM (server, client, menu)"); @@ -3184,6 +3190,18 @@ void PRVM_Init (void) prvm_runawaycheck = !Sys_CheckParm("-norunaway"); //VM_Cmd_Init(); + + // LadyHavoc: report supported extensions + Con_DPrintf("\nQuakeC extensions for server and client:"); + for (i = 0; vm_sv_extensions[i]; i++) + Con_DPrintf(" %s", vm_sv_extensions[i]); + Con_DPrintf("\n"); +#ifdef CONFIG_MENU + Con_DPrintf("\nQuakeC extensions for menu:"); + for (i = 0; vm_m_extensions[i]; i++) + Con_DPrintf(" %s", vm_m_extensions[i]); + Con_DPrintf("\n"); +#endif } /* @@ -3356,18 +3374,18 @@ int PRVM_SetTempString(prvm_prog_t *prog, const char *s) return 0; size = (int)strlen(s) + 1; if (developer_insane.integer) - Con_DPrintf("PRVM_SetTempString: cursize %i, size %i\n", prog->tempstringsbuf.cursize, size); + Con_DPrintf("PRVM_SetTempString %s: cursize %i, size %i\n", prog->name, prog->tempstringsbuf.cursize, size); if (prog->tempstringsbuf.maxsize < prog->tempstringsbuf.cursize + size) { sizebuf_t old = prog->tempstringsbuf; if (prog->tempstringsbuf.cursize + size >= 1<<28) - prog->error_cmd("PRVM_SetTempString: ran out of tempstring memory! (refusing to grow tempstring buffer over 256MB, cursize %i, size %i)\n", prog->tempstringsbuf.cursize, size); + prog->error_cmd("PRVM_SetTempString %s: ran out of tempstring memory! (refusing to grow tempstring buffer over 256MB, cursize %i, size %i)\n", prog->name, prog->tempstringsbuf.cursize, size); prog->tempstringsbuf.maxsize = max(prog->tempstringsbuf.maxsize, 65536); while (prog->tempstringsbuf.maxsize < prog->tempstringsbuf.cursize + size) prog->tempstringsbuf.maxsize *= 2; if (prog->tempstringsbuf.maxsize != old.maxsize || prog->tempstringsbuf.data == NULL) { - Con_DPrintf("PRVM_SetTempString: enlarging tempstrings buffer (%iKB -> %iKB)\n", old.maxsize/1024, prog->tempstringsbuf.maxsize/1024); + Con_DPrintf("PRVM_SetTempString %s: enlarging tempstrings buffer (%iKB -> %iKB)\n", prog->name, old.maxsize/1024, prog->tempstringsbuf.maxsize/1024); prog->tempstringsbuf.data = (unsigned char *) Mem_Alloc(prog->progs_mempool, prog->tempstringsbuf.maxsize); if (old.data) { @@ -3408,16 +3426,16 @@ int PRVM_AllocString(prvm_prog_t *prog, size_t bufferlength, char **pointer) void PRVM_FreeString(prvm_prog_t *prog, int num) { if (num == 0) - prog->error_cmd("PRVM_FreeString: attempt to free a NULL string"); + prog->error_cmd("PRVM_FreeString %s: attempt to free a NULL string", prog->name); else if (num >= 0 && num < prog->stringssize) - prog->error_cmd("PRVM_FreeString: attempt to free a constant string"); + prog->error_cmd("PRVM_FreeString %s: attempt to free a constant string", prog->name); else if (num >= PRVM_KNOWNSTRINGBASE && num < PRVM_KNOWNSTRINGBASE + prog->numknownstrings) { num = num - PRVM_KNOWNSTRINGBASE; if (!prog->knownstrings[num]) - prog->error_cmd("PRVM_FreeString: attempt to free a non-existent or already freed string"); + prog->error_cmd("PRVM_FreeString %s: attempt to free a non-existent or already freed string", prog->name); if (!prog->knownstrings_flags[num]) - prog->error_cmd("PRVM_FreeString: attempt to free a string owned by the engine"); + prog->error_cmd("PRVM_FreeString %s: attempt to free a string owned by the engine", prog->name); PRVM_Free((char *)prog->knownstrings[num]); if(prog->leaktest_active) if(prog->knownstrings_origin[num]) @@ -3427,7 +3445,7 @@ void PRVM_FreeString(prvm_prog_t *prog, int num) prog->firstfreeknownstring = min(prog->firstfreeknownstring, num); } else - prog->error_cmd("PRVM_FreeString: invalid string offset %i", num); + prog->error_cmd("PRVM_FreeString %s: invalid string offset %i", prog->name, num); } static qbool PRVM_IsStringReferenced(prvm_prog_t *prog, string_t string)