From: Mario Date: Thu, 29 Sep 2016 01:59:10 +0000 (+1000) Subject: Fix weaplast X-Git-Tag: xonotic-v0.8.2~326^2~91 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=4472d52c145d0315144d833a7ce408bb1de52fa0;p=xonotic%2Fxonotic-data.pk3dir.git Fix weaplast --- diff --git a/qcsrc/server/client.qc b/qcsrc/server/client.qc index b3e87e03b9..ccb658e737 100644 --- a/qcsrc/server/client.qc +++ b/qcsrc/server/client.qc @@ -701,10 +701,9 @@ void PutClientInServer(entity this) this.(weaponentity).m_switchweapon = WEP_Null; this.(weaponentity).weaponname = ""; this.(weaponentity).m_switchingweapon = WEP_Null; + this.cnt = -1; } - this.cnt = -1; // TODO - if (!warmup_stage && !this.alivetime) this.alivetime = time; diff --git a/qcsrc/server/g_damage.qc b/qcsrc/server/g_damage.qc index 7a28ae7333..6851f7cdfe 100644 --- a/qcsrc/server/g_damage.qc +++ b/qcsrc/server/g_damage.qc @@ -123,7 +123,7 @@ string AppendItemcodes(string s, entity player) //if(w == 0) // w = player.switchweapon; if(w == 0) - w = player.cnt; // previous weapon! + w = player.(weaponentity).cnt; // previous weapon! s = strcat(s, ftos(w)); if(time < player.strength_finished) s = strcat(s, "S"); diff --git a/qcsrc/server/miscfunctions.qc b/qcsrc/server/miscfunctions.qc index 00e33f0c4f..d38eedaf34 100644 --- a/qcsrc/server/miscfunctions.qc +++ b/qcsrc/server/miscfunctions.qc @@ -271,7 +271,7 @@ string formatmessage(entity this, string msg) case "l": replacement = NearestLocation(this.origin); break; case "y": replacement = NearestLocation(cursor); break; case "d": replacement = NearestLocation(this.death_origin); break; - case "w": replacement = ((this.(weaponentity).m_weapon == WEP_Null) ? ((this.(weaponentity).m_switchweapon == WEP_Null) ? Weapons_from(this.cnt) : this.(weaponentity).m_switchweapon) : this.(weaponentity).m_weapon).m_name; break; + case "w": replacement = ((this.(weaponentity).m_weapon == WEP_Null) ? ((this.(weaponentity).m_switchweapon == WEP_Null) ? Weapons_from(this.(weaponentity).cnt) : this.(weaponentity).m_switchweapon) : this.(weaponentity).m_weapon).m_name; break; case "W": replacement = ammoitems; break; case "x": replacement = ((cursor_ent.netname == "" || !cursor_ent) ? "nothing" : cursor_ent.netname); break; case "s": replacement = ftos(vlen(this.velocity - this.velocity_z * '0 0 1')); break; diff --git a/qcsrc/server/weapons/selection.qc b/qcsrc/server/weapons/selection.qc index da66310944..809becc33f 100644 --- a/qcsrc/server/weapons/selection.qc +++ b/qcsrc/server/weapons/selection.qc @@ -316,7 +316,7 @@ void W_PreviousWeapon(entity this, float list, .entity weaponentity) // previously used if exists and has ammo, (second) best otherwise void W_LastWeapon(entity this, .entity weaponentity) { - Weapon wep = Weapons_from(this.cnt); + Weapon wep = Weapons_from(this.(weaponentity).cnt); if (client_hasweapon(this, wep, true, false)) W_SwitchWeapon(this, wep, weaponentity); else