]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/server/mutators/gamemode_ctf.qh
Use separate messages for different return types
[xonotic/xonotic-data.pk3dir.git] / qcsrc / server / mutators / gamemode_ctf.qh
1 // these are needed since mutators are compiled last
2
3 // used in cheats.qc
4 void ctf_RespawnFlag(entity flag)
5
6 // used in t_quake3.qc
7 void spawnfunc_info_player_team1();
8 void spawnfunc_info_player_team2();
9 void spawnfunc_info_player_team3();
10 void spawnfunc_info_player_team4();
11 void spawnfunc_item_flag_team1();
12 void spawnfunc_item_flag_team2();
13 void spawnfunc_ctf_team();
14
15 // flag constants // for most of these, there is just one question to be asked: WHYYYYY?
16 #define FLAG_MIN (PL_MIN + '0 0 -13')
17 #define FLAG_MAX (PL_MAX + '0 0 -13')
18
19 #define FLAG_SCALE 0.6
20
21 #define FLAG_THINKRATE 0.2
22 #define FLAG_TOUCHRATE 0.5
23
24 #define FLAG_DROP_OFFSET ('0 0 32')
25 #define FLAG_CARRY_OFFSET ('-16 0 8')
26 #define FLAG_SPAWN_OFFSET ('0 0 1' * (PL_MAX_z - 13))
27 #define FLAG_WAYPOINT_OFFSET ('0 0 64')
28
29 #define VEHICLE_FLAG_OFFSET ('0 0 96')
30 #define VEHICLE_FLAG_SCALE 1.0
31
32 // waypoint colors
33 #define WPCOLOR_ENEMYFC(t) (colormapPaletteColor(t - 1, FALSE) * 0.75)
34 #define WPCOLOR_FLAGCARRIER(t) (('0 0.75 0' + colormapPaletteColor(t - 1, FALSE)) * 0.5)
35 #define WPCOLOR_DROPPEDFLAG(t) (('0.25 0.25 0.25' + colormapPaletteColor(t - 1, FALSE)) * 0.5)
36
37 // sounds 
38 #define snd_flag_taken noise
39 #define snd_flag_returned noise1
40 #define snd_flag_capture noise2
41 #define snd_flag_respawn noise3
42 .string snd_flag_dropped;
43 .string snd_flag_touch;
44
45 // list of flags on the map
46 entity ctf_worldflaglist;
47 .entity ctf_worldflagnext;
48
49 // waypoint sprites
50 .entity bot_basewaypoint; // flag waypointsprite
51 .entity wps_helpme;
52 .entity wps_flagbase; 
53 .entity wps_flagcarrier;
54 .entity wps_flagdropped;
55 .entity wps_enemyflagcarrier;
56
57 // statuses
58 #define FLAG_BASE 1
59 #define FLAG_DROPPED 2
60 #define FLAG_CARRY 3
61 #define FLAG_PASSING 4
62
63 #define DROP_NORMAL 1
64 #define DROP_THROW 2
65 #define DROP_PASS 3
66 #define DROP_RESET 4
67
68 #define PICKUP_BASE 1
69 #define PICKUP_DROPPED 2
70
71 #define CAPTURE_NORMAL 1
72 #define CAPTURE_DROPPED 2
73
74 #define RETURN_TIMEOUT 1
75 #define RETURN_DROPPED 2
76 #define RETURN_DAMAGE 3
77 #define RETURN_SPEEDRUN 4
78 #define RETURN_NEEDKILL 5
79
80 // flag properties
81 #define ctf_spawnorigin dropped_origin
82 float ctf_captimerecord; // record time for capturing the flag
83 .float ctf_pickuptime;
84 .float ctf_droptime;
85 .float ctf_status; // status of the flag (FLAG_BASE, FLAG_DROPPED, FLAG_CARRY declared globally)
86 .entity ctf_carrier;
87 .entity ctf_dropper; // don't allow spam of dropping the flag
88 .float max_flag_health;
89 .float next_take_time;
90 .float wpforenemy_announced;
91
92 // passing properties
93 .entity pass_sender;
94 .entity pass_target;
95 .float throw_antispam;
96
97 // CaptureShield: If the player is too bad to be allowed to capture, shield them from taking the flag.
98 .float ctf_captureshielded; // set to 1 if the player is too bad to be allowed to capture
99 float ctf_captureshield_min_negscore; // punish at -20 points
100 float ctf_captureshield_max_ratio; // punish at most 30% of each team
101 float ctf_captureshield_force; // push force of the shield