]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Steal new weapon cvar system
authorMario <mario.mario@y7mail.com>
Wed, 28 Aug 2013 20:19:18 +0000 (06:19 +1000)
committerMario <mario.mario@y7mail.com>
Wed, 28 Aug 2013 20:19:18 +0000 (06:19 +1000)
18 files changed:
monsters.cfg
qcsrc/common/command/generic.qc
qcsrc/common/monsters/config.qc [new file with mode: 0644]
qcsrc/common/monsters/config.qh [new file with mode: 0644]
qcsrc/common/monsters/monster/animus.qc
qcsrc/common/monsters/monster/bruiser.qc
qcsrc/common/monsters/monster/brute.qc
qcsrc/common/monsters/monster/cerberus.qc
qcsrc/common/monsters/monster/knight.qc
qcsrc/common/monsters/monster/mage.qc
qcsrc/common/monsters/monster/shambler.qc
qcsrc/common/monsters/monster/slime.qc
qcsrc/common/monsters/monster/spider.qc
qcsrc/common/monsters/monster/stingray.qc
qcsrc/common/monsters/monster/wyvern.qc
qcsrc/common/monsters/monster/zombie.qc
qcsrc/common/monsters/monsters.qh
qcsrc/server/progs.src

index 7d3fd9c8a46472418f5f4a66f3999b9110f6c076..1780359589a1716f9f852f9308baa9029d41df10 100644 (file)
@@ -29,7 +29,7 @@ set g_monsters_skill_nightmare 10 "Monster nightmare skill level (used for skill
 // Brute
 set g_monster_brute 1 "Enable Brutes"
 set g_monster_brute_health 300 "Brute health"
-set g_monster_brute_chainsaw_damage 15 "Brute chainsaw damage (hits multiple times)"
+set g_monster_brute_attack_chainsaw_damage 15 "Brute chainsaw damage (hits multiple times)"
 set g_monster_brute_drop ammo "Brute drops this item on death"
 set g_monster_brute_drop_size bullets "Size of the item Brutes drop. Possible values are: small, medium, large"
 set g_monster_brute_speed_walk 100 "Brute walk speed"
@@ -42,12 +42,16 @@ set g_monster_brute_attack_grenade_damage 40 "Brute grenade damage"
 set g_monster_brute_attack_grenade_edgedamage 20 "Brute grenade indirect hit damage"
 set g_monster_brute_attack_grenade_radius 200 "Brute grenade explosion radius"
 set g_monster_brute_attack_grenade_force 15 "Brute grenade knockback"
+set g_monster_brute_attack_grenade_speed 1900
+set g_monster_brute_attack_grenade_speed_up 225
+set g_monster_brute_attack_grenade_speed_z 0
+set g_monster_brute_attack_grenade_spread 0
 
 // Animus
 set g_monster_animus 1 "Enable Animuses"
 set g_monster_animus_health 150 "Animus health"
 set g_monster_animus_attack_jump_damage 80 "Animus jump attack damage"
-set g_monster_animus_damage 45 "Animus melee attack damage"
+set g_monster_animus_attack_melee_damage 45 "Animus melee attack damage"
 set g_monster_animus_drop health "Animus drops this item on death"
 set g_monster_animus_drop_size medium "Size of the item Animuses drop. Possible values are: small, medium, large"
 set g_monster_animus_speed_walk 150 "Animus walk speed"
@@ -56,7 +60,7 @@ set g_monster_animus_speed_run 350 "Animus run speed"
 // Shambler
 set g_monster_shambler 1 "Enable Shamblers"
 set g_monster_shambler_health 500 "Shambler health"
-set g_monster_shambler_damage 50 "Shambler melee attack damage"
+set g_monster_shambler_attack_smash_damage 50 "Shambler smash attack damage"
 set g_monster_shambler_attack_lightning_damage 15 "Shambler lightning attack damage per frame"
 set g_monster_shambler_attack_claw_damage 50 "Shambler claw attack damage"
 set g_monster_shambler_drop health "Shambler drops this item on death"
@@ -69,8 +73,7 @@ set g_monster_bruiser 1 "Enable Bruisers"
 set g_monster_bruiser_health 200 "Bruiser Health"
 set g_monster_bruiser_drop armor "Bruiser drops this item on death"
 set g_monster_bruiser_drop_size medium "Size of the item Bruisers drop. Possible values are: small, medium, large"
-set g_monster_bruiser_melee_damage 50 "Bruiser melee attack damage"
-set g_monster_bruiser_melee_side_damage 35 "Bruiser melee attack side damage"
+set g_monster_bruiser_attack_melee_damage 50 "Bruiser melee attack damage"
 set g_monster_bruiser_speed_walk 40 "Bruiser walk speed"
 set g_monster_bruiser_speed_run 360 "Bruiser run speed"
 
@@ -79,19 +82,20 @@ set g_monster_wyvern 1 "Enable Wyverns"
 set g_monster_wyvern_health 95 "Wyvern health"
 set g_monster_wyvern_drop ammo "Wyvern drops this item on death"
 set g_monster_wyvern_drop_size cells "Size of the item Wyverns drop. Possible values are: small, medium, large"
+set g_monster_wyvern_speed_stop 300 "Wyvern stop speed"
 set g_monster_wyvern_speed_walk 40 "Wyvern walk speed"
 set g_monster_wyvern_speed_run 120 "Wyvern run speed"
-set g_monster_wyvern_fireball_damagetime 3 "How long the enemy will burn if it's within fireball radius"
-set g_monster_wyvern_fireball_damage 30 "Wyvern fireball projectile damage"
-set g_monster_wyvern_fireball_edgedamage 20 "Wyvern fireball indirect hit damage"
-set g_monster_wyvern_fireball_force 50 "Wyvern fireball projectile push force"
-set g_monster_wyvern_fireball_radius 120 "Wyvern fireball projectile damage radius"
-set g_monster_wyvern_fireball_speed 900 "Wyvern fireball projectile speed"
+set g_monster_wyvern_attack_fireball_damagetime 3 "How long the enemy will burn if it's within fireball radius"
+set g_monster_wyvern_attack_fireball_damage 30 "Wyvern fireball projectile damage"
+set g_monster_wyvern_attack_fireball_edgedamage 20 "Wyvern fireball indirect hit damage"
+set g_monster_wyvern_attack_fireball_force 50 "Wyvern fireball projectile push force"
+set g_monster_wyvern_attack_fireball_radius 120 "Wyvern fireball projectile damage radius"
+set g_monster_wyvern_attack_fireball_speed 900 "Wyvern fireball projectile speed"
 
 // Cerberus
 set g_monster_cerberus 1 "Enable Cerberuses"
 set g_monster_cerberus_health 100 "Cerberus health"
-set g_monster_cerberus_bite_damage 30 "Cerberus bite attack damage"
+set g_monster_cerberus_attack_bite_damage 30 "Cerberus bite attack damage"
 set g_monster_cerberus_attack_jump_damage 40 "Cerberus jump attack damage"
 set g_monster_cerberus_drop health "Cerberus drops this item on death"
 set g_monster_cerberus_drop_size small "Size of the item Cerberuss drop. Possible values are: small, medium, large"
@@ -101,6 +105,7 @@ set g_monster_cerberus_speed_run 250 "Cerberus run speed"
 // Slime
 set g_monster_slime 1 "Enable Slime"
 set g_monster_slime_health 80 "Slime health"
+set g_monster_slime_attack_explode_damage 250
 set g_monster_slime_drop ammo "Slime drops this item when it explodes"
 set g_monster_slime_drop_size rockets "Size of the item Slime drops. Possible values are: small, medium, large"
 set g_monster_slime_speed_walk 20 "Slime walk speed"
@@ -111,50 +116,50 @@ set g_monster_knight 1 "Enable Knights"
 set g_monster_knight_health 300 "Knight health"
 set g_monster_knight_drop armor "Knight drops this item on death"
 set g_monster_knight_drop_size medium "Size of the item Knights drop. Possible values are: small, medium, large"
-set g_monster_knight_inferno_damage 40 "Knight inferno damage"
-set g_monster_knight_inferno_chance 0.4 "Knight inferno attack chance"
-set g_monster_knight_inferno_damagetime 3 "How long the inferno should burn the player"
-set g_monster_knight_fireball_damage 30 "Knight fireball projectile damage"
-set g_monster_knight_fireball_edgedamage 10 "Knight fireball indirect hit damage"
-set g_monster_knight_fireball_force 50 "Knight fireball projectile push force"
-set g_monster_knight_fireball_radius 70 "Knight fireball projectile damage radius"
-set g_monster_knight_fireball_speed 600 "Knight fireball projectile speed"
-set g_monster_knight_fireball_spread 0 "Knight fireball projectile spread"
-set g_monster_knight_fireball_chance 0.3 "Chance for Knight to throw a fireball"
-set g_monster_knight_jump_chance 0.2 "Chance for Knight to jump at the player (always 1 if enemy is further than _dist)"
-set g_monster_knight_jump_damage 25 "Knight jump attack damage"
-set g_monster_knight_jump_dist 500 "Knight will prioritise jumping if the enemy is this far away"
-set g_monster_knight_melee_damage 20 "Knight melee attack damage"
-set g_monster_knight_spike_damage 20 "Knight spike projectile damage"
-set g_monster_knight_spike_edgedamage 10 "Knight spike projectile indirect hit damage"
-set g_monster_knight_spike_radius 20 "Knight spike projectile damage radius"
-set g_monster_knight_spike_force 5 "Knight spike projectile force"
-set g_monster_knight_spike_chance 0.5 "Knight spike attack chance"
-set g_monster_knight_speed_walk 75 "Knight walk speed"
-set g_monster_knight_speed_run 150 "Knight run speed"
+set g_monster_knight_attack_inferno_damage 40 "Knight inferno damage"
+set g_monster_knight_attack_inferno_chance 0.4 "Knight inferno attack chance"
+set g_monster_knight_attack_inferno_damagetime 3 "How long the inferno should burn the player"
+set g_monster_knight_attack_fireball_damage 30 "Knight fireball projectile damage"
+set g_monster_knight_attack_fireball_edgedamage 10 "Knight fireball indirect hit damage"
+set g_monster_knight_attack_fireball_force 50 "Knight fireball projectile push force"
+set g_monster_knight_attack_fireball_radius 70 "Knight fireball projectile damage radius"
+set g_monster_knight_attack_fireball_speed 600 "Knight fireball projectile speed"
+set g_monster_knight_attack_fireball_spread 0 "Knight fireball projectile spread"
+set g_monster_knight_attack_fireball_chance 0.3 "Chance for Knight to throw a fireball"
+set g_monster_knight_attack_fireball_damagetime 1
+set g_monster_knight_attack_jump_chance 0.2 "Chance for Knight to jump at the player (always 1 if enemy is further than _dist)"
+set g_monster_knight_attack_jump_damage 25 "Knight jump attack damage"
+set g_monster_knight_attack_jump_distance 500 "Knight will prioritise jumping if the enemy is this far away"
+set g_monster_knight_attack_melee_damage 20 "Knight melee attack damage"
+set g_monster_knight_attack_spike_damage 20 "Knight spike projectile damage"
+set g_monster_knight_attack_spike_edgedamage 10 "Knight spike projectile indirect hit damage"
+set g_monster_knight_attack_spike_radius 20 "Knight spike projectile damage radius"
+set g_monster_knight_attack_spike_force 5 "Knight spike projectile force"
+set g_monster_knight_attack_spike_chance 0.5 "Knight spike attack chance"
+set g_monster_knight_attack_speed_walk 75 "Knight walk speed"
+set g_monster_knight_attack_speed_run 150 "Knight run speed"
 
 // Stingray
 set g_monster_stingray 1 "Enable Stingray"
 set g_monster_stingray_health 115 "Stingray health"
-set g_monster_stingray_damage 25 "Stingray bite attack damage"
+set g_monster_stingray_attack_bite_damage 25 "Stingray bite attack damage"
+set g_monster_stingray_attack_bite_delay 0.5
 set g_monster_stingray_drop health "Stingray drops this item on death"
 set g_monster_stingray_drop_size small "Size of the item Stingray drop. Possible values are: small, medium, large"
+set g_monster_stingray_speed_stop 10
 set g_monster_stingray_speed_walk 40 "Stingray walk speed"
 set g_monster_stingray_speed_run 200 "Stingray run speed"
 
 // Mage
 set g_monster_mage 1 "Enable Mages"
 set g_monster_mage_health 200 "Mage health"
-set g_monster_mage_drop health "Mage drops this item on death"
-set g_monster_mage_drop_size medium "Size of the item Mages drop. Possible values are: small, medium, large"
-set g_monster_mage_speed 50 "Mage move speed"
 set g_monster_mage_attack_spike_damage 30 "Mage homing spike explosion damage"
 set g_monster_mage_attack_spike_radius 60 "Mage homing spike explosion radius"
 set g_monster_mage_attack_spike_delay 2 "Delay between Mage homing spike attacks"
 set g_monster_mage_attack_melee_damage 30 "Mage magic attack damage"
 set g_monster_mage_attack_melee_delay 0.7 "Delay between Mage melee attacks"
 set g_monster_mage_heal_self 35 "Amount of health Mage will regenerate every attack when its low on health"
-set g_monster_mage_heal_friends 15 "Amount of health Mage will regenerate nearby friends"
+set g_monster_mage_heal_allies 15 "Amount of health Mage will regenerate nearby friends"
 set g_monster_mage_heal_minhealth 250 "Health limit below which Mage will try to heal itself"
 set g_monster_mage_heal_range 200 "Maximum healing distance"
 set g_monster_mage_heal_delay 1.5 "Delay between healing bursts"
@@ -167,10 +172,12 @@ set g_monster_mage_attack_grenade_radius 100 "Mage fake item grenade attack expl
 set g_monster_mage_attack_grenade_lifetime 5 "Mage fake item grenade life time"
 set g_monster_mage_attack_grenade_speed 150 "Mage fake item grenade forward speed"
 set g_monster_mage_attack_grenade_speed_up 95 "Mage fake item grenade upwards speed"
-set g_monster_mage_attack_grenade_speed_z 0 "Mage fake item grenade speed angle"
-set g_monster_mage_attack_grenade_spread 0 "Mage fake item grenade spread"
 set g_monster_mage_attack_grenade_force 170 "Mage fake item grenade damage knockback"
 set g_monster_mage_attack_grenade_chance 30 "% chance of Mage attack being fake item grenade"
+set g_monster_mage_drop health "Mage drops this item on death"
+set g_monster_mage_drop_size medium "Size of the item Mages drop. Possible values are: small, medium, large"
+set g_monster_mage_speed_walk 50 "Mage walk speed"
+set g_monster_mage_speed_run 75 "Mage run speed"
 
 // Zombie
 set g_monster_zombie 1 "Enable Zombies"
@@ -179,31 +186,27 @@ set g_monster_zombie_attack_leap_delay 1.5 "Delay after zombie attack leap"
 set g_monster_zombie_attack_leap_force 55 "Force of zombie attack leap"
 set g_monster_zombie_attack_leap_range 96 "Range of zombie attack leap"
 set g_monster_zombie_attack_leap_speed 500 "The speed of a zombie attack leap"
-set g_monster_zombie_attack_stand_damage 40 "Damage when zombie hits from a standing position"
-set g_monster_zombie_attack_stand_delay 1.2 "Delay after a zombie hits from a standing position"
-set g_monster_zombie_attack_stand_range 48 "Range of a zombie standing position attack"
+set g_monster_zombie_attack_melee_damage 40 "Damage when zombie hits from a standing position"
+set g_monster_zombie_attack_melee_delay 1.2 "Delay after a zombie hits from a standing position"
 set g_monster_zombie_health 150 "Zombie health"
 set g_monster_zombie_speed_walk 150 "Zombie walk speed"
 set g_monster_zombie_speed_run 400 "Zombie run speed"
-set g_monster_zombie_stopspeed 100 "Speed at which zombie stops"
+set g_monster_zombie_speed_stop 100 "Speed at which zombie stops"
 set g_monster_zombie_drop health "Zombie drops this item on death"
 set g_monster_zombie_drop_size large "Size of the item zombies drop. Possible values are: small, medium, large"
 
 // Spider
 set g_monster_spider 1 "Enable Spiders"
 set g_monster_spider_attack_type 0 "Spider attack type (0 = ice, 1 = fire, ...)"
-set g_monster_spider_attack_leap_delay 1.5 "Delay after spider attack leap"
-set g_monster_spider_attack_stand_damage 35 "Damage when spider hits from a standing position"
-set g_monster_spider_attack_stand_delay 1.2 "Delay after a spider hits from a standing position"
-set g_monster_spider_attack_fire_time 2 "Spider fire attack burn time"
+set g_monster_spider_attack_bite_damage 35 "Damage when spider hits from a standing position"
+set g_monster_spider_attack_bite_delay 1.2 "Delay after a spider hits from a standing position"
+set g_monster_spider_attack_web_damagetime 2 "Spider fire attack burn time"
 set g_monster_spider_attack_web_speed 1000 "Spider web fly speed"
 set g_monster_spider_attack_web_speed_up 150 "Spider web upwards fly speed"
-set g_monster_spider_attack_web_spread 0 "Spider web spread"
-set g_monster_spider_attack_web_speed_z 0 "Spider web upwards angle"
+set g_monster_spider_attack_web_delay 1.5 "Delay after spider attack web"
 set g_monster_spider_health 160 "Spider health"
-set g_monster_spider_idle_timer_min 1 "Minimum time a spider can stay idle"
 set g_monster_spider_speed_walk 150 "Spider walk speed"
 set g_monster_spider_speed_run 400 "Spider run speed"
-set g_monster_spider_stopspeed 100 Speed at which spider stops"
+set g_monster_spider_speed_stop 100 "Speed at which spider stops"
 set g_monster_spider_drop health "Spider drops this item on death"
 set g_monster_spider_drop_size large "Size of the item spiders drop. Possible values are: small, medium, large"
index 143f3bd78c03591919a40be9aebe3d90d479f172..1fefd5c7a938df1bddec72c4eccb0231781df444 100644 (file)
@@ -227,6 +227,59 @@ void GenericCommand_dumpcommands(float request)
        }
 }
 
+void GenericCommand_dumpmonsters(float request)
+{
+       switch(request)
+       {
+               case CMD_REQUEST_COMMAND:
+               {
+                       #ifdef SVQC
+                       mon_config_file = -1;
+                       mon_config_alsoprint = -1;
+                       string filename = argv(1);
+                       
+                       if(filename == "")
+                       {
+                               filename = "monsters_dump.cfg";
+                               mon_config_alsoprint = FALSE;
+                       }
+                       else if(filename == "-")
+                       {
+                               filename = "monsters_dump.cfg";
+                               mon_config_alsoprint = TRUE;
+                       }
+                       mon_config_file = fopen(filename, FILE_WRITE);
+                       
+                       if(mon_config_file >= 0)
+                       {
+                               Dump_Monster_Settings();
+                               print(sprintf("Dumping monsters... File located in ^2data/data/%s^7.\n", filename));
+                               fclose(mon_config_file);
+                               mon_config_file = -1;
+                               mon_config_alsoprint = -1;
+                       }
+                       else
+                       {
+                               print(sprintf("^1Error: ^7Could not open file '%s'!\n", filename));
+                       }
+                       #else
+                       print(_("Monsters dump command only works with sv_cmd.\n"));
+                       #endif
+                       return;
+               }
+                       
+               default:
+               case CMD_REQUEST_USAGE:
+               {
+                       print(strcat("\nUsage:^3 ", GetProgramCommandPrefix(), " dumpmonsters [filename]"));
+                       print("  Where 'filename' is the file to write (default is monsters_dump.cfg),\n");
+                       print("  if supplied with '-' output to console as well as default,\n");
+                       print("  if left blank, it will only write to default.\n");
+                       return;
+               }
+       }
+}
+
 void GenericCommand_dumpnotifs(float request)
 {
        switch(request)
@@ -582,6 +635,7 @@ void GenericCommand_(float request)
 #define GENERIC_COMMANDS(request,arguments,command) \
        GENERIC_COMMAND("addtolist", GenericCommand_addtolist(request, arguments), "Add a string to a cvar") \
        GENERIC_COMMAND("dumpcommands", GenericCommand_dumpcommands(request), "Dump all commands on the program to *_cmd_dump.txt") \
+       GENERIC_COMMAND("dumpmonsters", GenericCommand_dumpmonsters(request), "Dump all monsters into monsters_dump.cfg") \
        GENERIC_COMMAND("dumpnotifs", GenericCommand_dumpnotifs(request), "Dump all notifications into notifications_dump.txt") \
        GENERIC_COMMAND("maplist", GenericCommand_maplist(request, arguments), "Automatic control of maplist") \
        GENERIC_COMMAND("nextframe", GenericCommand_nextframe(request, arguments, command), "Execute the given command next frame of this VM") \
diff --git a/qcsrc/common/monsters/config.qc b/qcsrc/common/monsters/config.qc
new file mode 100644 (file)
index 0000000..a568db3
--- /dev/null
@@ -0,0 +1,62 @@
+// ==========================
+//  Monster Config Generator
+// ==========================
+
+void M_Config_Queue_Swap(float root, float child, entity pass)
+{
+       string oldroot = mon_config_queue[root];
+       mon_config_queue[root] = mon_config_queue[child];
+       mon_config_queue[child] = oldroot;
+}
+
+float M_Config_Queue_Compare(float root, float child, entity pass)
+{
+       float i, r, c;
+
+       for(i = 1; i <= 100; ++i)
+       {
+               r = str2chr(mon_config_queue[root], i);
+               c = str2chr(mon_config_queue[child], i);
+               if(r == c) { continue; }
+               else if(c > r) { return -1; }
+               else { return 1; }
+       }
+       
+       return 0;
+}
+
+void Dump_Monster_Settings(void)
+{
+       float i, x, totalsettings = 0;
+       for(i = MON_FIRST; i <= MON_LAST; ++i)
+       {
+               // step 1: clear the queue
+               MON_CONFIG_COUNT = 0;
+               for(x = 0; x <= MAX_MON_CONFIG; ++x)
+                       { mon_config_queue[x] = string_null; }
+
+               // step 2: build new queue
+               MON_ACTION(i, MR_CONFIG);
+
+               // step 3: sort queue
+               heapsort(MON_CONFIG_COUNT, M_Config_Queue_Swap, M_Config_Queue_Compare, world);
+               
+               // step 4: write queue
+               MON_CONFIG_WRITETOFILE(sprintf("// {{{ #%d: %s\n", i, M_NAME(i)))
+               for(x = 0; x <= MON_CONFIG_COUNT; ++x)
+                       { MON_CONFIG_WRITETOFILE(mon_config_queue[x]) }
+               MON_CONFIG_WRITETOFILE("// }}}\n")
+
+               // step 5: debug info
+               print(sprintf("#%d: %s: %d settings...\n", i, M_NAME(i), MON_CONFIG_COUNT));
+               totalsettings += MON_CONFIG_COUNT;
+       }
+
+       // clear queue now that we're finished
+       MON_CONFIG_COUNT = 0;
+       for(x = 0; x <= MAX_MON_CONFIG; ++x)
+               { mon_config_queue[x] = string_null; }
+
+       // extra information
+       print(sprintf("Totals: %d monsters, %d settings\n", (i - 1), totalsettings));
+}
diff --git a/qcsrc/common/monsters/config.qh b/qcsrc/common/monsters/config.qh
new file mode 100644 (file)
index 0000000..5a44c17
--- /dev/null
@@ -0,0 +1,29 @@
+// ==========================
+//  Monster Config Generator
+// ==========================
+
+void Dump_Monster_Settings(void);
+float mon_config_file;
+float mon_config_alsoprint;
+
+#define MAX_MON_CONFIG 256
+float MON_CONFIG_COUNT;
+string mon_config_queue[MAX_MON_CONFIG];
+
+#define MON_CONFIG_QUEUE(a) { \
+       mon_config_queue[MON_CONFIG_COUNT] = a; \
+       ++MON_CONFIG_COUNT; }
+
+#define MON_CONFIG_WRITETOFILE(a) { \
+       fputs(mon_config_file, a); \
+       if(mon_config_alsoprint) { print(a); } }
+
+#define MON_CONFIG_WRITE_CVARS(monster,name) \
+               { MON_CONFIG_QUEUE( \
+                       sprintf("set g_monster_%s_%s %g\n", #monster, #name, \
+                       cvar(sprintf("g_monster_%s_%s", #monster, #name)))) } \
+
+#define MON_CONFIG_SETTINGS(monsettings) \
+       #define MON_ADD_CVAR(monster,name) MON_CONFIG_WRITE_CVARS(monster,name) \
+       monsettings \
+       #undef MON_ADD_CVAR
index bd7639c0966479ba84d70078ba6d881a8fae49b6..09bb41a5a0e13c43703925cb75a754373487ecbe 100644 (file)
@@ -9,15 +9,18 @@ REGISTER_MONSTER(
 /* fullname   */ _("Animus")
 );
 
+#define ANIMUS_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_jump_damage) \
+       MON_ADD_CVAR(monster, attack_melee_damage) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+ANIMUS_SETTINGS(animus)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_animus;
-float autocvar_g_monster_animus_health;
-float autocvar_g_monster_animus_attack_jump_damage;
-float autocvar_g_monster_animus_damage;
-float autocvar_g_monster_animus_speed_walk;
-float autocvar_g_monster_animus_speed_run;
-
 const float animus_anim_stand  = 0;
 const float animus_anim_walk   = 1;
 const float animus_anim_run            = 2;
@@ -35,7 +38,7 @@ void animus_touch_jump()
        {
                if (vlen(self.velocity) > 300)
                {
-                       Damage(other, self, self, autocvar_g_monster_animus_attack_jump_damage * monster_skill, DEATH_MONSTER_ANIMUS, other.origin, normalize(other.origin - self.origin));
+                       Damage(other, self, self, MON_CVAR(animus, attack_jump_damage) * monster_skill, DEATH_MONSTER_ANIMUS, other.origin, normalize(other.origin - self.origin));
                        self.touch = MonsterTouch; // instantly turn it off to stop damage spam
                }
        }
@@ -52,7 +55,7 @@ float animus_attack(float attack_type)
                {
                        monsters_setframe(animus_anim_attack);
                        self.attack_finished_single = time + 1;
-                       monster_melee(self.enemy, autocvar_g_monster_animus_damage, 0.3, DEATH_MONSTER_ANIMUS, TRUE);
+                       monster_melee(self.enemy, MON_CVAR(animus, attack_melee_damage), 0.3, DEATH_MONSTER_ANIMUS, TRUE);
                        
                        return TRUE;
                }
@@ -69,8 +72,6 @@ float animus_attack(float attack_type)
 
 void spawnfunc_monster_animus()
 {
-       if not(autocvar_g_monster_animus) { remove(self); return; }
-       
        self.classname = "monster_animus";
        
        self.monster_spawnfunc = spawnfunc_monster_animus;
@@ -91,7 +92,7 @@ float m_animus(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_animus_speed_run, autocvar_g_monster_animus_speed_walk, 100, animus_anim_run, animus_anim_walk, animus_anim_stand);
+                       monster_move(MON_CVAR(animus, speed_run), MON_CVAR(animus, speed_walk), 100, animus_anim_run, animus_anim_walk, animus_anim_stand);
                        return TRUE;
                }
                case MR_DEATH:
@@ -101,7 +102,7 @@ float m_animus(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_animus_health;
+                       if not(self.health) self.health = MON_CVAR(animus, health);
                                
                        self.monster_attackfunc = animus_attack;
                        monsters_setframe(animus_anim_stand);
@@ -113,6 +114,11 @@ float m_animus(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(ANIMUS_SETTINGS(animus))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index fe16f9216597b5a3c84646248e7ce01283c15a79..b7cd36fe5ecd6b59a8cd89200c4e7e0ff2aca447 100644 (file)
@@ -9,14 +9,17 @@ REGISTER_MONSTER(
 /* fullname   */ _("Bruiser")
 );
 
+#define BRUISER_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_melee_damage) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+BRUISER_SETTINGS(bruiser)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_bruiser;
-float autocvar_g_monster_bruiser_health;
-float autocvar_g_monster_bruiser_melee_damage;
-float autocvar_g_monster_bruiser_speed_walk;
-float autocvar_g_monster_bruiser_speed_run;
-
 const float bruiser_anim_stand                 = 0;
 const float bruiser_anim_run           = 1;
 const float bruiser_anim_runattack     = 2;
@@ -39,7 +42,7 @@ float bruiser_attack(float attack_type)
                        monsters_setframe((len < 50) ? bruiser_anim_attack : bruiser_anim_runattack);
                        self.attack_finished_single = time + 1.25;
                        
-                       monster_melee(self.enemy, autocvar_g_monster_bruiser_melee_damage, 0.3, DEATH_MONSTER_BRUISER, FALSE);
+                       monster_melee(self.enemy, MON_CVAR(bruiser, attack_melee_damage), 0.3, DEATH_MONSTER_BRUISER, FALSE);
                        
                        return TRUE;
                }
@@ -55,8 +58,6 @@ float bruiser_attack(float attack_type)
 
 void spawnfunc_monster_bruiser()
 {
-       if not(autocvar_g_monster_bruiser) { remove(self); return; }
-       
        self.classname = "monster_bruiser";
        
        self.monster_spawnfunc = spawnfunc_monster_bruiser;
@@ -73,7 +74,7 @@ float m_bruiser(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_bruiser_speed_run, autocvar_g_monster_bruiser_speed_walk, 50, bruiser_anim_run, bruiser_anim_walk, bruiser_anim_stand);
+                       monster_move(MON_CVAR(bruiser, speed_run), MON_CVAR(bruiser, speed_walk), 50, bruiser_anim_run, bruiser_anim_walk, bruiser_anim_stand);
                        return TRUE;
                }
                case MR_DEATH:
@@ -83,7 +84,7 @@ float m_bruiser(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_bruiser_health;
+                       if not(self.health) self.health = MON_CVAR(bruiser, health);
                                
                        self.monster_attackfunc = bruiser_attack;
                        monsters_setframe(bruiser_anim_stand);
@@ -95,6 +96,11 @@ float m_bruiser(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(BRUISER_SETTINGS(bruiser))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 226e0d5885fb335896f6aa56b8270da1cd9cd15f..5b6ad3e5ada25e335f95c0ff8bc83e04ce81bae9 100644 (file)
@@ -9,22 +9,27 @@ REGISTER_MONSTER(
 /* fullname   */ _("Brute")
 );
 
+#define BRUTE_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_chainsaw_damage) \
+       MON_ADD_CVAR(monster, attack_uzi_bullets) \
+       MON_ADD_CVAR(monster, attack_uzi_damage) \
+       MON_ADD_CVAR(monster, attack_uzi_force) \
+       MON_ADD_CVAR(monster, attack_uzi_chance) \
+       MON_ADD_CVAR(monster, attack_grenade_damage) \
+       MON_ADD_CVAR(monster, attack_grenade_edgedamage) \
+       MON_ADD_CVAR(monster, attack_grenade_force) \
+       MON_ADD_CVAR(monster, attack_grenade_radius) \
+       MON_ADD_CVAR(monster, attack_grenade_speed) \
+       MON_ADD_CVAR(monster, attack_grenade_speed_up) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+BRUTE_SETTINGS(brute)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_brute;
-float autocvar_g_monster_brute_health;
-float autocvar_g_monster_brute_chainsaw_damage;
-float autocvar_g_monster_brute_speed_walk;
-float autocvar_g_monster_brute_speed_run;
-float autocvar_g_monster_brute_attack_uzi_bullets;
-float autocvar_g_monster_brute_attack_uzi_damage;
-float autocvar_g_monster_brute_attack_uzi_force;
-float autocvar_g_monster_brute_attack_uzi_chance;
-float autocvar_g_monster_brute_attack_grenade_damage;
-float autocvar_g_monster_brute_attack_grenade_edgedamage;
-float autocvar_g_monster_brute_attack_grenade_force;
-float autocvar_g_monster_brute_attack_grenade_radius;
-
 const float brute_anim_idle            = 0;
 const float brute_anim_walk            = 1;
 const float brute_anim_run                     = 2;
@@ -39,7 +44,7 @@ void brute_blade()
        self.brute_cycles += 1;
        self.angles_y = self.angles_y + random()* 25;
        
-       monster_melee(self.enemy, autocvar_g_monster_brute_chainsaw_damage, 0.3, DEATH_MONSTER_BRUTE_BLADE, TRUE);
+       monster_melee(self.enemy, MON_CVAR(brute, attack_chainsaw_damage), 0.3, DEATH_MONSTER_BRUTE_BLADE, TRUE);
        
        if(self.brute_cycles <= 4)
                defer(0.2, brute_blade);
@@ -51,11 +56,11 @@ void brute_uzi()
        
        monster_makevectors(self.enemy);
        
-       W_SetupShot (self, autocvar_g_antilag_bullets && 18000 >= autocvar_g_antilag_bullets, 0, "weapons/uzi_fire.wav", CH_WEAPON_A, autocvar_g_monster_brute_attack_uzi_damage);
-       fireBallisticBullet(w_shotorg, w_shotdir, 0.02, 18000, 5, autocvar_g_monster_brute_attack_uzi_damage, autocvar_g_monster_brute_attack_uzi_force, DEATH_MONSTER_BRUTE_UZI, 0, 1, 115);
+       W_SetupShot (self, autocvar_g_antilag_bullets && 18000 >= autocvar_g_antilag_bullets, 0, "weapons/uzi_fire.wav", CH_WEAPON_A, MON_CVAR(brute, attack_uzi_damage));
+       fireBallisticBullet(w_shotorg, w_shotdir, 0.02, 18000, 5, MON_CVAR(brute, attack_uzi_damage), MON_CVAR(brute, attack_uzi_force), DEATH_MONSTER_BRUTE_UZI, 0, 1, 115);
        endFireBallisticBullet();
        
-       if(self.brute_cycles <= autocvar_g_monster_brute_attack_uzi_bullets)
+       if(self.brute_cycles <= MON_CVAR(brute, attack_uzi_bullets))
                defer(0.1, brute_uzi);
 }
 
@@ -70,7 +75,7 @@ void brute_grenade_explode()
        if(self.movetype == MOVETYPE_NONE)
                self.velocity = self.oldvelocity;
 
-       RadiusDamage (self, self.realowner, autocvar_g_monster_brute_attack_grenade_damage, autocvar_g_monster_brute_attack_grenade_edgedamage, autocvar_g_monster_brute_attack_grenade_radius, world, autocvar_g_monster_brute_attack_grenade_force, self.projectiledeathtype, other);
+       RadiusDamage (self, self.realowner, MON_CVAR(brute, attack_grenade_damage), MON_CVAR(brute, attack_grenade_edgedamage), MON_CVAR(brute, attack_grenade_radius), world, MON_CVAR(brute, attack_grenade_force), self.projectiledeathtype, other);
 
        remove (self);
 }
@@ -111,14 +116,14 @@ void brute_grenade()
 {
        entity gren;
 
-       W_SetupShot_ProjectileSize (self, '-3 -3 -3', '3 3 3', FALSE, 4, "weapons/grenade_fire.wav", CH_WEAPON_A, autocvar_g_monster_brute_attack_grenade_damage);
+       W_SetupShot_ProjectileSize (self, '-3 -3 -3', '3 3 3', FALSE, 4, "weapons/grenade_fire.wav", CH_WEAPON_A, MON_CVAR(brute, attack_grenade_damage));
        w_shotdir = v_forward; // no TrueAim for grenades please
 
        gren = spawn ();
        gren.owner = gren.realowner = self;
        gren.classname = "grenade";
        gren.bot_dodge = TRUE;
-       gren.bot_dodgerating = autocvar_g_monster_brute_attack_grenade_damage;
+       gren.bot_dodgerating = MON_CVAR(brute, attack_grenade_damage);
        gren.movetype = MOVETYPE_BOUNCE;
        PROJECTILE_MAKETRIGGER(gren);
        gren.projectiledeathtype = DEATH_MONSTER_BRUTE_GRENADE;
@@ -132,12 +137,12 @@ void brute_grenade()
        gren.touch = brute_grenade_touch;
 
        gren.takedamage = DAMAGE_YES;
-       gren.health = autocvar_g_balance_grenadelauncher_primary_health;
-       gren.damageforcescale = autocvar_g_balance_grenadelauncher_primary_damageforcescale;
+       gren.health = 50;
+       gren.damageforcescale = 0;
        gren.event_damage = brute_grenade_damage;
        gren.damagedbycontents = TRUE;
        gren.missile_flags = MIF_SPLASH | MIF_ARC;
-       W_SETUPPROJECTILEVELOCITY_UP(gren, g_balance_grenadelauncher_primary);
+       W_SetupProjectileVelocityEx(gren, w_shotdir, v_up, MON_CVAR(brute, attack_grenade_speed), MON_CVAR(brute, attack_grenade_speed_up), 0, 0, FALSE);
 
        gren.angles = vectoangles (gren.velocity);
        gren.flags = FL_PROJECTILE;
@@ -161,7 +166,7 @@ float brute_attack(float attack_type)
                case MONSTER_ATTACK_RANGED:
                {
                        self.brute_cycles = 0;
-                       if(random() <= autocvar_g_monster_brute_attack_uzi_chance)
+                       if(random() <= MON_CVAR(brute, attack_uzi_chance))
                        {
                                monsters_setframe(brute_anim_pain);
                                self.attack_finished_single = time + 0.8;
@@ -184,8 +189,6 @@ float brute_attack(float attack_type)
 
 void spawnfunc_monster_brute()
 {
-       if not(autocvar_g_monster_brute) { remove(self); return; }
-       
        self.classname = "monster_brute";
        
        self.monster_spawnfunc = spawnfunc_monster_brute;
@@ -202,7 +205,7 @@ float m_brute(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_brute_speed_run, autocvar_g_monster_brute_speed_walk, 300, brute_anim_run, brute_anim_walk, brute_anim_idle);
+                       monster_move(MON_CVAR(brute, speed_run), MON_CVAR(brute, speed_walk), 300, brute_anim_run, brute_anim_walk, brute_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -212,7 +215,7 @@ float m_brute(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_brute_health;
+                       if not(self.health) self.health = MON_CVAR(brute, health);
                                
                        self.monster_attackfunc = brute_attack;
                        monsters_setframe(brute_anim_idle);
@@ -225,6 +228,11 @@ float m_brute(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(BRUTE_SETTINGS(brute))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 907c07ffbe6699c987c4631cfc5a03ac045135c2..e10ce3552e8069daf1f2f5497e5c3d5bc1255597 100644 (file)
@@ -9,15 +9,18 @@ REGISTER_MONSTER(
 /* fullname   */ _("Cerberus")
 );
 
+#define CERBERUS_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_bite_damage) \
+       MON_ADD_CVAR(monster, attack_jump_damage) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+CERBERUS_SETTINGS(cerberus)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_cerberus;
-float autocvar_g_monster_cerberus_health;
-float autocvar_g_monster_cerberus_bite_damage;
-float autocvar_g_monster_cerberus_attack_jump_damage;
-float autocvar_g_monster_cerberus_speed_walk;
-float autocvar_g_monster_cerberus_speed_run;
-
 const float cerberus_anim_idle         = 0;
 const float cerberus_anim_walk         = 1;
 const float cerberus_anim_run          = 2;
@@ -30,7 +33,7 @@ void cerberus_touch_jump()
        if (other.takedamage)
        if (vlen(self.velocity) > 300)
        {
-               Damage(self.enemy, self, self, autocvar_g_monster_cerberus_attack_jump_damage * monster_skill, DEATH_MONSTER_CERBERUS_JUMP, self.enemy.origin, normalize(self.enemy.origin - self.origin));
+               Damage(self.enemy, self, self, MON_CVAR(cerberus, attack_jump_damage) * monster_skill, DEATH_MONSTER_CERBERUS_JUMP, self.enemy.origin, normalize(self.enemy.origin - self.origin));
                self.touch = MonsterTouch;
        }
 
@@ -46,7 +49,7 @@ float cerberus_attack(float attack_type)
                {
                        monsters_setframe(cerberus_anim_attack);
                        self.attack_finished_single = time + 0.7;
-                       monster_melee(self.enemy, autocvar_g_monster_cerberus_bite_damage, 0.2, DEATH_MONSTER_CERBERUS_BITE, TRUE);
+                       monster_melee(self.enemy, MON_CVAR(cerberus, attack_bite_damage), 0.2, DEATH_MONSTER_CERBERUS_BITE, TRUE);
                        
                        return TRUE;
                }
@@ -63,8 +66,6 @@ float cerberus_attack(float attack_type)
 
 void spawnfunc_monster_cerberus()
 {
-       if not(autocvar_g_monster_cerberus) { remove(self); return; }
-       
        self.classname = "monster_cerberus";
        
        self.monster_spawnfunc = spawnfunc_monster_cerberus;
@@ -84,7 +85,7 @@ float m_cerberus(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_cerberus_speed_run, autocvar_g_monster_cerberus_speed_walk, 50, cerberus_anim_run, cerberus_anim_walk, cerberus_anim_idle);
+                       monster_move(MON_CVAR(cerberus, speed_run), MON_CVAR(cerberus, speed_walk), 50, cerberus_anim_run, cerberus_anim_walk, cerberus_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -94,7 +95,7 @@ float m_cerberus(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_cerberus_health;
+                       if not(self.health) self.health = MON_CVAR(cerberus, health);
                                
                        self.monster_attackfunc = cerberus_attack;
                        monsters_setframe(cerberus_anim_idle);
@@ -106,6 +107,11 @@ float m_cerberus(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(CERBERUS_SETTINGS(cerberus))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index bc2a0e950d7d2aa72c9670e45c0a5e7ca27f73fb..38629c54c2b5fd60a04a749796786a401373c3a9 100644 (file)
@@ -9,30 +9,34 @@ REGISTER_MONSTER(
 /* fullname   */ _("Knight")
 );
 
+#define KNIGHT_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_melee_damage) \
+       MON_ADD_CVAR(monster, attack_inferno_damage) \
+       MON_ADD_CVAR(monster, attack_inferno_damagetime) \
+       MON_ADD_CVAR(monster, attack_inferno_chance) \
+       MON_ADD_CVAR(monster, attack_fireball_damage) \
+       MON_ADD_CVAR(monster, attack_fireball_edgedamage) \
+       MON_ADD_CVAR(monster, attack_fireball_damagetime) \
+       MON_ADD_CVAR(monster, attack_fireball_force) \
+       MON_ADD_CVAR(monster, attack_fireball_radius) \
+       MON_ADD_CVAR(monster, attack_fireball_chance) \
+       MON_ADD_CVAR(monster, attack_spike_damage) \
+       MON_ADD_CVAR(monster, attack_spike_edgedamage) \
+       MON_ADD_CVAR(monster, attack_spike_force) \
+       MON_ADD_CVAR(monster, attack_spike_radius) \
+       MON_ADD_CVAR(monster, attack_spike_chance) \
+       MON_ADD_CVAR(monster, attack_jump_damage) \
+       MON_ADD_CVAR(monster, attack_jump_distance) \
+       MON_ADD_CVAR(monster, attack_jump_chance) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+KNIGHT_SETTINGS(knight)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_knight;
-float autocvar_g_monster_knight_health;
-float autocvar_g_monster_knight_melee_damage;
-float autocvar_g_monster_knight_inferno_damage;
-float autocvar_g_monster_knight_inferno_damagetime;
-float autocvar_g_monster_knight_inferno_chance;
-float autocvar_g_monster_knight_speed_walk;
-float autocvar_g_monster_knight_speed_run;
-float autocvar_g_monster_knight_fireball_damage;
-float autocvar_g_monster_knight_fireball_force;
-float autocvar_g_monster_knight_fireball_radius;
-float autocvar_g_monster_knight_fireball_chance;
-float autocvar_g_monster_knight_fireball_edgedamage;
-float autocvar_g_monster_knight_spike_chance;
-float autocvar_g_monster_knight_spike_force;
-float autocvar_g_monster_knight_spike_radius;
-float autocvar_g_monster_knight_spike_edgedamage;
-float autocvar_g_monster_knight_spike_damage;
-float autocvar_g_monster_knight_jump_chance;
-float autocvar_g_monster_knight_jump_damage;
-float autocvar_g_monster_knight_jump_dist;
-
 const float knight_anim_stand  = 0;
 const float knight_anim_walk   = 1;
 const float knight_anim_run    = 2;
@@ -63,7 +67,7 @@ void knight_inferno()
        sound(self.enemy, CHAN_AUTO, "player/lava.wav", 1, ATTN_NORM);
        
        if(vlen(self.enemy.origin - self.origin) <= 2000)
-               Fire_AddDamage(self.enemy, self, autocvar_g_monster_knight_inferno_damage * monster_skill, autocvar_g_monster_knight_inferno_damagetime, DEATH_MONSTER_KNIGHT_INFERNO);
+               Fire_AddDamage(self.enemy, self, MON_CVAR(knight, attack_inferno_damage) * monster_skill, MON_CVAR(knight, attack_inferno_damagetime), DEATH_MONSTER_KNIGHT_INFERNO);
 }
 
 void knight_fireball_explode()
@@ -73,10 +77,10 @@ void knight_fireball_explode()
        {
                pointparticles(particleeffectnum("fireball_explode"), self.origin, '0 0 0', 1);
                
-               RadiusDamage(self, self.realowner, autocvar_g_monster_knight_fireball_damage, autocvar_g_monster_knight_fireball_edgedamage, autocvar_g_monster_knight_fireball_force, world, autocvar_g_monster_knight_fireball_radius, self.projectiledeathtype, world);
+               RadiusDamage(self, self.realowner, MON_CVAR(knight, attack_fireball_damage), MON_CVAR(knight, attack_fireball_edgedamage), MON_CVAR(knight, attack_fireball_force), world, MON_CVAR(knight, attack_fireball_radius), self.projectiledeathtype, world);
                
-               for(e = world; (e = findfloat(e, takedamage, DAMAGE_AIM)); ) if(vlen(e.origin - self.origin) <= autocvar_g_monster_knight_fireball_radius)
-                       Fire_AddDamage(e, self, 5 * monster_skill, autocvar_g_monster_knight_inferno_damagetime, self.projectiledeathtype);
+               for(e = world; (e = findfloat(e, takedamage, DAMAGE_AIM)); ) if(vlen(e.origin - self.origin) <= MON_CVAR(knight, attack_inferno_damage))
+                       Fire_AddDamage(e, self, 5 * monster_skill, MON_CVAR(knight, attack_fireball_damagetime), self.projectiledeathtype);
                
                remove(self);
        }
@@ -121,7 +125,7 @@ void knight_spike_explode()
        {
                pointparticles(particleeffectnum("TE_WIZSPIKE"), self.origin, '0 0 0', 1);
                
-               RadiusDamage (self, self.realowner, autocvar_g_monster_knight_spike_damage, autocvar_g_monster_knight_spike_edgedamage, autocvar_g_monster_knight_spike_force, world, autocvar_g_monster_knight_spike_radius, DEATH_MONSTER_KNIGHT_SPIKE, other);
+               RadiusDamage (self, self.realowner, MON_CVAR(knight, attack_spike_damage), MON_CVAR(knight, attack_spike_edgedamage), MON_CVAR(knight, attack_spike_force), world, MON_CVAR(knight, attack_spike_radius), DEATH_MONSTER_KNIGHT_SPIKE, other);
                remove(self);
        }
 }
@@ -174,10 +178,10 @@ float knight_attack_ranged()
        self.knight_cycles = 0;
        
        RandomSelection_Init();
-       RandomSelection_Add(world, 1, "", autocvar_g_monster_knight_fireball_chance, 1);
-       RandomSelection_Add(world, 2, "", autocvar_g_monster_knight_inferno_chance, 1);
-       RandomSelection_Add(world, 3, "", autocvar_g_monster_knight_spike_chance, 1);
-       if(self.health >= 100) RandomSelection_Add(world, 4, "", ((vlen(self.enemy.origin - self.origin) > autocvar_g_monster_knight_jump_dist) ? 1 : autocvar_g_monster_knight_jump_chance), 1);
+       RandomSelection_Add(world, 1, "", MON_CVAR(knight, attack_fireball_chance), 1);
+       RandomSelection_Add(world, 2, "", MON_CVAR(knight, attack_inferno_chance), 1);
+       RandomSelection_Add(world, 3, "", MON_CVAR(knight, attack_spike_chance), 1);
+       if(self.health >= 100) RandomSelection_Add(world, 4, "", ((vlen(self.enemy.origin - self.origin) > MON_CVAR(knight, attack_jump_distance)) ? 1 : MON_CVAR(knight, attack_jump_chance)), 1);
        
        switch(RandomSelection_chosen_float)
        {
@@ -211,7 +215,7 @@ float knight_attack_ranged()
                        if(findtrajectorywithleading(self.origin, self.mins, self.maxs, self.enemy, 1000, 0, 10, 0, self))
                        {
                                self.velocity = findtrajectory_velocity;
-                               Damage(self.enemy, self, self, autocvar_g_monster_knight_jump_damage * monster_skill, DEATH_MONSTER_KNIGHT_CRUSH, self.enemy.origin, normalize(self.enemy.origin - self.origin));
+                               Damage(self.enemy, self, self, MON_CVAR(knight, attack_jump_damage) * monster_skill, DEATH_MONSTER_KNIGHT_CRUSH, self.enemy.origin, normalize(self.enemy.origin - self.origin));
                                self.attack_finished_single = time + 2;
                                return TRUE;
                        }
@@ -238,7 +242,7 @@ float knight_attack(float attack_type)
                        
                        monsters_setframe(anim);
                        self.attack_finished_single = time + 0.7;
-                       monster_melee(self.enemy, autocvar_g_monster_knight_melee_damage, 0.3, DEATH_MONSTER_KNIGHT_MELEE, TRUE);
+                       monster_melee(self.enemy, MON_CVAR(knight, attack_melee_damage), 0.3, DEATH_MONSTER_KNIGHT_MELEE, TRUE);
                        
                        return TRUE;
                }
@@ -254,8 +258,6 @@ float knight_attack(float attack_type)
 
 void spawnfunc_monster_knight()
 {
-       if not(autocvar_g_monster_knight) { remove(self); return; }
-       
        self.classname = "monster_knight";
        
        self.monster_spawnfunc = spawnfunc_monster_knight;
@@ -275,7 +277,7 @@ float m_knight(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_knight_speed_run, autocvar_g_monster_knight_speed_walk, 100, knight_anim_run, knight_anim_walk, knight_anim_stand);
+                       monster_move(MON_CVAR(knight, speed_run), MON_CVAR(knight, speed_walk), 100, knight_anim_run, knight_anim_walk, knight_anim_stand);
                        return TRUE;
                }
                case MR_DEATH:
@@ -292,7 +294,7 @@ float m_knight(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_knight_health;
+                       if not(self.health) self.health = MON_CVAR(knight, health);
                                
                        self.monster_attackfunc = knight_attack;
                        monsters_setframe(knight_anim_stand);
@@ -304,6 +306,11 @@ float m_knight(float req)
                        precache_sound ("player/lava.wav");
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(KNIGHT_SETTINGS(knight))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index f62892f8d0120549a13ad94afbd64c33c234c343..4a9162a219e1b817ce9d66d207ad7ae8e1600f46 100644 (file)
@@ -9,31 +9,37 @@ REGISTER_MONSTER(
 /* fullname   */ _("Mage")
 );
 
+#define MAGE_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_spike_damage) \
+       MON_ADD_CVAR(monster, attack_spike_radius) \
+       MON_ADD_CVAR(monster, attack_spike_delay) \
+       MON_ADD_CVAR(monster, attack_melee_damage) \
+       MON_ADD_CVAR(monster, attack_melee_delay) \
+       MON_ADD_CVAR(monster, attack_grenade_damage) \
+       MON_ADD_CVAR(monster, attack_grenade_edgedamage) \
+       MON_ADD_CVAR(monster, attack_grenade_force) \
+       MON_ADD_CVAR(monster, attack_grenade_radius) \
+       MON_ADD_CVAR(monster, attack_grenade_lifetime) \
+       MON_ADD_CVAR(monster, attack_grenade_chance) \
+       MON_ADD_CVAR(monster, attack_grenade_speed) \
+       MON_ADD_CVAR(monster, attack_grenade_speed_up) \
+       MON_ADD_CVAR(monster, heal_self) \
+       MON_ADD_CVAR(monster, heal_allies) \
+       MON_ADD_CVAR(monster, heal_minhealth) \
+       MON_ADD_CVAR(monster, heal_range) \
+       MON_ADD_CVAR(monster, heal_delay) \
+       MON_ADD_CVAR(monster, shield_time) \
+       MON_ADD_CVAR(monster, shield_delay) \
+       MON_ADD_CVAR(monster, shield_blockpercent) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+MAGE_SETTINGS(mage)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_mage;
-float autocvar_g_monster_mage_health;
-float autocvar_g_monster_mage_speed;
-float autocvar_g_monster_mage_attack_spike_damage;
-float autocvar_g_monster_mage_attack_spike_radius;
-float autocvar_g_monster_mage_attack_spike_delay;
-float autocvar_g_monster_mage_attack_melee_damage;
-float autocvar_g_monster_mage_attack_melee_delay;
-float autocvar_g_monster_mage_heal_self;
-float autocvar_g_monster_mage_heal_friends;
-float autocvar_g_monster_mage_heal_minhealth;
-float autocvar_g_monster_mage_heal_range;
-float autocvar_g_monster_mage_heal_delay;
-float autocvar_g_monster_mage_shield_time;
-float autocvar_g_monster_mage_shield_delay;
-float autocvar_g_monster_mage_shield_blockpercent;
-float autocvar_g_monster_mage_attack_grenade_damage;
-float autocvar_g_monster_mage_attack_grenade_edgedamage;
-float autocvar_g_monster_mage_attack_grenade_radius;
-float autocvar_g_monster_mage_attack_grenade_lifetime;
-float autocvar_g_monster_mage_attack_grenade_force;
-float autocvar_g_monster_mage_attack_grenade_chance;
-
 const float mage_anim_idle             = 0;
 const float mage_anim_walk             = 1;
 const float mage_anim_attack   = 2;
@@ -51,7 +57,7 @@ float friend_needshelp(entity e)
                return FALSE;
        if(e.health <= 0)
                return FALSE;
-       if(vlen(e.origin - self.origin) > autocvar_g_monster_mage_heal_range)
+       if(vlen(e.origin - self.origin) > MON_CVAR(mage, heal_range))
                return FALSE;
        if(IsDifferentTeam(e, self))
                return FALSE;
@@ -95,7 +101,7 @@ float friend_needshelp(entity e)
 
 void mageattack_melee()
 {
-       monster_melee(self.enemy, autocvar_g_monster_mage_attack_melee_damage, 0.3, DEATH_MONSTER_MAGE, TRUE);
+       monster_melee(self.enemy, MON_CVAR(mage, attack_melee_damage), 0.3, DEATH_MONSTER_MAGE, TRUE);
 }
 
 void mage_grenade_explode()
@@ -103,7 +109,7 @@ void mage_grenade_explode()
        pointparticles(particleeffectnum("explosion_small"), self.origin, '0 0 0', 1);
        
        sound(self, CH_SHOTS, "weapons/grenade_impact.wav", VOL_BASE, ATTN_NORM);
-       RadiusDamage (self, self.realowner, autocvar_g_monster_mage_attack_grenade_damage, autocvar_g_monster_mage_attack_grenade_edgedamage, autocvar_g_monster_mage_attack_grenade_radius, world, autocvar_g_monster_mage_attack_grenade_force, DEATH_MONSTER_MAGE, other);
+       RadiusDamage (self, self.realowner, MON_CVAR(mage, attack_grenade_damage), MON_CVAR(mage, attack_grenade_edgedamage), MON_CVAR(mage, attack_grenade_radius), world, MON_CVAR(mage, attack_grenade_force), DEATH_MONSTER_MAGE, other);
        remove(self);
 }
 
@@ -121,7 +127,7 @@ void mage_throw_itemgrenade()
 {
        makevectors(self.angles);
 
-       W_SetupShot_ProjectileSize (self, '-64 -64 -64', '64 64 64', FALSE, 4, "", CH_WEAPON_A, autocvar_g_monster_mage_attack_grenade_damage);
+       W_SetupShot_ProjectileSize (self, '-64 -64 -64', '64 64 64', FALSE, 4, "", CH_WEAPON_A, MON_CVAR(mage, attack_grenade_damage));
        w_shotdir = v_forward; // no TrueAim for grenades please
 
        entity gren = spawn ();
@@ -134,13 +140,13 @@ void mage_throw_itemgrenade()
        setorigin(gren, w_shotorg);
        setsize(gren, '-64 -64 -64', '64 64 64');
 
-       gren.nextthink = time + autocvar_g_monster_mage_attack_grenade_lifetime;
+       gren.nextthink = time + MON_CVAR(mage, attack_grenade_lifetime);
        gren.think = mage_grenade_explode;
        gren.use = mage_grenade_explode;
        gren.touch = mage_grenade_touch;
 
        gren.missile_flags = MIF_SPLASH | MIF_ARC;
-       W_SETUPPROJECTILEVELOCITY_UP(gren, g_monster_mage_attack_grenade);
+       W_SetupProjectileVelocityEx(gren, w_shotdir, v_up, MON_CVAR(mage, attack_grenade_speed), MON_CVAR(mage, attack_grenade_speed_up), 0, 0, FALSE);
        
        gren.flags = FL_PROJECTILE;
        
@@ -154,7 +160,7 @@ void mage_spike_explode()
        self.event_damage = func_null;
 
        pointparticles(particleeffectnum("explosion_small"), self.origin, '0 0 0', 1);
-       RadiusDamage (self, self.realowner, autocvar_g_monster_mage_attack_spike_damage, autocvar_g_monster_mage_attack_spike_damage * 0.5, autocvar_g_monster_mage_attack_spike_radius, world, 0, DEATH_MONSTER_MAGE, other);
+       RadiusDamage (self, self.realowner, MON_CVAR(mage, attack_spike_damage), MON_CVAR(mage, attack_spike_damage) * 0.5, MON_CVAR(mage, attack_spike_radius), world, 0, DEATH_MONSTER_MAGE, other);
 
        remove (self);
 }
@@ -226,7 +232,7 @@ void mage_heal()
                        switch(self.skin)
                        {
                                case 0:
-                                       if(head.health < autocvar_g_balance_health_regenstable) head.health = bound(0, head.health + autocvar_g_monster_mage_heal_friends, autocvar_g_balance_health_regenstable);
+                                       if(head.health < autocvar_g_balance_health_regenstable) head.health = bound(0, head.health + MON_CVAR(mage, heal_allies), autocvar_g_balance_health_regenstable);
                                        fx = "healing_fx";
                                        break;
                                case 1:
@@ -239,12 +245,12 @@ void mage_heal()
                                case 2:
                                        if(head.armorvalue < autocvar_g_balance_armor_regenstable)
                                        {
-                                               head.armorvalue = bound(0, head.armorvalue + autocvar_g_monster_mage_heal_friends, autocvar_g_balance_armor_regenstable);
+                                               head.armorvalue = bound(0, head.armorvalue + MON_CVAR(mage, heal_allies), autocvar_g_balance_armor_regenstable);
                                                fx = "armorrepair_fx";
                                        }
                                        break;
                                case 3:
-                                       head.health = bound(0, head.health - ((head == self)  ? autocvar_g_monster_mage_heal_self : autocvar_g_monster_mage_heal_friends), autocvar_g_balance_health_regenstable);
+                                       head.health = bound(0, head.health - ((head == self)  ? MON_CVAR(mage, heal_self) : MON_CVAR(mage, heal_allies)), autocvar_g_balance_health_regenstable);
                                        fx = "rage";
                                        break;
                        }
@@ -254,7 +260,7 @@ void mage_heal()
                else
                {
                        pointparticles(particleeffectnum("healing_fx"), head.origin, '0 0 0', 1);
-                       head.health = bound(0, head.health + autocvar_g_monster_mage_heal_friends, head.max_health);
+                       head.health = bound(0, head.health + MON_CVAR(mage, heal_allies), head.max_health);
                        WaypointSprite_UpdateHealth(head.sprite, head.health);
                }
        }
@@ -262,7 +268,7 @@ void mage_heal()
        if(washealed)
        {
                monsters_setframe(mage_anim_attack);
-               self.attack_finished_single = time + autocvar_g_monster_mage_heal_delay;
+               self.attack_finished_single = time + MON_CVAR(mage, heal_delay);
        }
 }
 
@@ -287,7 +293,7 @@ void mage_shield()
 
        shield.owner = self;
        shield.team = self.team;
-       shield.ltime = time + autocvar_g_monster_mage_shield_time;
+       shield.ltime = time + MON_CVAR(mage, shield_time);
        shield.health = 70;
        shield.classname = "shield";
        shield.effects = EF_ADDITIVE;
@@ -302,12 +308,12 @@ void mage_shield()
        
        self.weaponentity = shield;
        
-       self.lastshielded = time + autocvar_g_monster_mage_shield_delay;
+       self.lastshielded = time + MON_CVAR(mage, shield_delay);
        
        monsters_setframe(mage_anim_attack);
        self.attack_finished_single = time + 1;
        
-       self.armorvalue = autocvar_g_monster_mage_shield_blockpercent / 100;
+       self.armorvalue = MON_CVAR(mage, shield_blockpercent) / 100;
 }
 
 float mage_attack(float attack_type)
@@ -317,21 +323,21 @@ float mage_attack(float attack_type)
                case MONSTER_ATTACK_MELEE:
                {
                        monsters_setframe(mage_anim_attack);
-                       self.attack_finished_single = time + autocvar_g_monster_mage_attack_melee_delay;
+                       self.attack_finished_single = time + MON_CVAR(mage, attack_melee_delay);
                        defer(0.2, mageattack_melee);
                        
                        return TRUE;
                }
                case MONSTER_ATTACK_RANGED:
                {
-                       if(random() < autocvar_g_monster_mage_attack_grenade_chance / 100)
+                       if(random() < MON_CVAR(mage, attack_grenade_chance) / 100)
                        {
                                mage_throw_itemgrenade();
                                return TRUE;
                        }
        
                        monsters_setframe(mage_anim_attack);
-                       self.attack_finished_single = time + autocvar_g_monster_mage_attack_spike_delay;
+                       self.attack_finished_single = time + MON_CVAR(mage, attack_spike_delay);
                        defer(0.2, mage_spike);
                        
                        return TRUE;
@@ -343,8 +349,6 @@ float mage_attack(float attack_type)
 
 void spawnfunc_monster_mage()
 {
-       if not(autocvar_g_monster_mage) { remove(self); return; }
-       
        self.classname = "monster_mage";
        
        self.monster_spawnfunc = spawnfunc_monster_mage;
@@ -386,7 +390,7 @@ float m_mage(float req)
                        if(time >= self.weaponentity.ltime)
                                mage_shield_die();
                                
-                       if(self.health < autocvar_g_monster_mage_heal_minhealth || need_help)
+                       if(self.health < MON_CVAR(mage, heal_minhealth) || need_help)
                        if(time >= self.attack_finished_single)
                        if(random() < 0.5)
                                mage_heal();
@@ -397,7 +401,7 @@ float m_mage(float req)
                        if(random() < 0.5)
                                mage_shield();
                        
-                       monster_move(autocvar_g_monster_mage_speed, autocvar_g_monster_mage_speed, 50, mage_anim_walk, mage_anim_run, mage_anim_idle);
+                       monster_move(MON_CVAR(mage, speed_run), MON_CVAR(mage, speed_walk), 50, mage_anim_walk, mage_anim_run, mage_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -407,7 +411,7 @@ float m_mage(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_mage_health;
+                       if not(self.health) self.health = MON_CVAR(mage, health);
                                
                        self.monster_attackfunc = mage_attack;
                        monsters_setframe(mage_anim_walk);
@@ -419,6 +423,11 @@ float m_mage(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(MAGE_SETTINGS(mage))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 54a6ec0c3411f19f12fed033098cc27290adc2c9..50d7f633281ed119bb4e74c872f146f35882c62f 100644 (file)
@@ -9,16 +9,19 @@ REGISTER_MONSTER(
 /* fullname   */ _("Shambler")
 );
 
+#define SHAMBLER_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_smash_damage) \
+       MON_ADD_CVAR(monster, attack_claw_damage) \
+       MON_ADD_CVAR(monster, attack_lightning_damage) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+SHAMBLER_SETTINGS(shambler)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_shambler;
-float autocvar_g_monster_shambler_health;
-float autocvar_g_monster_shambler_damage;
-float autocvar_g_monster_shambler_attack_lightning_damage;
-float autocvar_g_monster_shambler_attack_claw_damage;
-float autocvar_g_monster_shambler_speed_walk;
-float autocvar_g_monster_shambler_speed_run;
-
 const float shambler_anim_stand        = 0;
 const float shambler_anim_walk                 = 1;
 const float shambler_anim_run          = 2;
@@ -31,7 +34,7 @@ const float shambler_anim_death       = 8;
 
 void shambler_smash()
 {
-       monster_melee(self.enemy, autocvar_g_monster_shambler_damage, 0.3, DEATH_MONSTER_SHAMBLER_SMASH, TRUE);
+       monster_melee(self.enemy, MON_CVAR(shambler, attack_smash_damage), 0.3, DEATH_MONSTER_SHAMBLER_SMASH, TRUE);
 }
 
 void shambler_delayedsmash()
@@ -45,7 +48,7 @@ void shambler_swing()
 {
        float r = (random() < 0.5);
        monsters_setframe((r) ? shambler_anim_swingr : shambler_anim_swingl);
-       monster_melee(self.enemy, autocvar_g_monster_shambler_attack_claw_damage, 0.3, DEATH_MONSTER_SHAMBLER_CLAW, TRUE);
+       monster_melee(self.enemy, MON_CVAR(shambler, attack_claw_damage), 0.3, DEATH_MONSTER_SHAMBLER_CLAW, TRUE);
        self.attack_finished_single = time + 0.8;
        if(r)
                defer(0.5, shambler_swing);
@@ -65,7 +68,7 @@ void CastLightning()
 
        traceline (org, self.origin + dir * 1000, TRUE, self);
                
-       FireRailgunBullet (org, org + dir * 1000, autocvar_g_monster_shambler_attack_lightning_damage * monster_skill, 0, 0, 0, 0, 0, DEATH_MONSTER_SHAMBLER_ZAP);
+       FireRailgunBullet (org, org + dir * 1000, MON_CVAR(shambler, attack_lightning_damage) * monster_skill, 0, 0, 0, 0, 0, DEATH_MONSTER_SHAMBLER_ZAP);
        
        // teamcolor / hit beam effect
        //v = WarpZone_UnTransformOrigin(WarpZone_trace_transform, trace_endpos);
@@ -104,8 +107,6 @@ float shambler_attack(float attack_type)
 
 void spawnfunc_monster_shambler()
 {
-       if not(autocvar_g_monster_shambler) { remove(self); return; }
-       
        self.classname = "monster_shambler";
        
        self.monster_spawnfunc = spawnfunc_monster_shambler;
@@ -122,7 +123,7 @@ float m_shambler(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_shambler_speed_run, autocvar_g_monster_shambler_speed_walk, 300, shambler_anim_run, shambler_anim_walk, shambler_anim_stand);
+                       monster_move(MON_CVAR(shambler, speed_run), MON_CVAR(shambler, speed_walk), 300, shambler_anim_run, shambler_anim_walk, shambler_anim_stand);
                        return TRUE;
                }
                case MR_DEATH:
@@ -132,7 +133,7 @@ float m_shambler(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_shambler_health;
+                       if not(self.health) self.health = MON_CVAR(shambler, health);
                                
                        self.monster_attackfunc = shambler_attack;
                        monsters_setframe(shambler_anim_stand);
@@ -145,6 +146,11 @@ float m_shambler(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(SHAMBLER_SETTINGS(shambler))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 5e206f227551ed6d9883a9808c6a3abf26236337..c9eadcc960c422d7bac9411eefc341cc68b54595 100644 (file)
@@ -9,13 +9,17 @@ REGISTER_MONSTER(
 /* fullname   */ _("Slime")
 );
 
+#define SLIME_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_explode_damage) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+SLIME_SETTINGS(slime)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_slime;
-float autocvar_g_monster_slime_health;
-float autocvar_g_monster_slime_speed_walk;
-float autocvar_g_monster_slime_speed_run;
-
 const float slime_anim_walk            = 0;
 const float slime_anim_idle            = 1;
 const float slime_anim_jump            = 2;
@@ -30,7 +34,7 @@ void slime_touch_jump()
        if(other.takedamage)
        if(vlen(self.velocity) > 200)
        {
-               Damage (self, world, world, self.health + self.max_health + 200, DEATH_MONSTER_SLIME, self.origin, '0 0 0');
+               Damage (self, world, world, MON_CVAR(slime, attack_explode_damage), DEATH_MONSTER_SLIME, self.origin, '0 0 0');
                        
                return;
        }
@@ -60,7 +64,7 @@ float slime_attack(float attack_type)
 
 void slime_explode()
 {
-       RadiusDamage(self, self, 250 * monster_skill, 15, 250 * (monster_skill * 0.7), world, 250, DEATH_MONSTER_SLIME, world);
+       RadiusDamage(self, self, MON_CVAR(slime, attack_explode_damage), 15, MON_CVAR(slime, attack_explode_damage) * 0.7, world, 250, DEATH_MONSTER_SLIME, world);
        pointparticles(particleeffectnum("explosion_medium"), self.origin, '0 0 0', 1);
        sound(self, CH_SHOTS, "weapons/rocket_impact.wav", VOL_BASE, ATTN_NORM);
        
@@ -72,7 +76,7 @@ void slime_dead()
        self.health = -100; // gibbed
        slime_explode();
        
-       Monster_CheckDropCvars ("slime"); // TODO: add a special function to drop items after death
+       Monster_CheckDropCvars (self.netname); // TODO: add a special function to drop items after death
        
        self.deadflag = DEAD_DEAD;
        self.think = Monster_Fade;
@@ -81,8 +85,6 @@ void slime_dead()
 
 void spawnfunc_monster_slime()
 {
-       if not(autocvar_g_monster_slime) { remove(self); return; }
-       
        self.classname = "monster_slime";
        
        self.monster_spawnfunc = spawnfunc_monster_slime;
@@ -102,7 +104,7 @@ float m_slime(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_slime_speed_run, autocvar_g_monster_slime_speed_walk, 20, slime_anim_walk, slime_anim_walk, slime_anim_idle);
+                       monster_move(MON_CVAR(slime, speed_run), MON_CVAR(slime, speed_walk), 20, slime_anim_walk, slime_anim_walk, slime_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -121,7 +123,7 @@ float m_slime(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_slime_health;
+                       if not(self.health) self.health = MON_CVAR(slime, health);
                                
                        self.monster_attackfunc = slime_attack;
                        monsters_setframe(slime_anim_idle);
@@ -133,6 +135,11 @@ float m_slime(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(SLIME_SETTINGS(slime))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index cd0e903760f7ca8a03e978a16531dcccc8849df1..2dadb88d8a225a118b97f9ae1fccb0d3c2c21699 100644 (file)
@@ -9,19 +9,24 @@ REGISTER_MONSTER(
 /* fullname   */ _("Spider")
 );
 
+#define SPIDER_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_bite_damage) \
+       MON_ADD_CVAR(monster, attack_bite_delay) \
+       MON_ADD_CVAR(monster, attack_web_damagetime) \
+       MON_ADD_CVAR(monster, attack_web_speed) \
+       MON_ADD_CVAR(monster, attack_web_speed_up) \
+       MON_ADD_CVAR(monster, attack_web_delay) \
+       MON_ADD_CVAR(monster, attack_type) \
+       MON_ADD_CVAR(monster, speed_stop) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+SPIDER_SETTINGS(spider)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_spider;
-float autocvar_g_monster_spider_stopspeed;
-float autocvar_g_monster_spider_attack_leap_delay;
-float autocvar_g_monster_spider_attack_stand_damage;
-float autocvar_g_monster_spider_attack_stand_delay;
-float autocvar_g_monster_spider_attack_fire_time;
-float autocvar_g_monster_spider_health;
-float autocvar_g_monster_spider_speed_walk;
-float autocvar_g_monster_spider_speed_run;
-float autocvar_g_monster_spider_attack_type;
-
 const float spider_anim_idle           = 0;
 const float spider_anim_walk           = 1;
 const float spider_anim_attack         = 2;
@@ -61,7 +66,7 @@ void spider_web_explode()
                                        Freeze(e, 0.3, 2, FALSE);
                                        break;
                                case SPIDER_TYPE_FIRE:
-                                       Fire_AddDamage(e, self.realowner, 5 * monster_skill, autocvar_g_monster_spider_attack_fire_time, DEATH_MONSTER_SPIDER_FIRE);
+                                       Fire_AddDamage(e, self.realowner, 5 * monster_skill, MON_CVAR(spider, attack_web_damagetime), DEATH_MONSTER_SPIDER_FIRE);
                                        break;
                        }
                }
@@ -114,7 +119,7 @@ void spider_shootweb(float ptype)
        //proj.glow_size = 50;
        //proj.glow_color = 45;
        proj.movetype = MOVETYPE_BOUNCE;
-       W_SETUPPROJECTILEVELOCITY_UP(proj, g_monster_spider_attack_web);
+       W_SetupProjectileVelocityEx(proj, w_shotdir, v_up, MON_CVAR(spider, attack_web_speed), MON_CVAR(spider, attack_web_speed_up), 0, 0, FALSE);
        proj.touch = spider_web_touch;
        setsize(proj, fmins, fmaxs);
        proj.takedamage = DAMAGE_NO;
@@ -137,9 +142,9 @@ float spider_attack(float attack_type)
        {
                case MONSTER_ATTACK_MELEE:
                {
-                       monster_melee(self.enemy, autocvar_g_monster_spider_attack_stand_damage, 0.3, DEATH_MONSTER_SPIDER, TRUE);
+                       monster_melee(self.enemy, MON_CVAR(spider, attack_bite_damage), 0.3, DEATH_MONSTER_SPIDER, TRUE);
                        monsters_setframe((random() > 0.5) ? spider_anim_attack : spider_anim_attack2);
-                       self.attack_finished_single = time + autocvar_g_monster_spider_attack_stand_delay;
+                       self.attack_finished_single = time + MON_CVAR(spider, attack_bite_delay);
                        
                        return TRUE;
                }
@@ -149,7 +154,7 @@ float spider_attack(float attack_type)
                                return FALSE;
                        
                        monsters_setframe(spider_anim_attack2);
-                       self.attack_finished_single = time + autocvar_g_monster_spider_attack_leap_delay;
+                       self.attack_finished_single = time + MON_CVAR(spider, attack_web_delay);
                        monster_makevectors(self.enemy);
                        spider_shootweb(self.spider_type);
                        
@@ -162,8 +167,6 @@ float spider_attack(float attack_type)
 
 void spawnfunc_monster_spider() 
 {
-       if not(autocvar_g_monster_spider) { remove(self); return; }
-       
        self.classname = "monster_spider";
        
        self.monster_spawnfunc = spawnfunc_monster_spider;
@@ -180,7 +183,7 @@ float m_spider(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_spider_speed_run, autocvar_g_monster_spider_speed_walk, autocvar_g_monster_spider_stopspeed, spider_anim_walk, spider_anim_walk, spider_anim_idle);
+                       monster_move(MON_CVAR(spider, speed_run), MON_CVAR(spider, speed_walk), MON_CVAR(spider, speed_stop), spider_anim_walk, spider_anim_walk, spider_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -192,8 +195,8 @@ float m_spider(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_spider_health;
-                       if not(self.spider_type) self.spider_type = autocvar_g_monster_spider_attack_type;
+                       if not(self.health) self.health = MON_CVAR(spider, health);
+                       if not(self.spider_type) self.spider_type = MON_CVAR(spider, attack_type);
                                
                        self.monster_attackfunc = spider_attack;
                        monsters_setframe(spider_anim_idle);
@@ -205,6 +208,11 @@ float m_spider(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(SPIDER_SETTINGS(spider))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index d17d3713714f1cb61bea2dba96099d2038ba960e..c93b728facfaec01b59faad1c1d5beeb5a85fa99 100644 (file)
@@ -9,14 +9,19 @@ REGISTER_MONSTER(
 /* fullname   */ _("Stingray")
 );
 
+#define STINGRAY_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_bite_damage) \
+       MON_ADD_CVAR(monster, attack_bite_delay) \
+       MON_ADD_CVAR(monster, speed_stop) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+STINGRAY_SETTINGS(stingray)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_stingray;
-float autocvar_g_monster_stingray_health;
-float autocvar_g_monster_stingray_damage;
-float autocvar_g_monster_stingray_speed_walk;
-float autocvar_g_monster_stingray_speed_run;
-
 const float stingray_anim_attack = 0;
 const float stingray_anim_death  = 1;
 const float stingray_anim_swim   = 2;
@@ -29,8 +34,8 @@ float stingray_attack(float attack_type)
                case MONSTER_ATTACK_MELEE:
                {
                        monsters_setframe(stingray_anim_attack);
-                       self.attack_finished_single = time + 0.5;
-                       monster_melee(self.enemy, autocvar_g_monster_stingray_damage, 0.1, DEATH_MONSTER_STINGRAY, FALSE);
+                       self.attack_finished_single = time + MON_CVAR(stingray, attack_bite_delay);
+                       monster_melee(self.enemy, MON_CVAR(stingray, attack_bite_damage), 0.1, DEATH_MONSTER_STINGRAY, FALSE);
                        
                        return TRUE;
                }
@@ -42,8 +47,6 @@ float stingray_attack(float attack_type)
 
 void spawnfunc_monster_stingray()
 {
-       if not(autocvar_g_monster_stingray) { remove(self); return; }
-       
        self.classname = "monster_stingray";
        
        self.monster_spawnfunc = spawnfunc_monster_stingray;
@@ -60,7 +63,7 @@ float m_stingray(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_stingray_speed_run, autocvar_g_monster_stingray_speed_walk, 10, stingray_anim_swim, stingray_anim_swim, stingray_anim_swim);
+                       monster_move(MON_CVAR(stingray, speed_run), MON_CVAR(stingray, speed_walk), MON_CVAR(stingray, speed_stop), stingray_anim_swim, stingray_anim_swim, stingray_anim_swim);
                        return TRUE;
                }
                case MR_DEATH:
@@ -70,7 +73,7 @@ float m_stingray(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_stingray_health;
+                       if not(self.health) self.health = MON_CVAR(stingray, health);
                                
                        self.monster_attackfunc = stingray_attack;
                        monsters_setframe(stingray_anim_swim);
@@ -82,6 +85,11 @@ float m_stingray(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(STINGRAY_SETTINGS(stingray))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 4087bacca1696d9690124013c6fdbef044893c51..9ca7b66339cdbc1a31c7f9f707852c8566dfc10b 100644 (file)
@@ -9,19 +9,23 @@ REGISTER_MONSTER(
 /* fullname   */ _("Wyvern")
 );
 
+#define WYVERN_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_fireball_damage) \
+       MON_ADD_CVAR(monster, attack_fireball_edgedamage) \
+       MON_ADD_CVAR(monster, attack_fireball_damagetime) \
+       MON_ADD_CVAR(monster, attack_fireball_force) \
+       MON_ADD_CVAR(monster, attack_fireball_radius) \
+       MON_ADD_CVAR(monster, attack_fireball_speed) \
+       MON_ADD_CVAR(monster, speed_stop) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+WYVERN_SETTINGS(wyvern)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_wyvern;
-float autocvar_g_monster_wyvern_health;
-float autocvar_g_monster_wyvern_speed_walk;
-float autocvar_g_monster_wyvern_speed_run;
-float autocvar_g_monster_wyvern_fireball_damage;
-float autocvar_g_monster_wyvern_fireball_force;
-float autocvar_g_monster_wyvern_fireball_radius;
-float autocvar_g_monster_wyvern_fireball_edgedamage;
-float autocvar_g_monster_wyvern_fireball_damagetime;
-float autocvar_g_monster_wyvern_fireball_speed;
-
 const float wyvern_anim_hover  = 0;
 const float wyvern_anim_fly    = 1;
 const float wyvern_anim_magic  = 2;
@@ -35,10 +39,10 @@ void wyvern_fireball_explode()
        {
                pointparticles(particleeffectnum("fireball_explode"), self.origin, '0 0 0', 1);
                
-               RadiusDamage(self, self.realowner, autocvar_g_monster_wyvern_fireball_damage, autocvar_g_monster_wyvern_fireball_edgedamage, autocvar_g_monster_wyvern_fireball_force, world, autocvar_g_monster_wyvern_fireball_radius, self.projectiledeathtype, world);
+               RadiusDamage(self, self.realowner, MON_CVAR(wyvern, attack_fireball_damage), MON_CVAR(wyvern, attack_fireball_edgedamage), MON_CVAR(wyvern, attack_fireball_force), world, MON_CVAR(wyvern, attack_fireball_radius), self.projectiledeathtype, world);
                
-               for(e = world; (e = findfloat(e, takedamage, DAMAGE_AIM)); ) if(vlen(e.origin - self.origin) <= autocvar_g_monster_wyvern_fireball_radius)
-                       Fire_AddDamage(e, self, 5 * monster_skill, autocvar_g_monster_wyvern_fireball_damagetime, self.projectiledeathtype);
+               for(e = world; (e = findfloat(e, takedamage, DAMAGE_AIM)); ) if(vlen(e.origin - self.origin) <= MON_CVAR(wyvern, attack_fireball_radius))
+                       Fire_AddDamage(e, self, 5 * monster_skill, MON_CVAR(wyvern, attack_fireball_damagetime), self.projectiledeathtype);
                
                remove(self);
        }
@@ -65,7 +69,7 @@ void wyvern_fireball()
        setsize(missile, '-6 -6 -6', '6 6 6');          
        setorigin(missile, self.origin + self.view_ofs + v_forward * 14);
        missile.flags = FL_PROJECTILE;
-       missile.velocity = dir * autocvar_g_monster_wyvern_fireball_speed;
+       missile.velocity = dir * MON_CVAR(wyvern, attack_fireball_speed);
        missile.avelocity = '300 300 300';
        missile.nextthink = time + 5;
        missile.think = wyvern_fireball_explode;
@@ -94,8 +98,6 @@ float wyvern_attack(float attack_type)
 
 void spawnfunc_monster_wyvern()
 {
-       if not(autocvar_g_monster_wyvern) { remove(self); return; }
-       
        self.classname = "monster_wyvern";
        
        self.monster_spawnfunc = spawnfunc_monster_wyvern;
@@ -115,7 +117,7 @@ float m_wyvern(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_wyvern_speed_run, autocvar_g_monster_wyvern_speed_walk, 300, wyvern_anim_fly, wyvern_anim_hover, wyvern_anim_hover);
+                       monster_move(MON_CVAR(wyvern, speed_run), MON_CVAR(wyvern, speed_walk), MON_CVAR(wyvern, speed_stop), wyvern_anim_fly, wyvern_anim_hover, wyvern_anim_hover);
                        return TRUE;
                }
                case MR_DEATH:
@@ -128,7 +130,7 @@ float m_wyvern(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_wyvern_health;
+                       if not(self.health) self.health = MON_CVAR(wyvern, health);
                                
                        self.monster_attackfunc = wyvern_attack;
                        monsters_setframe(wyvern_anim_hover);
@@ -140,6 +142,11 @@ float m_wyvern(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(WYVERN_SETTINGS(wyvern))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 24ecd296c6bb9054e4e83328ddf6282370697c3c..d698b4a731124e50144251a7ad1afce6e6f539dd 100644 (file)
@@ -9,20 +9,23 @@ REGISTER_MONSTER(
 /* fullname   */ _("Zombie")
 );
 
+#define ZOMBIE_SETTINGS(monster) \
+       MON_ADD_CVAR(monster, health) \
+       MON_ADD_CVAR(monster, attack_melee_damage) \
+       MON_ADD_CVAR(monster, attack_melee_delay) \
+       MON_ADD_CVAR(monster, attack_leap_damage) \
+       MON_ADD_CVAR(monster, attack_leap_force) \
+       MON_ADD_CVAR(monster, attack_leap_speed) \
+       MON_ADD_CVAR(monster, attack_leap_delay) \
+       MON_ADD_CVAR(monster, speed_stop) \
+       MON_ADD_CVAR(monster, speed_run) \
+       MON_ADD_CVAR(monster, speed_walk) 
+
+#ifdef SVQC
+ZOMBIE_SETTINGS(zombie)
+#endif // SVQC
 #else
 #ifdef SVQC
-float autocvar_g_monster_zombie;
-float autocvar_g_monster_zombie_stopspeed;
-float autocvar_g_monster_zombie_attack_leap_damage;
-float autocvar_g_monster_zombie_attack_leap_delay;
-float autocvar_g_monster_zombie_attack_leap_force;
-float autocvar_g_monster_zombie_attack_leap_speed;
-float autocvar_g_monster_zombie_attack_stand_damage;
-float autocvar_g_monster_zombie_attack_stand_delay;
-float autocvar_g_monster_zombie_health;
-float autocvar_g_monster_zombie_speed_walk;
-float autocvar_g_monster_zombie_speed_run;
-
 const float zombie_anim_attackleap                     = 0;
 const float zombie_anim_attackrun1                     = 1;
 const float zombie_anim_attackrun2                     = 2;
@@ -65,8 +68,8 @@ void zombie_attack_leap_touch()
        if(other.takedamage)
        {
                angles_face = vectoangles(self.moveto - self.origin);
-               angles_face = normalize(angles_face) * autocvar_g_monster_zombie_attack_leap_force;
-               Damage(other, self, self, autocvar_g_monster_zombie_attack_leap_damage * monster_skill, DEATH_MONSTER_ZOMBIE_JUMP, other.origin, angles_face);
+               angles_face = normalize(angles_face) * MON_CVAR(zombie, attack_leap_force);
+               Damage(other, self, self, MON_CVAR(zombie, attack_leap_damage) * monster_skill, DEATH_MONSTER_ZOMBIE_JUMP, other.origin, angles_face);
                self.touch = MonsterTouch; // instantly turn it off to stop damage spam
        }
 
@@ -91,16 +94,16 @@ float zombie_attack(float attack_type)
                                
                        monsters_setframe(chosen_anim);
 
-                       self.attack_finished_single = time + autocvar_g_monster_zombie_attack_stand_delay;
+                       self.attack_finished_single = time + MON_CVAR(zombie, attack_melee_delay);
                        
-                       monster_melee(self.enemy, autocvar_g_monster_zombie_attack_stand_damage, 0.3, DEATH_MONSTER_ZOMBIE_MELEE, TRUE);
+                       monster_melee(self.enemy, MON_CVAR(zombie, attack_melee_damage), 0.3, DEATH_MONSTER_ZOMBIE_MELEE, TRUE);
                        
                        return TRUE;
                }
                case MONSTER_ATTACK_RANGED:
                {
                        makevectors(self.angles);
-                       if(monster_leap(zombie_anim_attackleap, zombie_attack_leap_touch, v_forward * autocvar_g_monster_zombie_attack_leap_speed + '0 0 200', autocvar_g_monster_zombie_attack_leap_delay))
+                       if(monster_leap(zombie_anim_attackleap, zombie_attack_leap_touch, v_forward * MON_CVAR(zombie, attack_leap_speed) + '0 0 200', MON_CVAR(zombie, attack_leap_delay)))
                                return TRUE;
                }
        }
@@ -110,8 +113,6 @@ float zombie_attack(float attack_type)
 
 void spawnfunc_monster_zombie() 
 {
-       if not(autocvar_g_monster_zombie) { remove(self); return; }
-       
        self.classname = "monster_zombie";
        
        self.monster_spawnfunc = spawnfunc_monster_zombie;
@@ -130,7 +131,7 @@ float m_zombie(float req)
        {
                case MR_THINK:
                {
-                       monster_move(autocvar_g_monster_zombie_speed_run, autocvar_g_monster_zombie_speed_walk, autocvar_g_monster_zombie_stopspeed, zombie_anim_runforward, zombie_anim_runforward, zombie_anim_idle);
+                       monster_move(MON_CVAR(zombie, speed_run), MON_CVAR(zombie, speed_walk), MON_CVAR(zombie, speed_stop), zombie_anim_runforward, zombie_anim_runforward, zombie_anim_idle);
                        return TRUE;
                }
                case MR_DEATH:
@@ -140,7 +141,7 @@ float m_zombie(float req)
                }
                case MR_SETUP:
                {
-                       if not(self.health) self.health = autocvar_g_monster_zombie_health;
+                       if not(self.health) self.health = MON_CVAR(zombie, health);
                                
                        self.monster_attackfunc = zombie_attack;
                        monsters_setframe(zombie_anim_spawn);
@@ -155,6 +156,11 @@ float m_zombie(float req)
                        // nothing
                        return TRUE;
                }
+               case MR_CONFIG:
+               {
+                       MON_CONFIG_SETTINGS(ZOMBIE_SETTINGS(zombie))
+                       return TRUE;
+               }
        }
        
        return TRUE;
index 8b5320336fdc710784022fc3c27f197ae1a4d03d..e5750baed198e02e90370fb6fb2bd0fffc77fef3 100644 (file)
@@ -64,24 +64,10 @@ float MON_LAST;
 #define MON_ADD_CVAR(monster,name) \
                MON_DUPECHECK(MON_CVAR_##monster##_##name, autocvar_g_monster_##monster##_##name)
 
-#define MON_CVAR(monster,name) autocvar_g_balance_##monster##_##name
-
-#define MON_ADD_PROP(monster,prop,name) \
-       .float ##prop; \
-       MON_DUPECHECK(MON_CVAR_##monster##_##name, autocvar_g_monster_##monster##_##name)
-
-#define MON_SET_PROP(wepid,monster,prop,name) get_monsterinfo(##wepid).##prop = autocvar_g_monster_##monster##_##name;
-
-#define MON_SET_PROPS(monsettings,wepid) \
-       #define MON_ADD_CVAR(monster,mode,name) \
-       #define MON_ADD_PROP(monster,prop,name) MON_SET_PROP(wepid,monster,prop,name) \
-       monsettings \
-       #undef MON_ADD_CVAR \
-       #undef MON_ADD_PROP
+#define MON_CVAR(monster,name) autocvar_g_monster_##monster##_##name
 
 #include "all.qh"
 
 #undef MON_ADD_CVAR
-#undef MON_ADD_PROP
 #undef REGISTER_MONSTER
 ACCUMULATE_FUNCTION(RegisterMonsters, register_monsters_done)
index 7de6565c3f987b83c914eb7fa32c4d6723cb603f..32b61aac0785b4e260aa8f2d4ed9c0851d2a4d20 100644 (file)
@@ -26,8 +26,11 @@ sys-post.qh
 ../common/command/shared_defs.qh
 ../common/net_notice.qh
 ../common/animdecide.qh
+
+../common/monsters/config.qh
 ../common/monsters/monsters.qh
 
+
 autocvars.qh
 constants.qh
 defs.qh                // Should rename this, it has fields and globals
@@ -234,6 +237,7 @@ round_handler.qc
 
 ../common/explosion_equation.qc
 
+../common/monsters/config.qc
 ../common/monsters/monsters.qc
 
 mutators/base.qc