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

Some fixes for sv_upld.cpp (#225)

Hide unneeded checks under REHLDS_FIXES macro.
Use SV_ClearResourceLists() function instead of two SV_ClearResourceList().
Use for() on lists, instead of while(). More readable.
Put SV_ClearResourceLists under macro, use empty-braced initializer instead of C-style { 0 }
This commit is contained in:
Alibek Omarov 2016-07-27 00:31:58 +06:00 committed by theAsmodai
parent 8efc228bec
commit 89f64e92fd

View File

@ -33,10 +33,8 @@
// Checks MD5 of the resource against local cache and returns TRUE if resource was found or if downloads are disabled. Otherwise, if resource was requested from the player, it returns FALSE. // Checks MD5 of the resource against local cache and returns TRUE if resource was found or if downloads are disabled. Otherwise, if resource was requested from the player, it returns FALSE.
qboolean SV_CheckFile(sizebuf_t *msg, char *filename) qboolean SV_CheckFile(sizebuf_t *msg, char *filename)
{ {
resource_t p; resource_t p = { };
Q_memset(&p, 0, sizeof(p));
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
// FIXED: First, check for allowed downloads, then try to lookup, this is faster if downloads aren't enabled // FIXED: First, check for allowed downloads, then try to lookup, this is faster if downloads aren't enabled
@ -116,8 +114,7 @@ void SV_CreateCustomizationList(client_t *pHost)
pHost->customdata.pNext = NULL; pHost->customdata.pNext = NULL;
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
pResource = pHost->resourcesonhand.pNext; for( pResource = pHost->resourcesonhand.pNext; pResource != &pHost->resourcesonhand; pResource = pResource->pNext )
while (pResource != &pHost->resourcesonhand)
{ {
// TODO: Check if we need to filter resources here based on type (t_decal) and flags (RES_CUSTOM) // TODO: Check if we need to filter resources here based on type (t_decal) and flags (RES_CUSTOM)
@ -154,8 +151,6 @@ void SV_CreateCustomizationList(client_t *pHost)
Con_Printf("Ignoring invalid custom decal from %s\n", pHost->name); Con_Printf("Ignoring invalid custom decal from %s\n", pHost->name);
} }
} }
pResource = pResource->pNext;
} }
} }
@ -259,19 +254,15 @@ void SV_ClearResourceList(resource_t *pList)
{ {
resource_t *p, *n; resource_t *p, *n;
p = pList->pNext; for( p = pList->pNext; p && p != pList; p = n )
while (p != NULL)
{ {
if (p == pList)
break;
n = p->pNext; n = p->pNext;
SV_RemoveFromResourceList(p); SV_RemoveFromResourceList(p);
Mem_Free(p); Mem_Free(p);
p = n;
} }
pList->pPrev = pList; pList->pPrev = pList;
pList->pNext = pList; pList->pNext = pList;
} }
@ -362,8 +353,7 @@ void SV_BatchUploadRequest(client_t *cl)
resource_t *p, *n; resource_t *p, *n;
char filename[MAX_PATH]; char filename[MAX_PATH];
p = cl->resourcesneeded.pNext; for( p = cl->resourcesneeded.pNext; p != &cl->resourcesneeded; p = n )
while (p != &cl->resourcesneeded)
{ {
n = p->pNext; n = p->pNext;
@ -387,8 +377,6 @@ void SV_BatchUploadRequest(client_t *cl)
SV_MoveToOnHandList(p); SV_MoveToOnHandList(p);
} }
} }
p = n;
} }
} }
@ -413,8 +401,12 @@ void SV_ParseResourceList(client_t *pSenderClient)
total = MSG_ReadShort(); total = MSG_ReadShort();
SV_ClearResourceList(&host_client->resourcesneeded); #ifdef REHLDS_FIXES
SV_ClearResourceList(&host_client->resourcesonhand); SV_ClearResourceLists( host_client );
#else // REHLDS_FIXES
SV_ClearResourceList( &host_client->resourcesneeded );
SV_ClearResourceList( &host_client->resourcesonhand );
#endif // REHLDS_FIXES
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
if (total > 1) // client uses only one custom resource (spray decal) if (total > 1) // client uses only one custom resource (spray decal)
@ -449,8 +441,12 @@ void SV_ParseResourceList(client_t *pSenderClient)
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
resource->nDownloadSize > 1024 * 1024 * 1024) // FIXME: Are they gone crazy??! resource->nDownloadSize > 1024 * 1024 * 1024) // FIXME: Are they gone crazy??!
{ {
SV_ClearResourceList(&host_client->resourcesneeded); #ifdef REHLDS_FIXES
SV_ClearResourceList(&host_client->resourcesonhand); SV_ClearResourceLists( host_client );
#else // REHLDS_FIXES
SV_ClearResourceList( &host_client->resourcesneeded );
SV_ClearResourceList( &host_client->resourcesonhand );
#endif // REHLDS_FIXES
return; return;
} }
@ -470,6 +466,7 @@ void SV_ParseResourceList(client_t *pSenderClient)
#endif // REHLDS_FIXES #endif // REHLDS_FIXES
{ {
Con_DPrintf("Custom resources total %.2fK\n", total / 1024.0f); Con_DPrintf("Custom resources total %.2fK\n", total / 1024.0f);
#ifndef REHLDS_FIXES // because client can send only decals, why there is need to check other types?
if (ri.info[t_model].size) if (ri.info[t_model].size)
{ {
total = ri.info[t_model].size; total = ri.info[t_model].size;
@ -480,10 +477,13 @@ void SV_ParseResourceList(client_t *pSenderClient)
total = ri.info[t_sound].size; total = ri.info[t_sound].size;
Con_DPrintf(" Sounds: %.2fK\n", total / 1024.0f); Con_DPrintf(" Sounds: %.2fK\n", total / 1024.0f);
} }
if (ri.info[t_decal].size) if (ri.info[t_decal].size)
{ {
#endif // REHLDS_FIXES
// this check is useless, because presence of decals was checked before.
total = ri.info[t_decal].size; total = ri.info[t_decal].size;
Con_DPrintf(" Decals: %.2fK\n", total / 1024.0f); Con_DPrintf(" Decals: %.2fK\n", total / 1024.0f);
#ifndef REHLDS_FIXES
} }
if (ri.info[t_skin].size) if (ri.info[t_skin].size)
{ {
@ -500,14 +500,19 @@ void SV_ParseResourceList(client_t *pSenderClient)
total = ri.info[t_eventscript].size; total = ri.info[t_eventscript].size;
Con_DPrintf(" Events : %.2fK\n", total / 1024.0f); Con_DPrintf(" Events : %.2fK\n", total / 1024.0f);
} }
#endif // REHLDS_FIXES
Con_DPrintf("----------------------\n"); Con_DPrintf("----------------------\n");
int bytestodownload = SV_EstimateNeededResources(); int bytestodownload = SV_EstimateNeededResources();
if (bytestodownload > sv_max_upload.value * 1024 * 1024) if (bytestodownload > sv_max_upload.value * 1024 * 1024)
{ {
SV_ClearResourceList(&host_client->resourcesneeded); #ifdef REHLDS_FIXES
SV_ClearResourceList(&host_client->resourcesonhand); SV_ClearResourceLists( host_client );
#else // REHLDS_FIXES
SV_ClearResourceList( &host_client->resourcesneeded );
SV_ClearResourceList( &host_client->resourcesonhand );
#endif //REHLDS_FIXES
return; return;
} }