void PlayerState_detach(entity this)
{
- if (!PS(this)) return; // initial connect
- FOREACH_CLIENT(PS(it) == PS(this), { PS(it) = NULL; });
- remove(PS(this));
- this._ps = NULL;
+ PlayerState ps = PS(this);
+ if (!ps) return; // initial connect
+ PS(this) = NULL;
- Inventory_delete(self);
+ if (ps.m_client != this) return; // don't own state, spectator
+
+ FOREACH_CLIENT(PS(it) == ps, { PS(it) = NULL; });
+ delete(ps);
+
+ Inventory_delete(this);
}
-void GetCvars(int);
+void GetCvars(entity this, int);
void DecodeLevelParms(entity this);
void PlayerScore_Attach(entity this);
void ClientData_Attach(entity this);
{
this._cs = NEW(ClientState, this);
- GetCvars(0); // get other cvars from player
-
- // TODO: xonstat elo.txt support, until then just 404s
- if (false && IS_REAL_CLIENT(this)) { PlayerStats_PlayerBasic_CheckUpdate(this); }
+ GetCvars(this, 0); // get other cvars from player
// TODO: fold all of these into ClientState
DecodeLevelParms(this);
PlayerScore_Attach(this);
+ PlayerStats_PlayerBasic_CheckUpdate(this);
ClientData_Attach(this);
accuracy_init(this);
entcs_attach(this);
bot_clientconnect(this);
}
-void bot_clientdisconnect();
+void bot_clientdisconnect(entity this);
void W_HitPlotClose(entity this);
-void anticheat_report(entity this);
-void playerdemo_shutdown();
+void anticheat_report_to_eventlog(entity this);
+void playerdemo_shutdown(entity this);
void entcs_detach(entity this);
void accuracy_free(entity this);
void ClientData_Detach(entity this);
void ClientState_detach(entity this)
{
- remove(CS(this));
+ delete(CS(this));
this._cs = NULL;
- GetCvars(-1); // free cvars
+ GetCvars(this, -1); // free cvars
- bot_clientdisconnect();
+ bot_clientdisconnect(this);
W_HitPlotClose(this);
- anticheat_report(this);
- playerdemo_shutdown();
+ anticheat_report_to_eventlog(this);
+ playerdemo_shutdown(this);
entcs_detach(this);
- accuracy_free(self);
+ accuracy_free(this);
ClientData_Detach(this);
- PlayerScore_Detach(self);
+ PlayerScore_Detach(this);
}