From d00a9375083831447c0cba78eba61d11f0d9dad1 Mon Sep 17 00:00:00 2001 From: s1lent Date: Thu, 6 Jun 2019 04:20:19 +0700 Subject: [PATCH] Implemented cvars ff_damage_reduction_bullets, ff_damage_reduction_grenade, ff_damage_reduction_grenade_self, ff_damage_reduction_other Resolves #297 --- README.md | 76 ++++++++++++++++++++------------------- dist/game.cfg | 24 +++++++++++++ regamedll/dlls/game.cpp | 10 ++++++ regamedll/dlls/game.h | 4 +++ regamedll/dlls/player.cpp | 25 +++++++++++-- 5 files changed, 100 insertions(+), 39 deletions(-) diff --git a/README.md b/README.md index 4247ee5b..a96da283 100644 --- a/README.md +++ b/README.md @@ -19,42 +19,46 @@ Archive's bin directory contains 2 subdirectories, 'bugfixed' and 'pure' Warning! ReGameDLL_CS is not binary compatible with original hlds since it's compiled with compilers other than ones used for original mod CS. This means that plugins that do binary code analysis (Orpheu for example) probably will not work with ReGameDLL_CS. ## Configuration (cvars) -| CVar | Default | Min | Max | Description | -| :---------------------------- | :-----: | :-: | :----------: | :--------------------------------------------- | -| mp_freeforall | 0 | 0 | 1 | The style of gameplay where there aren't any teams (FFA mode)
`0` disabled
`1` enabled | -| mp_autoteambalance | 1 | 0 | 2 | Auto balancing of teams.
`0` disabled
`1` on after next round
`2` on next round | -| mp_buytime | 1.5 | 0.0 | - | Designate the desired amount of buy time for each round. (in minutes)
`-1` means no time limit
`0` disable buy | -| mp_maxmoney | 16000 | 0 | `999999` | The maximum allowable amount of money in the game | -| mp_round_infinite | 0 | 0 | 1 | Flags for fine grained control (choose as many as needed)
`0` disabled
`1` enabled

or flags
`a` block round time round end check
`b` block needed players round end check
`c` block VIP assassination/success round end check
`d` block prison escape round end check
`e` block bomb round end check
`f` block team extermination round end check
`g` block hostage rescue round end check

`Example setting:` "ae" blocks round time and bomb round end checks | -| mp_roundover | 0 | - | - | The round by expired time will be over, if on a map it does not have the scenario of the game.
`0` disabled
`1` enabled | -| mp_round_restart_delay | 5 | - | - | Number of seconds to delay before restarting a round after a win. | -| mp_hegrenade_penetration | 0 | 0 | 1 | Disable grenade damage through walls.
`0` disabled
`1` enabled | -| mp_nadedrops | 0 | 0 | 2 | Drop a grenade after player death.
`0` disabled
`1` drop one the grenade
`2` drop an everyone grenades | -| mp_roundrespawn_time | 20 | 0 | - | Player cannot respawn until next round if more than N seconds has elapsed since the beginning round | -| mp_auto_reload_weapons | 0 | 0 | 1 | Automatically reload each weapon on player spawn.
`0` disabled
`1` enabled | -| mp_refill_bpammo_weapons | 0 | 0 | 3 | Refill amount of backpack ammo up to the max.
`0` disabled
`1` refill backpack ammo on player spawn
`2` refill backpack ammo on player spawn and on the purchase of the item
`3` refill backpack ammo on each weapon reload | -| mp_auto_join_team | 0 | 0 | 1 | Automatically joins the team.
`0` disabled
`1` enable (Use in conjunction with the cvar humans_join_team any/CT/T) | -| mp_max_teamkills | 3 | 0 | - | Maximum number of allowed teamkills before autokick. Used when enabled mp_autokick. | -| mp_fragsleft | - | - | - | Is the number of frags left, if you have set mp_fraglimit. You just type mp_fragsleft in server console, and it tells you the number of frags left depending of mp_fraglimit. | -| mp_fraglimit | 0 | 0 | - | If set to something other than 0, when anybody’s scored reaches mp_fraglimit the server changes map.
`0` means no limit | -| mp_timeleft | - | - | - | Is the number of time left before the map changes, if you have set mp_timelimit. You just type mp_timeleft in server console, and it tells you the number of time left depending of mp_timelimit. | -| mp_timelimit | 0 | - | - | Period between map rotations.
`0` means no limit | -| mp_forcerespawn | 0 | 0 | - | Players will automatically respawn when killed.
`0` disabled
`>0.00001` time delay to respawn | -| mp_hostage_hurtable | 1 | 0 | 1 | The hostages can take damage.
`0` disabled
`1` from any team
`2` only from `CT`
`3` only from `T` | -| mp_show_radioicon | 1 | 0 | 1 | Show radio icon.
`0` disabled
`1` enabled | -| mp_old_bomb_defused_sound | 1 | 0 | 1 | Play "Bomb has been defused" sound instead of "Counter-Terrorists win" when bomb was defused
`0` disabled
`1` enabled | -| showtriggers | 0 | 0 | 1 | Debug cvar shows triggers. | -| sv_alltalk | 0 | 0 | 4 | When players can hear each other ([further explanation](../../wiki/sv_alltalk)).
`0` dead don't hear alive
`1` no restrictions
`2` teammates hear each other
`3` Same as 2, but spectators hear everybody
`4` alive hear alive, dead hear dead and alive. -| bot_deathmatch | 0 | 0 | 1 | Set's the mode for the zBot.
`0` disabled
`1` enable mode Deathmatch and not allow to do the scenario | -| bot_quota_mode | normal | - | - | Determines the type of quota.
`normal` default behaviour
`fill` the server will adjust bots to keep `N` players in the game, where `N` is bot_quota | -| mp_item_staytime | 300 | - | - | Time to remove item that have been dropped from the players. | -| mp_legacy_bombtarget_touch | 1 | 0 | 1 | Legacy func_bomb_target touch. New one is more strict.
`0` New behavior
`1` Legacy behavior| -| mp_respawn_immunitytime | 0 | 0 | - | Specifies the players defense time after respawn. (in seconds).
`0` disabled
`>0.00001` time delay to remove protection | -| mp_kill_filled_spawn | 1 | 0 | 1 | Kill the player in filled spawn before spawning some one else (Prevents players stucking in each other).
Only disable this if you have semiclip or other plugins that prevents stucking.
`0` disabled
`1` enabled | -| mp_allow_point_servercommand | 0 | 0 | 1 | Allow use of point_servercommand entities in map.
`0` disallow
`1` allow
`NOTE`: Potentially dangerous for untrusted maps.| -| mp_hullbounds_sets | 1 | 0 | 1 | Sets mins/maxs hull bounds for the player.
`0` disabled
`1` enabled | -| mp_scoreboard_showhealth | 3 | 0 | 5 | Show `HP` field into a scoreboard.
`0` don't send any update for `HP` field to any clients
`1` show only Terrorist `HP` field to all clients
`2` show only CT `HP` field to all clients
`3` show `HP` field to teammates
`4` show `HP` field to all clients
`5` show `HP` field to teammates and spectators | -| mp_scoreboard_showmoney | 3 | 0 | 5 | Show `Money` field into a scoreboard.
`0` don't send any update for `Money` field to any clients
`1` show only Terrorist `Money` field to all clients
`2` show only CT `Money` field to all clients
`3` show `Money` field to teammates
`4` show `Money` field to all clients
`5` show `Money` field to teammates and spectators | +| CVar | Default | Min | Max | Description | +| :--------------------------------- | :-----: | :-: | :----------: | :--------------------------------------------- | +| mp_freeforall | 0 | 0 | 1 | The style of gameplay where there aren't any teams (FFA mode)
`0` disabled
`1` enabled | +| mp_autoteambalance | 1 | 0 | 2 | Auto balancing of teams.
`0` disabled
`1` on after next round
`2` on next round | +| mp_buytime | 1.5 | 0.0 | - | Designate the desired amount of buy time for each round. (in minutes)
`-1` means no time limit
`0` disable buy | +| mp_maxmoney | 16000 | 0 | `999999` | The maximum allowable amount of money in the game | +| mp_round_infinite | 0 | 0 | 1 | Flags for fine grained control (choose as many as needed)
`0` disabled
`1` enabled

or flags
`a` block round time round end check
`b` block needed players round end check
`c` block VIP assassination/success round end check
`d` block prison escape round end check
`e` block bomb round end check
`f` block team extermination round end check
`g` block hostage rescue round end check

`Example setting:` "ae" blocks round time and bomb round end checks | +| mp_roundover | 0 | - | - | The round by expired time will be over, if on a map it does not have the scenario of the game.
`0` disabled
`1` enabled | +| mp_round_restart_delay | 5 | - | - | Number of seconds to delay before restarting a round after a win. | +| mp_hegrenade_penetration | 0 | 0 | 1 | Disable grenade damage through walls.
`0` disabled
`1` enabled | +| mp_nadedrops | 0 | 0 | 2 | Drop a grenade after player death.
`0` disabled
`1` drop one the grenade
`2` drop an everyone grenades | +| mp_roundrespawn_time | 20 | 0 | - | Player cannot respawn until next round if more than N seconds has elapsed since the beginning round | +| mp_auto_reload_weapons | 0 | 0 | 1 | Automatically reload each weapon on player spawn.
`0` disabled
`1` enabled | +| mp_refill_bpammo_weapons | 0 | 0 | 3 | Refill amount of backpack ammo up to the max.
`0` disabled
`1` refill backpack ammo on player spawn
`2` refill backpack ammo on player spawn and on the purchase of the item
`3` refill backpack ammo on each weapon reload | +| mp_auto_join_team | 0 | 0 | 1 | Automatically joins the team.
`0` disabled
`1` enable (Use in conjunction with the cvar humans_join_team any/CT/T) | +| mp_max_teamkills | 3 | 0 | - | Maximum number of allowed teamkills before autokick. Used when enabled mp_autokick. | +| mp_fragsleft | - | - | - | Is the number of frags left, if you have set mp_fraglimit. You just type mp_fragsleft in server console, and it tells you the number of frags left depending of mp_fraglimit. | +| mp_fraglimit | 0 | 0 | - | If set to something other than 0, when anybody’s scored reaches mp_fraglimit the server changes map.
`0` means no limit | +| mp_timeleft | - | - | - | Is the number of time left before the map changes, if you have set mp_timelimit. You just type mp_timeleft in server console, and it tells you the number of time left depending of mp_timelimit. | +| mp_timelimit | 0 | - | - | Period between map rotations.
`0` means no limit | +| mp_forcerespawn | 0 | 0 | - | Players will automatically respawn when killed.
`0` disabled
`>0.00001` time delay to respawn | +| mp_hostage_hurtable | 1 | 0 | 1 | The hostages can take damage.
`0` disabled
`1` from any team
`2` only from `CT`
`3` only from `T` | +| mp_show_radioicon | 1 | 0 | 1 | Show radio icon.
`0` disabled
`1` enabled | +| mp_old_bomb_defused_sound | 1 | 0 | 1 | Play "Bomb has been defused" sound instead of "Counter-Terrorists win" when bomb was defused
`0` disabled
`1` enabled | +| showtriggers | 0 | 0 | 1 | Debug cvar shows triggers. | +| sv_alltalk | 0 | 0 | 4 | When players can hear each other ([further explanation](../../wiki/sv_alltalk)).
`0` dead don't hear alive
`1` no restrictions
`2` teammates hear each other
`3` Same as 2, but spectators hear everybody
`4` alive hear alive, dead hear dead and alive. +| bot_deathmatch | 0 | 0 | 1 | Set's the mode for the zBot.
`0` disabled
`1` enable mode Deathmatch and not allow to do the scenario | +| bot_quota_mode | normal | - | - | Determines the type of quota.
`normal` default behaviour
`fill` the server will adjust bots to keep `N` players in the game, where `N` is bot_quota | +| mp_item_staytime | 300 | - | - | Time to remove item that have been dropped from the players. | +| mp_legacy_bombtarget_touch | 1 | 0 | 1 | Legacy func_bomb_target touch. New one is more strict.
`0` New behavior
`1` Legacy behavior| +| mp_respawn_immunitytime | 0 | 0 | - | Specifies the players defense time after respawn. (in seconds).
`0` disabled
`>0.00001` time delay to remove protection | +| mp_kill_filled_spawn | 1 | 0 | 1 | Kill the player in filled spawn before spawning some one else (Prevents players stucking in each other).
Only disable this if you have semiclip or other plugins that prevents stucking.
`0` disabled
`1` enabled | +| mp_allow_point_servercommand | 0 | 0 | 1 | Allow use of point_servercommand entities in map.
`0` disallow
`1` allow
`NOTE`: Potentially dangerous for untrusted maps.| +| mp_hullbounds_sets | 1 | 0 | 1 | Sets mins/maxs hull bounds for the player.
`0` disabled
`1` enabled | +| mp_scoreboard_showhealth | 3 | 0 | 5 | Show `HP` field into a scoreboard.
`0` don't send any update for `HP` field to any clients
`1` show only Terrorist `HP` field to all clients
`2` show only CT `HP` field to all clients
`3` show `HP` field to teammates
`4` show `HP` field to all clients
`5` show `HP` field to teammates and spectators | +| mp_scoreboard_showmoney | 3 | 0 | 5 | Show `Money` field into a scoreboard.
`0` don't send any update for `Money` field to any clients
`1` show only Terrorist `Money` field to all clients
`2` show only CT `Money` field to all clients
`3` show `Money` field to teammates
`4` show `Money` field to all clients
`5` show `Money` field to teammates and spectators | +| ff_damage_reduction_bullets | 0.35 | 0.0 | 1.0 | How much to reduce damage done to teammates when shot.
Range is from `0` - `1` (with 1 being damage equal to what is done to an enemy) | +| ff_damage_reduction_grenade | 0.25 | 0.0 | 1.0 | How much to reduce damage done to teammates by a thrown grenade.
Range is from `0` - `1` (with 1 being damage equal to what is done to an enemy) | +| ff_damage_reduction_grenade_self | 1.0 | 0.0 | 1.0 | How much to damage a player does to himself with his own grenade.
Range is from `0` - `1` (with 1 being damage equal to what is done to an enemy) | +| ff_damage_reduction_other | 0.25 | 0.0 | 1.0 | How much to reduce damage done to teammates by things other than bullets and grenades.
Range is from `0` - `1` (with 1 being damage equal to what is done to an enemy) | ## How to install zBot for CS 1.6? * Extract all the files from an [archive](regamedll/extra/zBot/bot_profiles.zip?raw=true) diff --git a/dist/game.cfg b/dist/game.cfg index f58b2bc2..b93c3b58 100644 --- a/dist/game.cfg +++ b/dist/game.cfg @@ -229,3 +229,27 @@ mp_scoreboard_showhealth "3" // 5 - show 'Money' field to teammates and spectators // Default value: "3" mp_scoreboard_showmoney "3" + +// How much to reduce damage done to teammates when shot. +// Range is from 0 - 1 (with 1 being damage equal to what is done to an enemy) +// +// Default value: "0.35" +ff_damage_reduction_bullets "0.35" + +// How much to reduce damage done to teammates by a thrown grenade. +// Range is from 0 - 1 (with 1 being damage equal to what is done to an enemy) +// +// Default value: "0.25" +ff_damage_reduction_grenade "0.25" + +// How much to damage a player does to himself with his own grenade +// Range is from 0 - 1 (with 1 being damage equal to what is done to an enemy) +// +// Default value: "1.0" +ff_damage_reduction_grenade_self "1.0" + +// How much to reduce damage done to teammates by things other than bullets and grenades. +// Range is from 0 - 1 (with 1 being damage equal to what is done to an enemy) +// +// Default value: "0.25" +ff_damage_reduction_other "0.25" diff --git a/regamedll/dlls/game.cpp b/regamedll/dlls/game.cpp index 785e2832..09faaffe 100644 --- a/regamedll/dlls/game.cpp +++ b/regamedll/dlls/game.cpp @@ -125,6 +125,11 @@ cvar_t hullbounds_sets = { "mp_hullbounds_sets", "1", 0, 0.0f, nullptr cvar_t scoreboard_showmoney = { "mp_scoreboard_showmoney", "3", FCVAR_SERVER, 0.0f, nullptr }; cvar_t scoreboard_showhealth = { "mp_scoreboard_showhealth", "3", FCVAR_SERVER, 0.0f, nullptr }; +cvar_t ff_damage_reduction_bullets = { "ff_damage_reduction_bullets", "0.35", FCVAR_SERVER, 0.0f, nullptr }; +cvar_t ff_damage_reduction_grenade = { "ff_damage_reduction_grenade", "0.25", FCVAR_SERVER, 0.0f, nullptr }; +cvar_t ff_damage_reduction_grenade_self = { "ff_damage_reduction_grenade_self", "1", FCVAR_SERVER, 0.0f, nullptr }; +cvar_t ff_damage_reduction_other = { "ff_damage_reduction_other", "0.25", FCVAR_SERVER, 0.0f, nullptr }; + void GameDLL_Version_f() { if (Q_stricmp(CMD_ARGV(1), "version") != 0) @@ -302,6 +307,11 @@ void EXT_FUNC GameDLLInit() CVAR_REGISTER(&allow_point_servercommand); CVAR_REGISTER(&hullbounds_sets); + CVAR_REGISTER(&ff_damage_reduction_bullets); + CVAR_REGISTER(&ff_damage_reduction_grenade); + CVAR_REGISTER(&ff_damage_reduction_grenade_self); + CVAR_REGISTER(&ff_damage_reduction_other); + // print version CONSOLE_ECHO("ReGameDLL version: " APP_VERSION "\n"); diff --git a/regamedll/dlls/game.h b/regamedll/dlls/game.h index 7ff0b727..c7ce2458 100644 --- a/regamedll/dlls/game.h +++ b/regamedll/dlls/game.h @@ -157,6 +157,10 @@ extern cvar_t respawn_immunitytime; extern cvar_t kill_filled_spawn; extern cvar_t allow_point_servercommand; extern cvar_t hullbounds_sets; +extern cvar_t ff_damage_reduction_bullets; +extern cvar_t ff_damage_reduction_grenade; +extern cvar_t ff_damage_reduction_grenade_self; +extern cvar_t ff_damage_reduction_other; #endif diff --git a/regamedll/dlls/player.cpp b/regamedll/dlls/player.cpp index b406a230..d9cc7049 100644 --- a/regamedll/dlls/player.cpp +++ b/regamedll/dlls/player.cpp @@ -861,6 +861,10 @@ BOOL EXT_FUNC CBasePlayer::__API_HOOK(TakeDamage)(entvars_t *pevInflictor, entva bTeamAttack = TRUE; pAttack = CBasePlayer::Instance(pevAttacker); + + flDamage *= clamp((pAttack == this) ? + ff_damage_reduction_grenade_self.value : + ff_damage_reduction_grenade.value, 0.0f, 1.0f); } #ifdef REGAMEDLL_ADD else if (CSGameRules()->IsFreeForAll()) @@ -868,9 +872,18 @@ BOOL EXT_FUNC CBasePlayer::__API_HOOK(TakeDamage)(entvars_t *pevInflictor, entva pAttack = CBasePlayer::Instance(pevAttacker); } #endif - else if (pGrenade->m_iTeam == m_iTeam && (&edict()->v != pevAttacker)) + else if (pGrenade->m_iTeam == m_iTeam) { - return FALSE; + // if cvar friendlyfire is disabled + // and if the victim is teammate then ignore this damage + if (&edict()->v != pevAttacker) + { + return FALSE; + } + +#ifdef REGAMEDLL_ADD + flDamage *= clamp(ff_damage_reduction_grenade_self.value, 0.0f, 1.0f); +#endif } } } @@ -1054,8 +1067,14 @@ BOOL EXT_FUNC CBasePlayer::__API_HOOK(TakeDamage)(entvars_t *pevInflictor, entva if (!bAttackFFA && pAttack->m_iTeam == m_iTeam) { +#ifdef REGAMEDLL_ADD // bullets hurt teammates less + flDamage *= clamp((bitsDamageType & DMG_BULLET) ? + ff_damage_reduction_bullets.value : + ff_damage_reduction_other.value, 0.0f, 1.0f); +#else flDamage *= 0.35; +#endif // #ifdef REGAMEDLL_ADD } if (pAttack->m_pActiveItem) @@ -7199,7 +7218,7 @@ bool EXT_FUNC CBasePlayer::__API_HOOK(HintMessageEx)(const char *pMessage, float bool EXT_FUNC CBasePlayer::HintMessage(const char *pMessage, BOOL bDisplayIfPlayerDead, BOOL bOverride) { - return HintMessageEx(pMessage, 6.0f, bDisplayIfPlayerDead, bOverride); + return HintMessageEx(pMessage, 6.0f, bDisplayIfPlayerDead == TRUE, bOverride == TRUE); } Vector CBasePlayer::GetAutoaimVector(float flDelta)