From 7fc93f6e2e2ed3cb6a6f4626ddbb0718e81922af Mon Sep 17 00:00:00 2001 From: Rudolf Polzer Date: Fri, 2 Dec 2011 10:46:12 +0100 Subject: [PATCH] move the exterior weapon entity to csqcmodel (preparation for forcemodels) --- qcsrc/csqcmodel/settings.qh | 29 +++++++++++++++++++++++++++++ qcsrc/server/autocvars.qh | 3 --- qcsrc/server/cl_client.qc | 33 ++------------------------------- qcsrc/server/cl_weaponsystem.qc | 9 +++++++++ 4 files changed, 40 insertions(+), 34 deletions(-) diff --git a/qcsrc/csqcmodel/settings.qh b/qcsrc/csqcmodel/settings.qh index 4147329242..5402387330 100644 --- a/qcsrc/csqcmodel/settings.qh +++ b/qcsrc/csqcmodel/settings.qh @@ -40,3 +40,32 @@ //vector PL_CROUCH_MIN = ...; //vector PL_CROUCH_MAX = ...; //vector PL_CROUCH_VIEW_OFS = ...; + +#ifdef SVQC +# ifdef NO_LEGACY_NETWORKING +# define CSQCMODEL_AUTOINIT() CSQCModel_LinkEntity() +# define CSQCMODEL_AUTOUPDATE() CSQCModel_CheckUpdate() +# else +.float iscsqcmodel; +float autocvar_sv_use_csqc_players; +# define CSQCMODEL_AUTOINIT() \ + if(autocvar_sv_use_csqc_players) \ + { \ + CSQCModel_LinkEntity(); \ + self.iscsqcmodel = 1; \ + } +# define CSQCMODEL_AUTOUPDATE() \ + if(autocvar_sv_use_csqc_players && !self.iscsqcmodel) \ + { \ + CSQCModel_LinkEntity(); \ + self.iscsqcmodel = 1; \ + } \ + if(!autocvar_sv_use_csqc_players && self.iscsqcmodel) \ + { \ + CSQCModel_UnlinkEntity(); \ + self.iscsqcmodel = 0; \ + } \ + if(self.iscsqcmodel) \ + CSQCModel_CheckUpdate(); +# endif +#endif diff --git a/qcsrc/server/autocvars.qh b/qcsrc/server/autocvars.qh index c3e267ccee..7f006745ef 100644 --- a/qcsrc/server/autocvars.qh +++ b/qcsrc/server/autocvars.qh @@ -1194,6 +1194,3 @@ float autocvar_sv_gameplayfix_gravityunaffectedbyticrate; float autocvar_g_trueaim_minrange; float autocvar_g_debug_defaultsounds; float autocvar_g_loituma; -#ifndef NO_LEGACY_NETWORKING -float autocvar_sv_use_csqc_players; -#endif diff --git a/qcsrc/server/cl_client.qc b/qcsrc/server/cl_client.qc index 2386c3ca9b..65b30b1d64 100644 --- a/qcsrc/server/cl_client.qc +++ b/qcsrc/server/cl_client.qc @@ -1424,10 +1424,6 @@ float PlayerInIDList(entity p, string idlist) return 0; } -#ifndef NO_LEGACY_NETWORKING -.float iscsqcmodel; -#endif - /* ============= ClientConnect @@ -1687,15 +1683,7 @@ void ClientConnect (void) if(!autocvar_g_campaign) Send_CSQC_Centerprint_Generic(self, CPID_MOTD, getwelcomemessage(), autocvar_welcome_message_time, 0); -#ifndef NO_LEGACY_NETWORKING - if(autocvar_sv_use_csqc_players) - { - CSQCModel_LinkEntity(); - self.iscsqcmodel = 1; - } -#else - CSQCModel_LinkEntity(); -#endif + CSQCMODEL_AUTOINIT(); self.model_randomizer = random(); } @@ -3150,22 +3138,5 @@ void PlayerPostThink (void) dprint(sprintf("%f %.6f\n", time, race_GetFractionalLapCount(self))); */ -#ifndef NO_LEGACY_NETWORKING - if(autocvar_sv_use_csqc_players && !self.iscsqcmodel) - { - CSQCModel_LinkEntity(); - self.iscsqcmodel = 1; - } - - if(!autocvar_sv_use_csqc_players && self.iscsqcmodel) - { - CSQCModel_UnlinkEntity(); - self.iscsqcmodel = 0; - } - - if(self.iscsqcmodel) - CSQCModel_CheckUpdate(); -#else - CSQCModel_CheckUpdate(); -#endif + CSQCMODEL_AUTOUPDATE(); } diff --git a/qcsrc/server/cl_weaponsystem.qc b/qcsrc/server/cl_weaponsystem.qc index 4acb8da891..ae275ac679 100644 --- a/qcsrc/server/cl_weaponsystem.qc +++ b/qcsrc/server/cl_weaponsystem.qc @@ -681,6 +681,8 @@ void CL_ExteriorWeaponentity_Think() self.glowmod = self.owner.weaponentity_glowmod; self.colormap = self.owner.colormap; + + CSQCMODEL_AUTOUPDATE(); } // spawning weaponentity for client @@ -708,6 +710,13 @@ void CL_SpawnWeaponentity() self.exteriorweaponentity.angles = '0 0 0'; self.exteriorweaponentity.think = CL_ExteriorWeaponentity_Think; self.exteriorweaponentity.nextthink = time; + + { + entity oldself = self; + self = self.exteriorweaponentity; + CSQCMODEL_AUTOINIT(); + self = oldself; + } } void Send_WeaponComplain (entity e, float wpn, string wpnname, float type) -- 2.39.2