mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-04 02:55:50 +03:00
Fix for:
- correctly using types with define - missing EXT_FUNC for SV_GetChallenge
This commit is contained in:
parent
3be05fce38
commit
24eb2d0ccd
@ -193,7 +193,7 @@ typedef struct client_state_s
|
||||
int max_edicts;
|
||||
resource_t resourcesonhand;
|
||||
resource_t resourcesneeded;
|
||||
resource_t resourcelist[1280];
|
||||
resource_t resourcelist[MAX_RESOURCE_LIST];
|
||||
int num_resources;
|
||||
qboolean need_force_consistency_response;
|
||||
char serverinfo[512];
|
||||
@ -236,7 +236,7 @@ typedef struct client_state_s
|
||||
model_t *model_precache[HL_MODEL_MAX];
|
||||
int model_precache_count;
|
||||
sfx_s *sound_precache[HL_SOUND_MAX];
|
||||
consistency_t consistency_list[512];
|
||||
consistency_t consistency_list[MAX_CONSISTENCY_LIST];
|
||||
int num_consistency;
|
||||
int highentity;
|
||||
char levelname[40];
|
||||
|
@ -90,31 +90,31 @@ qboolean COM_CreateCustomization(customization_t *pListHead, resource_t *pResour
|
||||
customization_t *pCust; // 91
|
||||
qboolean bError; // 92
|
||||
|
||||
bError = 0;
|
||||
bError = FALSE;
|
||||
if (pCustomization)
|
||||
*pCustomization = 0;
|
||||
*pCustomization = NULL;
|
||||
pCust = (customization_t *)Mem_ZeroMalloc(sizeof(customization_t));
|
||||
|
||||
Q_memcpy(&pCust->resource, pResource, sizeof(pCust->resource));
|
||||
if (pResource->nDownloadSize <= 0)
|
||||
{
|
||||
bError = 1;
|
||||
bError = TRUE;
|
||||
goto CustomizationError;
|
||||
}
|
||||
|
||||
pCust->bInUse = 1;
|
||||
pCust->bInUse = TRUE;
|
||||
|
||||
if (flags & 1)
|
||||
if (flags & FCUST_FROMHPAK)
|
||||
{
|
||||
if (!HPAK_GetDataPointer("custom.hpk", pResource, (uint8**)&pCust->pBuffer, 0))
|
||||
if (!HPAK_GetDataPointer("custom.hpk", pResource, (uint8**)&pCust->pBuffer, NULL))
|
||||
{
|
||||
bError = 1;
|
||||
bError = TRUE;
|
||||
goto CustomizationError;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
pCust->pBuffer = COM_LoadFile(pResource->szFileName, 5, 0);
|
||||
pCust->pBuffer = COM_LoadFile(pResource->szFileName, 5, NULL);
|
||||
}
|
||||
|
||||
if ((pCust->resource.ucFlags & RES_CUSTOM) && pCust->resource.type == t_decal)
|
||||
@ -122,13 +122,13 @@ qboolean COM_CreateCustomization(customization_t *pListHead, resource_t *pResour
|
||||
pCust->resource.playernum = playernumber;
|
||||
if (!CustomDecal_Validate(pCust->pBuffer, pResource->nDownloadSize))
|
||||
{
|
||||
bError = 1;
|
||||
bError = TRUE;
|
||||
goto CustomizationError;
|
||||
}
|
||||
|
||||
if (!(flags & 4))
|
||||
if (!(flags & RES_CUSTOM))
|
||||
{
|
||||
cachewad_t * pWad = (cachewad_t *)Mem_ZeroMalloc(0x2Cu);
|
||||
cachewad_t * pWad = (cachewad_t *)Mem_ZeroMalloc(sizeof(cachewad_t));
|
||||
pCust->pInfo = pWad;
|
||||
if (pResource->nDownloadSize >= 1024 && pResource->nDownloadSize <= 20480)
|
||||
{
|
||||
@ -141,16 +141,16 @@ qboolean COM_CreateCustomization(customization_t *pListHead, resource_t *pResour
|
||||
if (nLumps)
|
||||
*nLumps = pWad->lumpCount;
|
||||
|
||||
pCust->bTranslated = 1;
|
||||
pCust->bTranslated = TRUE;
|
||||
pCust->nUserData1 = 0;
|
||||
pCust->nUserData2 = pWad->lumpCount;
|
||||
if (flags & 2)
|
||||
if (flags & FCUST_WIPEDATA)
|
||||
{
|
||||
Mem_Free(pWad->name);
|
||||
Mem_Free(pWad->cache);
|
||||
Mem_Free(pWad->lumps);
|
||||
Mem_Free(pCust->pInfo);
|
||||
pCust->pInfo = 0;
|
||||
pCust->pInfo = NULL;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -173,7 +173,7 @@ CustomizationError:
|
||||
pCust->pNext = pListHead->pNext;
|
||||
pListHead->pNext = pCust;
|
||||
}
|
||||
return bError == 0;
|
||||
return bError == FALSE;
|
||||
}
|
||||
|
||||
/* <9b41> ../engine/com_custom.c:229 */
|
||||
|
@ -40,6 +40,8 @@
|
||||
#define MAX_NAME 32
|
||||
#define MAX_LIGHTSTYLES 64
|
||||
#define MAX_PACKET_ENTITIES 256
|
||||
#define MAX_RESOURCE_LIST 1280
|
||||
#define MAX_CONSISTENCY_LIST 512
|
||||
#ifdef REHLDS_OPT_PEDANTIC
|
||||
#define MAX_CHALLENGES 64
|
||||
#else
|
||||
@ -129,9 +131,9 @@ typedef struct server_s
|
||||
struct model_s *worldmodel;
|
||||
CRC32_t worldmapCRC;
|
||||
unsigned char clientdllmd5[16];
|
||||
resource_t resourcelist[1280];
|
||||
resource_t resourcelist[MAX_RESOURCE_LIST];
|
||||
int num_resources;
|
||||
consistency_t consistency_list[512];
|
||||
consistency_t consistency_list[MAX_CONSISTENCY_LIST];
|
||||
int num_consistency;
|
||||
const char *model_precache[HL_MODEL_MAX];
|
||||
struct model_s *models[HL_MODEL_MAX];
|
||||
|
@ -1676,7 +1676,7 @@ void SV_Spawn_f(void)
|
||||
SZ_Write(&msg, g_psv.signon.data, g_psv.signon.cursize);
|
||||
SV_WriteSpawn(&msg);
|
||||
SV_WriteVoiceCodec(&msg);
|
||||
Netchan_CreateFragments(1, &host_client->netchan, &msg);
|
||||
Netchan_CreateFragments(TRUE, &host_client->netchan, &msg);
|
||||
Netchan_FragSend(&host_client->netchan);
|
||||
}
|
||||
else
|
||||
@ -2408,7 +2408,7 @@ void EXT_FUNC SV_ConnectClient_internal(void)
|
||||
SV_ExtractFromUserinfo(host_client);
|
||||
Info_SetValueForStarKey(host_client->userinfo, "*sid", va("%lld", host_client->network_userid.m_SteamID), MAX_INFO_STRING);
|
||||
|
||||
host_client->datagram.flags = 1;
|
||||
host_client->datagram.flags = SIZEBUF_ALLOW_OVERFLOW;
|
||||
host_client->datagram.data = (byte *)host_client->datagram_buf;
|
||||
host_client->datagram.maxsize = sizeof(host_client->datagram_buf);
|
||||
host_client->datagram.buffername = host_client->name;
|
||||
@ -2427,7 +2427,7 @@ void SVC_Ping(void)
|
||||
NET_SendPacket(NS_SERVER, sizeof(data), data, net_from);
|
||||
}
|
||||
|
||||
int SV_GetChallenge(const netadr_t& adr)
|
||||
int EXT_FUNC SV_GetChallenge(const netadr_t& adr)
|
||||
{
|
||||
int i;
|
||||
#ifndef REHLDS_OPT_PEDANTIC
|
||||
@ -3262,7 +3262,7 @@ void SV_AddFailedRcon(netadr_t *adr)
|
||||
/* <a61f6> ../engine/sv_main.c:4364 */
|
||||
qboolean SV_CheckRconFailure(netadr_t *adr)
|
||||
{
|
||||
for (int i = 0; i < 32; i++)
|
||||
for (int i = 0; i < MAX_RCON_FAILURES_STORAGE; i++)
|
||||
{
|
||||
rcon_failure_t *r = &g_rgRconFailures[i];
|
||||
if (NET_CompareAdr(*adr, r->adr))
|
||||
@ -3495,7 +3495,7 @@ void SV_ProcessFile(client_t *cl, char *filename)
|
||||
pList = pList->pNext;
|
||||
}
|
||||
|
||||
if (!COM_CreateCustomization(&cl->customdata, resource, -1, 7, NULL, NULL))
|
||||
if (!COM_CreateCustomization(&cl->customdata, resource, -1, (FCUST_FROMHPAK | FCUST_WIPEDATA | RES_CUSTOM), NULL, NULL))
|
||||
Con_Printf("Error parsing custom decal from %s\n", cl->name);
|
||||
}
|
||||
|
||||
@ -4235,7 +4235,7 @@ int SV_CreatePacketEntities(sv_delta_t type, client_t *client, packet_entities_t
|
||||
FALSE,
|
||||
custom,
|
||||
&numbase,
|
||||
from == 0,
|
||||
from == NULL,
|
||||
0);
|
||||
|
||||
entity_state_t *baseline_ = &g_psv.baselines[newindex];
|
||||
@ -4259,7 +4259,7 @@ int SV_CreatePacketEntities(sv_delta_t type, client_t *client, packet_entities_t
|
||||
_mm_prefetch((const char*)baseline_, _MM_HINT_T0);
|
||||
_mm_prefetch(((const char*)baseline_) + 64, _MM_HINT_T0);
|
||||
if (offset)
|
||||
SV_SetCallback(newindex, 0, custom, &numbase, 1, offset);
|
||||
SV_SetCallback(newindex, FALSE, custom, &numbase, TRUE, offset);
|
||||
|
||||
// fix for https://github.com/dreamstalker/rehlds/issues/24
|
||||
#ifdef REHLDS_FIXES
|
||||
@ -4323,16 +4323,16 @@ qboolean SV_ShouldUpdatePing(client_t *client)
|
||||
if (client->proxy)
|
||||
{
|
||||
if (realtime < client->nextping)
|
||||
return 0;
|
||||
return FALSE;
|
||||
|
||||
client->nextping = realtime + 2.0;
|
||||
return 1;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
//useless call
|
||||
//SV_CalcPing(client);
|
||||
|
||||
return client->lastcmd.buttons & 0x8000;
|
||||
return client->lastcmd.buttons & IN_SCORE;
|
||||
}
|
||||
|
||||
/* <a9109> ../engine/sv_main.c:5734 */
|
||||
@ -4441,7 +4441,6 @@ void SV_EmitPings(client_t *client, sizebuf_t *msg)
|
||||
/* <a947b> ../engine/sv_main.c:5878 */
|
||||
void SV_WriteEntitiesToClient(client_t *client, sizebuf_t *msg)
|
||||
{
|
||||
|
||||
client_frame_t *frame = &client->frames[SV_UPDATE_MASK & client->netchan.outgoing_sequence];
|
||||
|
||||
unsigned char *pvs = NULL;
|
||||
@ -4919,7 +4918,7 @@ int SV_ModelIndex(const char *name)
|
||||
void SV_AddResource(resourcetype_t type, const char *name, int size, unsigned char flags, int index)
|
||||
{
|
||||
resource_t *r;
|
||||
if (g_psv.num_resources >= 1280)
|
||||
if (g_psv.num_resources >= MAX_RESOURCE_LIST)
|
||||
Sys_Error("Too many resources on server.");
|
||||
|
||||
r = &g_psv.resourcelist[g_psv.num_resources++];
|
||||
@ -5010,7 +5009,7 @@ void SV_CreateResourceList(void)
|
||||
else
|
||||
nSize = 0;
|
||||
|
||||
SV_AddResource(t_generic, *s, nSize, 1, i);
|
||||
SV_AddResource(t_generic, *s, nSize, RES_FATALIFMISSING, i);
|
||||
}
|
||||
#ifdef REHLDS_CHECKS
|
||||
for (i = 1, s = &g_psv.sound_precache[1]; i < HL_SOUND_MAX && *s != NULL; i++, s++)
|
||||
@ -5023,7 +5022,7 @@ void SV_CreateResourceList(void)
|
||||
if (!ffirstsent)
|
||||
{
|
||||
ffirstsent = 1;
|
||||
SV_AddResource(t_sound, "!", 0, 1, i);
|
||||
SV_AddResource(t_sound, "!", 0, RES_FATALIFMISSING, i);
|
||||
}
|
||||
}
|
||||
else
|
||||
@ -5056,7 +5055,7 @@ void SV_CreateResourceList(void)
|
||||
if (!ep->filename)
|
||||
break;
|
||||
|
||||
SV_AddResource(t_eventscript, (char *)ep->filename, ep->filesize, 1, i);
|
||||
SV_AddResource(t_eventscript, (char *)ep->filename, ep->filesize, RES_FATALIFMISSING, i);
|
||||
}
|
||||
}
|
||||
|
||||
@ -5109,7 +5108,7 @@ void SV_PropagateCustomizations(void)
|
||||
MSG_WriteByte(&host_client->netchan.message, pResource->ucFlags);
|
||||
if (pResource->ucFlags & RES_CUSTOM)
|
||||
{
|
||||
SZ_Write(&host_client->netchan.message, pResource->rgucMD5_hash, 16);
|
||||
SZ_Write(&host_client->netchan.message, pResource->rgucMD5_hash, sizeof(pResource->rgucMD5_hash));
|
||||
}
|
||||
}
|
||||
|
||||
@ -5181,10 +5180,12 @@ void SV_CreateBaseline(void)
|
||||
{
|
||||
player = SV_IsPlayerIndex(entnum);
|
||||
g_psv.baselines[entnum].number = entnum;
|
||||
g_psv.baselines[entnum].entityType = 1;
|
||||
|
||||
// set entity type
|
||||
if (svent->v.flags & FL_CUSTOMENTITY)
|
||||
g_psv.baselines[entnum].entityType = 2;
|
||||
g_psv.baselines[entnum].entityType = ENTITY_BEAM;
|
||||
else
|
||||
g_psv.baselines[entnum].entityType = ENTITY_NORMAL;
|
||||
|
||||
__invokeValvesBuggedCreateBaseline((void *)gEntityInterface.pfnCreateBaseline, player, entnum, &(g_psv.baselines[entnum]), svent, sv_playermodel, player_mins[0], player_maxs[0]);
|
||||
sv_lastnum = entnum;
|
||||
@ -5201,7 +5202,7 @@ void SV_CreateBaseline(void)
|
||||
{
|
||||
MSG_WriteBits(entnum, 11);
|
||||
MSG_WriteBits(g_psv.baselines[entnum].entityType, 2);
|
||||
custom = ~g_psv.baselines[entnum].entityType & 1;
|
||||
custom = ~g_psv.baselines[entnum].entityType & ENTITY_NORMAL;
|
||||
if (custom)
|
||||
pDelta = g_pcustomentitydelta;
|
||||
else
|
||||
@ -5790,12 +5791,12 @@ USERID_t *SV_StringToUserID(const char *str)
|
||||
if (Q_strnicmp(str, "STEAM_", 6))
|
||||
{
|
||||
Q_strncpy(szTemp, pszUserID, sizeof(szTemp) - 1);
|
||||
id.idtype = 2;
|
||||
id.idtype = AUTH_IDTYPE_VALVE;
|
||||
}
|
||||
else
|
||||
{
|
||||
Q_strncpy(szTemp, pszUserID, sizeof(szTemp) - 1);
|
||||
id.idtype = 1;
|
||||
id.idtype = AUTH_IDTYPE_STEAM;
|
||||
}
|
||||
szTemp[127] = 0;
|
||||
id.m_SteamID = Steam_StringToSteamID(szTemp);
|
||||
@ -6126,7 +6127,7 @@ void Host_Kick_f(void)
|
||||
|
||||
SV_ClientPrintf("Kicked by %s\n", who);
|
||||
Log_Printf("Kick: \"%s<%i><%s><>\" was kicked by \"%s\"\n", host_client->name, host_client->userid, SV_GetClientIDString(host_client), who);
|
||||
SV_DropClient(host_client, 0, "Kicked");
|
||||
SV_DropClient(host_client, FALSE, "Kicked");
|
||||
}
|
||||
host_client = save;
|
||||
}
|
||||
@ -6143,7 +6144,8 @@ void SV_RemoveId_f(void)
|
||||
}
|
||||
|
||||
Q_strncpy(idstring, Cmd_Argv(1), sizeof(idstring) - 1);
|
||||
idstring[63] = 0;
|
||||
idstring[sizeof(idstring) - 1] = 0;
|
||||
|
||||
if (!idstring[0])
|
||||
{
|
||||
Con_Printf(__FUNCTION__ ": Id string is empty!\n");
|
||||
@ -6173,8 +6175,10 @@ void SV_RemoveId_f(void)
|
||||
{
|
||||
if (!Q_strnicmp(idstring, "STEAM_", 6) || !Q_strnicmp(idstring, "VALVE_", 6))
|
||||
{
|
||||
Q_snprintf(idstring, 0x3Fu, "%s:%s:%s", Cmd_Argv(1), Cmd_Argv(3), Cmd_Argv(5));
|
||||
Q_snprintf(idstring, sizeof(idstring) - 1, "%s:%s:%s", Cmd_Argv(1), Cmd_Argv(3), Cmd_Argv(5));
|
||||
#ifndef REHLDS_FIXES
|
||||
idstring[63] = 0;
|
||||
#endif // REHLDS_FIXES
|
||||
}
|
||||
|
||||
for (int i = 0; i < numuserfilters; i++)
|
||||
@ -6605,7 +6609,7 @@ void SV_BeginFileDownload_f(void)
|
||||
#ifdef REHLDS_FIXES
|
||||
if (pbuf && size)
|
||||
{
|
||||
Netchan_CreateFileFragmentsFromBuffer(1, &host_client->netchan, name, pbuf, size);
|
||||
Netchan_CreateFileFragmentsFromBuffer(TRUE, &host_client->netchan, name, pbuf, size);
|
||||
Netchan_FragSend(&host_client->netchan);
|
||||
}
|
||||
// Mem_Free pbuf even if size is zero
|
||||
@ -6616,7 +6620,7 @@ void SV_BeginFileDownload_f(void)
|
||||
#else // REHLDS_FIXES
|
||||
if (pbuf && size)
|
||||
{
|
||||
Netchan_CreateFileFragmentsFromBuffer(1, &host_client->netchan, name, pbuf, size);
|
||||
Netchan_CreateFileFragmentsFromBuffer(TRUE, &host_client->netchan, name, pbuf, size);
|
||||
Netchan_FragSend(&host_client->netchan);
|
||||
Mem_Free((void *)pbuf);
|
||||
}
|
||||
|
@ -211,7 +211,7 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
|
||||
{
|
||||
msg_badread = 1;
|
||||
Con_Printf("SV_ParseConsistencyResponse: %s:%s sent bad file data\n", host_client->name, NET_AdrToString(host_client->netchan.remote_address));
|
||||
SV_DropClient(host_client, 0, "Bad file data");
|
||||
SV_DropClient(host_client, FALSE, "Bad file data");
|
||||
return;
|
||||
}
|
||||
|
||||
@ -226,7 +226,7 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
|
||||
if (dropmessage[0])
|
||||
SV_ClientPrintf("%s", dropmessage);
|
||||
|
||||
SV_DropClient(host_client, 0, "Bad file %s", g_psv.resourcelist[c - 1].szFileName); // only filename. reason was printed in console if exists.
|
||||
SV_DropClient(host_client, FALSE, "Bad file %s", g_psv.resourcelist[c - 1].szFileName); // only filename. reason was printed in console if exists.
|
||||
}
|
||||
#else // REHLDS_FIXES
|
||||
if (gEntityInterface.pfnInconsistentFile(host_client->edict, g_psv.resourcelist[c - 1].szFileName, dropmessage))
|
||||
@ -234,7 +234,7 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
|
||||
if (Q_strlen(dropmessage) > 0)
|
||||
SV_ClientPrintf("%s", dropmessage);
|
||||
|
||||
SV_DropClient(host_client, 0, "Bad file %s", dropmessage);
|
||||
SV_DropClient(host_client, FALSE, "Bad file %s", dropmessage);
|
||||
}
|
||||
#endif // REHLDS_FIXES
|
||||
|
||||
@ -1515,7 +1515,7 @@ void SV_ParseMove(client_t *pSenderClient)
|
||||
if (totalcmds < 0 || totalcmds >= 63)
|
||||
{
|
||||
Con_Printf("SV_ReadClientMessage: too many cmds %i sent for %s/%s\n", totalcmds, host_client->name, NET_AdrToString(host_client->netchan.remote_address));
|
||||
SV_DropClient(host_client, 0, "CMD_MAXBACKUP hit");
|
||||
SV_DropClient(host_client, FALSE, "CMD_MAXBACKUP hit");
|
||||
msg_badread = 1;
|
||||
return;
|
||||
}
|
||||
@ -1630,7 +1630,7 @@ void SV_ParseVoiceData(client_t *cl)
|
||||
if (nDataLength > sizeof(chReceived))
|
||||
{
|
||||
Con_DPrintf("SV_ParseVoiceData: invalid incoming packet.\n");
|
||||
SV_DropClient(cl, 0, "Invalid voice data\n");
|
||||
SV_DropClient(cl, FALSE, "Invalid voice data\n");
|
||||
return;
|
||||
}
|
||||
|
||||
@ -1701,7 +1701,7 @@ void EXT_FUNC SV_HandleClientMessage_api(IGameClient* client, int8 opcode) {
|
||||
if (opcode < clc_bad || opcode > clc_cvarvalue2)
|
||||
{
|
||||
Con_Printf("SV_ReadClientMessage: unknown command char (%d)\n", opcode);
|
||||
SV_DropClient(cl, 0, "Bad command character in client command");
|
||||
SV_DropClient(cl, FALSE, "Bad command character in client command");
|
||||
return;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user