From 4cd651d8659add3cd74e00dfcca40b6eccff558a Mon Sep 17 00:00:00 2001 From: WPMGPRoSToTeMa Date: Sat, 27 Feb 2016 01:23:35 +0300 Subject: [PATCH] Added auto precaching detail textures if present Moved auto WAD precaching to TEX_InitFromWad --- rehlds/engine/sv_main.cpp | 50 +++++++++++++++++++++----------------- rehlds/engine/textures.cpp | 8 ++++++ 2 files changed, 36 insertions(+), 22 deletions(-) diff --git a/rehlds/engine/sv_main.cpp b/rehlds/engine/sv_main.cpp index 95f9937..6ebe8e8 100644 --- a/rehlds/engine/sv_main.cpp +++ b/rehlds/engine/sv_main.cpp @@ -5086,34 +5086,40 @@ void PrecacheMapSpecifiedResources() if (FS_FileExists(va("maps/%s.txt", g_psv.name))) PF_precache_generic_I(va("maps/%s.txt", g_psv.name)); - // TODO: or this is not-engine and this better do by gamedll or .res? - if (FS_FileExists(va("maps/%s_detail.txt", g_psv.name))) - PF_precache_generic_I(va("maps/%s_detail.txt", g_psv.name)); - - if (wadpath != nullptr) + char *detailTextureInfoFileName = va("maps/%s_detail.txt", g_psv.name); + if (FS_FileExists(detailTextureInfoFileName)) { - char tempPath[1024]; - Q_strncpy(tempPath, wadpath, sizeof(tempPath) - 2); - tempPath[sizeof(tempPath) - 2] = 0; - if (!Q_strchr(tempPath, ';')) - Q_strcat(tempPath, ";"); + PF_precache_generic_I(detailTextureInfoFileName); - for (char *token = strtok(tempPath, ";"); token != nullptr; token = strtok(nullptr, ";")) + char *buffer = (char *)COM_LoadFileForMe(detailTextureInfoFileName, nullptr); + char *pos = buffer; + while (true) { - char wadName[MAX_QPATH]; - COM_FileBase(token, wadName); - COM_DefaultExtension(wadName, ".wad"); + // Get texture name + pos = COM_Parse(pos); - if (!FS_FileExists(wadName) - || !Q_stricmp(wadName, "pldecal.wad") - || !Q_stricmp(wadName, "tempdecal.wad") - || !Q_stricmp(wadName, "halflife.wad") - || !Q_stricmp(wadName, "xeno.wad") - || !Q_stricmp(wadName, "decals.wad")) - continue; + if (com_token[0] == '\0') + break; - PF_precache_generic_I(wadName); + // Skip '{' in texture name (COM_Parse read one symbol '{' as full token) + if (com_token[0] == '{') + pos = COM_Parse(pos); + + // Get detail texture filename + pos = COM_Parse(pos); + + char *detailTextureFileName = va("gfx/%s.tga", com_token); + if (FS_FileExists(detailTextureFileName)) + PF_precache_generic_I(detailTextureFileName); + else + Con_Printf("WARNING: detail texture '%s' for map '%s' not found!\n", detailTextureFileName, g_psv.name); + + // Skip hscale and vscale + pos = COM_Parse(pos); + pos = COM_Parse(pos); } + + COM_FreeFile(buffer); } } #endif // REHLDS_FIXES diff --git a/rehlds/engine/textures.cpp b/rehlds/engine/textures.cpp index c7f31c9..7f4b740 100644 --- a/rehlds/engine/textures.cpp +++ b/rehlds/engine/textures.cpp @@ -118,6 +118,14 @@ qboolean TEX_InitFromWad(char *path) if (Q_strstr(wadName, "pldecal") || Q_strstr(wadName, "tempdecal")) continue; +#ifdef REHLDS_FIXES + if (g_psv.active + && Q_stricmp(wadPath, "halflife.wad") + && Q_stricmp(wadPath, "xeno.wad") + && Q_stricmp(wadPath, "decals.wad")) + PF_precache_generic_I(wadPath); +#endif // REHLDS_FIXES + texfile = FS_Open(wadPath, "rb"); texfiles[nTexFiles++] = texfile; if (!texfile)