2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-17 17:17:56 +03:00

Merge pull request #181 from WPMGPRoSToTeMa/autoprecachemapstxtoverviewsandskys

Added auto precaching of detail textures if present
This commit is contained in:
theAsmodai 2016-03-06 23:51:58 +03:00
commit 8196956dab
2 changed files with 36 additions and 22 deletions

View File

@ -5086,34 +5086,40 @@ void PrecacheMapSpecifiedResources()
if (FS_FileExists(va("maps/%s.txt", g_psv.name))) if (FS_FileExists(va("maps/%s.txt", g_psv.name)))
PF_precache_generic_I(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? char *detailTextureInfoFileName = va("maps/%s_detail.txt", g_psv.name);
if (FS_FileExists(va("maps/%s_detail.txt", g_psv.name))) if (FS_FileExists(detailTextureInfoFileName))
PF_precache_generic_I(va("maps/%s_detail.txt", g_psv.name));
if (wadpath != nullptr)
{ {
char tempPath[1024]; PF_precache_generic_I(detailTextureInfoFileName);
Q_strncpy(tempPath, wadpath, sizeof(tempPath) - 2);
tempPath[sizeof(tempPath) - 2] = 0;
if (!Q_strchr(tempPath, ';'))
Q_strcat(tempPath, ";");
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]; // Get texture name
COM_FileBase(token, wadName); pos = COM_Parse(pos);
COM_DefaultExtension(wadName, ".wad");
if (!FS_FileExists(wadName) if (com_token[0] == '\0')
|| !Q_stricmp(wadName, "pldecal.wad") break;
|| !Q_stricmp(wadName, "tempdecal.wad")
|| !Q_stricmp(wadName, "halflife.wad")
|| !Q_stricmp(wadName, "xeno.wad")
|| !Q_stricmp(wadName, "decals.wad"))
continue;
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 #endif // REHLDS_FIXES

View File

@ -118,6 +118,14 @@ qboolean TEX_InitFromWad(char *path)
if (Q_strstr(wadName, "pldecal") || Q_strstr(wadName, "tempdecal")) if (Q_strstr(wadName, "pldecal") || Q_strstr(wadName, "tempdecal"))
continue; 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"); texfile = FS_Open(wadPath, "rb");
texfiles[nTexFiles++] = texfile; texfiles[nTexFiles++] = texfile;
if (!texfile) if (!texfile)