]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
new parameter target_random to ALL entities; when set to 1, only one instead of all...
authorRudolf Polzer <divVerent@xonotic.org>
Wed, 8 Jun 2011 08:51:38 +0000 (10:51 +0200)
committerRudolf Polzer <divVerent@xonotic.org>
Wed, 8 Jun 2011 08:51:38 +0000 (10:51 +0200)
qcsrc/server/defs.qh
qcsrc/server/g_triggers.qc

index f3c754151e87ac719a10ff11bdc9758160b92e66..e0a362ebe8dfbc8c5bb2d1ebf1c2f2a6a52e7209 100644 (file)
@@ -545,6 +545,7 @@ void target_voicescript_clear(entity pl);
 .string target2;
 .string target3;
 .string target4;
+.float target_random;
 .float trigger_reverse;
 
 // Nexball 
index 6c0921ba9b6ee7317f341dd2e09a623786a3c4d7..3ad43b0c36dbf0815ef87145ff6d101aef4e248b 100644 (file)
@@ -88,6 +88,9 @@ void SUB_UseTargets()
        stemp = self;
        otemp = other;
 
+       if(stemp.target_random)
+               RandomSelection_Init();
+
        for(i = 0; i < 4; ++i)
        {
                switch(i)
@@ -103,15 +106,29 @@ void SUB_UseTargets()
                        for(t = world; (t = find(t, targetname, s)); )
                        if(t.use)
                        {
-                               //print(stemp.classname, " ", stemp.targetname, " -> ", t.classname, " ", t.targetname, "\n");
-                               self = t;
-                               other = stemp;
-                               activator = act;
-                               self.use();
+                               if(stemp.target_random)
+                               {
+                                       RandomSelection_Add(t, 0, string_null, 1, 0);
+                               }
+                               else
+                               {
+                                       self = t;
+                                       other = stemp;
+                                       activator = act;
+                                       self.use();
+                               }
                        }
                }
        }
 
+       if(stemp.target_random && RandomSelection_chosen_ent)
+       {
+               self = RandomSelection_chosen_ent;
+               other = stemp;
+               activator = act;
+               self.use();
+       }
+
        activator = act;
        self = stemp;
        other = otemp;