Allow the model to be specified from the spawn command.
[xonotic/xonotic-data.pk3dir.git] / qcsrc / server / mutators / sandbox.qc
1 MUTATOR_HOOKFUNCTION(sandbox_PlayerCommand)
2 {
3         if(MUTATOR_RETURNVALUE) // command was already handled?
4                 return 0;
5         if(cmd_name == "g_sandbox")
6         {
7                 if(cmd_argc < 2)
8                 {
9                         print_to(self, "Sandbox mode is active. For more information, use 'g_sandbox help'");
10                         return 1;
11                 }
12
13                 if(argv(1) == "help")
14                 {
15                         print_to(self, "You can use the following sandbox commands:");
16                         print_to(self, "^7\"^2spawn ^3models/foo/bar.md3^7\" spawns a new object in front of the player, and gives it the specified model");
17                         return 1;
18                 }
19                 else if(argv(1) == "spawn")
20                 {
21                         // spawn a new object with the default settings
22
23                         entity e;
24                         e = spawn();
25                         e.classname = "object";
26                         makevectors(self.v_angle);
27                         traceline(self.origin + self.view_ofs, self.origin + self.view_ofs + v_forward * autocvar_g_sandbox_editor_distance, MOVE_NOMONSTERS, self);
28                         setorigin(e, trace_endpos);
29                         setmodel(e, argv(2));
30                         e.angles = self.v_angle; // give the player's angles to the object, as he spawns it from behind
31
32                         if(autocvar_g_sandbox_info)
33                                 print(strcat(self.netname, " spawned an object at origin ", vtos(e.origin), "\n"));
34
35                         return 1;
36                 }
37         }
38         return 0;
39 }
40
41 MUTATOR_DEFINITION(sandbox)
42 {
43         MUTATOR_HOOK(SV_ParseClientCommand, sandbox_PlayerCommand, CBC_ORDER_ANY);
44
45         return 0;
46 }