mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-16 08:38:07 +03:00
Bug fixes and other minor improvements
This commit is contained in:
parent
02ef683824
commit
2f599d21b8
@ -439,8 +439,7 @@ void EXT_FUNC ClientPutInServer(edict_t *pEntity)
|
|||||||
pPlayer->pev->flags |= FL_SPECTATOR;
|
pPlayer->pev->flags |= FL_SPECTATOR;
|
||||||
pPlayer->pev->solid = SOLID_NOT;
|
pPlayer->pev->solid = SOLID_NOT;
|
||||||
pPlayer->pev->movetype = MOVETYPE_NOCLIP;
|
pPlayer->pev->movetype = MOVETYPE_NOCLIP;
|
||||||
pPlayer->pev->effects = EF_NODRAW;
|
pPlayer->pev->effects = (EF_NODRAW | EF_NOINTERP);
|
||||||
pPlayer->pev->effects |= EF_NOINTERP;
|
|
||||||
pPlayer->pev->takedamage = DAMAGE_NO;
|
pPlayer->pev->takedamage = DAMAGE_NO;
|
||||||
pPlayer->pev->deadflag = DEAD_DEAD;
|
pPlayer->pev->deadflag = DEAD_DEAD;
|
||||||
pPlayer->pev->velocity = g_vecZero;
|
pPlayer->pev->velocity = g_vecZero;
|
||||||
|
@ -4054,6 +4054,8 @@ void EXT_FUNC CHalfLifeMultiplay::__API_VHOOK(DeathNotice)(CBasePlayer *pVictim,
|
|||||||
GETPLAYERAUTHID(pVictim->edict()), team, killer_weapon_name);
|
GETPLAYERAUTHID(pVictim->edict()), team, killer_weapon_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: It is called in CBasePlayer::Killed too, most likely,
|
||||||
|
// an unnecessary call. (Need investigate)
|
||||||
CheckWinConditions();
|
CheckWinConditions();
|
||||||
|
|
||||||
MESSAGE_BEGIN(MSG_SPEC, SVC_DIRECTOR);
|
MESSAGE_BEGIN(MSG_SPEC, SVC_DIRECTOR);
|
||||||
|
@ -3662,11 +3662,11 @@ void CBasePlayer::PlayerDeathThink()
|
|||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
pev->deadflag = DEAD_RESPAWNABLE;
|
pev->deadflag = DEAD_RESPAWNABLE;
|
||||||
}
|
|
||||||
|
|
||||||
if (CSGameRules()->IsMultiplayer())
|
if (CSGameRules()->IsMultiplayer())
|
||||||
CSGameRules()->CheckWinConditions();
|
CSGameRules()->CheckWinConditions();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pev->nextthink = gpGlobals->time + 0.1f;
|
pev->nextthink = gpGlobals->time + 0.1f;
|
||||||
return;
|
return;
|
||||||
@ -8276,6 +8276,11 @@ void CBasePlayer::SpawnClientSideCorpse()
|
|||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef REGAMEDLL_ADD
|
||||||
|
if (forcerespawn.value > 0.0f)
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
char *infobuffer = GET_INFO_BUFFER(edict());
|
char *infobuffer = GET_INFO_BUFFER(edict());
|
||||||
char *pModel = GET_KEY_VALUE(infobuffer, "model");
|
char *pModel = GET_KEY_VALUE(infobuffer, "model");
|
||||||
|
|
||||||
|
@ -544,7 +544,7 @@ void CTriggerCDAudio::__MAKE_VHOOK(Touch)(CBaseEntity *pOther)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayTrack();
|
PlayTrack(pOther->edict());
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTriggerCDAudio::__MAKE_VHOOK(Spawn)()
|
void CTriggerCDAudio::__MAKE_VHOOK(Spawn)()
|
||||||
@ -554,7 +554,7 @@ void CTriggerCDAudio::__MAKE_VHOOK(Spawn)()
|
|||||||
|
|
||||||
void CTriggerCDAudio::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
|
void CTriggerCDAudio::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
|
||||||
{
|
{
|
||||||
PlayTrack();
|
PlayTrack(pCaller->edict());
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef REGAMEDLL_FIXES
|
#ifdef REGAMEDLL_FIXES
|
||||||
@ -591,11 +591,8 @@ const char *g_szMP3trackFileMap[] =
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void PlayCDTrack(int iTrack)
|
void PlayCDTrack(edict_t *pClient, int iTrack)
|
||||||
{
|
{
|
||||||
// manually find the single player.
|
|
||||||
edict_t *pClient = INDEXENT(1);
|
|
||||||
|
|
||||||
// Can't play if the client is not connected!
|
// Can't play if the client is not connected!
|
||||||
if (!pClient)
|
if (!pClient)
|
||||||
return;
|
return;
|
||||||
@ -627,9 +624,9 @@ void PlayCDTrack(int iTrack)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// only plays for ONE client, so only use in single play!
|
// only plays for ONE client, so only use in single play!
|
||||||
void CTriggerCDAudio::PlayTrack()
|
void CTriggerCDAudio::PlayTrack(edict_t *pEdict)
|
||||||
{
|
{
|
||||||
PlayCDTrack(int(pev->health));
|
PlayCDTrack(pEdict, int(pev->health));
|
||||||
|
|
||||||
SetTouch(NULL);
|
SetTouch(NULL);
|
||||||
UTIL_Remove(this);
|
UTIL_Remove(this);
|
||||||
@ -661,7 +658,7 @@ void CTargetCDAudio::__MAKE_VHOOK(Spawn)()
|
|||||||
|
|
||||||
void CTargetCDAudio::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
|
void CTargetCDAudio::__MAKE_VHOOK(Use)(CBaseEntity *pActivator, CBaseEntity *pCaller, USE_TYPE useType, float value)
|
||||||
{
|
{
|
||||||
Play();
|
Play(pCaller->edict());
|
||||||
}
|
}
|
||||||
|
|
||||||
// only plays for ONE client, so only use in single play!
|
// only plays for ONE client, so only use in single play!
|
||||||
@ -678,13 +675,13 @@ void CTargetCDAudio::__MAKE_VHOOK(Think)()
|
|||||||
|
|
||||||
if ((pClient->v.origin - pev->origin).Length() <= pev->scale)
|
if ((pClient->v.origin - pev->origin).Length() <= pev->scale)
|
||||||
{
|
{
|
||||||
Play();
|
Play(pClient);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CTargetCDAudio::Play()
|
void CTargetCDAudio::Play(edict_t *pEdict)
|
||||||
{
|
{
|
||||||
PlayCDTrack(int(pev->health));
|
PlayCDTrack(pEdict, int(pev->health));
|
||||||
UTIL_Remove(this);
|
UTIL_Remove(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -323,7 +323,7 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void PlayTrack();
|
void PlayTrack(edict_t *pEdict);
|
||||||
};
|
};
|
||||||
|
|
||||||
// This plays a CD track when fired or when the player enters it's radius
|
// This plays a CD track when fired or when the player enters it's radius
|
||||||
@ -345,7 +345,7 @@ public:
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void Play();
|
void Play(edict_t *pEdict);
|
||||||
};
|
};
|
||||||
|
|
||||||
// QUAKED trigger_multiple (.5 .5 .5) ? notouch
|
// QUAKED trigger_multiple (.5 .5 .5) ? notouch
|
||||||
@ -761,7 +761,7 @@ public:
|
|||||||
float m_fDensity;
|
float m_fDensity;
|
||||||
};
|
};
|
||||||
|
|
||||||
void PlayCDTrack(int iTrack);
|
void PlayCDTrack(edict_t *pClient, int iTrack);
|
||||||
int BuildChangeList(LEVELLIST *pLevelList, int maxList);
|
int BuildChangeList(LEVELLIST *pLevelList, int maxList);
|
||||||
void NextLevel();
|
void NextLevel();
|
||||||
|
|
||||||
|
@ -90,8 +90,7 @@ bool EXT_FUNC CCSPlayer::JoinTeam(TeamName team)
|
|||||||
|
|
||||||
pPlayer->pev->solid = SOLID_NOT;
|
pPlayer->pev->solid = SOLID_NOT;
|
||||||
pPlayer->pev->movetype = MOVETYPE_NOCLIP;
|
pPlayer->pev->movetype = MOVETYPE_NOCLIP;
|
||||||
pPlayer->pev->effects = EF_NODRAW;
|
pPlayer->pev->effects = (EF_NODRAW | EF_NOINTERP);
|
||||||
pPlayer->pev->effects |= EF_NOINTERP;
|
|
||||||
pPlayer->pev->takedamage = DAMAGE_NO;
|
pPlayer->pev->takedamage = DAMAGE_NO;
|
||||||
pPlayer->pev->deadflag = DEAD_DEAD;
|
pPlayer->pev->deadflag = DEAD_DEAD;
|
||||||
pPlayer->pev->velocity = g_vecZero;
|
pPlayer->pev->velocity = g_vecZero;
|
||||||
@ -102,6 +101,13 @@ bool EXT_FUNC CCSPlayer::JoinTeam(TeamName team)
|
|||||||
pPlayer->m_fDeadTime = 0;
|
pPlayer->m_fDeadTime = 0;
|
||||||
pPlayer->has_disconnected = false;
|
pPlayer->has_disconnected = false;
|
||||||
|
|
||||||
|
if (pPlayer->m_bJustConnected) {
|
||||||
|
pPlayer->m_iObserverLastMode = OBS_ROAMING;
|
||||||
|
pPlayer->m_iObserverC4State = 0;
|
||||||
|
pPlayer->m_bObserverHasDefuser = false;
|
||||||
|
pPlayer->SetObserverAutoDirector(false);
|
||||||
|
}
|
||||||
|
|
||||||
pPlayer->m_iJoiningState = GETINTOGAME;
|
pPlayer->m_iJoiningState = GETINTOGAME;
|
||||||
pPlayer->SendItemStatus();
|
pPlayer->SendItemStatus();
|
||||||
|
|
||||||
@ -131,7 +137,6 @@ bool EXT_FUNC CCSPlayer::JoinTeam(TeamName team)
|
|||||||
pPlayer->m_iTeam = team;
|
pPlayer->m_iTeam = team;
|
||||||
pPlayer->TeamChangeUpdate();
|
pPlayer->TeamChangeUpdate();
|
||||||
|
|
||||||
CSGameRules()->CheckWinConditions();
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user