From: Rudolf Polzer Date: Tue, 14 Jun 2011 18:20:35 +0000 (+0200) Subject: add a test case for csqc/svqc entity type switching X-Git-Tag: xonotic-v0.5.0~199^2~29 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=b5a9b3523d380f9233463daa4718163f24a127a8;p=xonotic%2Fxonotic-data.pk3dir.git add a test case for csqc/svqc entity type switching --- diff --git a/qcsrc/server/gamecommand.qc b/qcsrc/server/gamecommand.qc index a83be998a8..c8d2af1436 100644 --- a/qcsrc/server/gamecommand.qc +++ b/qcsrc/server/gamecommand.qc @@ -668,6 +668,34 @@ void changematchtime(float delta, float mi, float ma) cvar_set("timelimit", ftos(new / 60)); } +float g_clientmodel_genericsendentity (entity to, float sf); +void modelbug_make_svqc(); +void modelbug_make_csqc() +{ + Net_LinkEntity(self, TRUE, 0, g_clientmodel_genericsendentity); + self.think = modelbug_make_svqc; + self.nextthink = time + 1; + setorigin(self, self.origin - '0 0 8'); +} +void modelbug_make_svqc() +{ + self.SendEntity = func_null; + self.think = modelbug_make_csqc; + self.nextthink = time + 1; + setorigin(self, self.origin + '0 0 8'); +} + +void modelbug() +{ + entity e; + e = spawn(); + setorigin(e, nextent(world).origin); + precache_model("models_portal.md3"); + setmodel(e, "models/portal.md3"); + e.think = modelbug_make_svqc; + e.nextthink = time + 1; +} + void GameCommand(string command) { float argc; @@ -1451,6 +1479,12 @@ void GameCommand(string command) return; } + if(argv(0) == "modelbug") + { + modelbug(); + return; + } + print("Invalid command. For a list of supported commands, try sv_cmd help.\n"); }