From a96ef5276dd2f22d651f677e67b04bff3467ab61 Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Sun, 14 May 2017 12:26:31 -0400 Subject: [PATCH 01/10] - Added new flags8 actor field. Isn't it frightening how quickly how we got to our 8th flag field? - Speaking of frightening, added +FRIGHTENING flag. --- src/actor.h | 7 +++++++ src/p_actionfunctions.cpp | 1 + src/p_enemy.cpp | 5 +++-- src/p_mobj.cpp | 4 ++++ src/scripting/thingdef_data.cpp | 2 ++ src/scripting/thingdef_properties.cpp | 1 + 6 files changed, 18 insertions(+), 2 deletions(-) diff --git a/src/actor.h b/src/actor.h index 17a7a6a8a..043f07ae5 100644 --- a/src/actor.h +++ b/src/actor.h @@ -398,6 +398,10 @@ enum ActorFlag7 MF7_FORCEINFIGHTING = 0x40000000, // overrides a map setting of 'no infighting'. MF7_SPRITEFLIP = 0x80000000, // sprite flipped on x-axis }; +enum ActorFlag8 +{ + MF8_FRIGHTENING = 0x00000001, // for those moments when halloween just won't do +}; // --- mobj.renderflags --- enum ActorRenderFlag @@ -517,6 +521,7 @@ typedef TFlags ActorFlags4; typedef TFlags ActorFlags5; typedef TFlags ActorFlags6; typedef TFlags ActorFlags7; +typedef TFlags ActorFlags8; typedef TFlags ActorRenderFlags; typedef TFlags ActorBounceFlags; DEFINE_TFLAGS_OPERATORS (ActorFlags) @@ -526,6 +531,7 @@ DEFINE_TFLAGS_OPERATORS (ActorFlags4) DEFINE_TFLAGS_OPERATORS (ActorFlags5) DEFINE_TFLAGS_OPERATORS (ActorFlags6) DEFINE_TFLAGS_OPERATORS (ActorFlags7) +DEFINE_TFLAGS_OPERATORS (ActorFlags8) DEFINE_TFLAGS_OPERATORS (ActorRenderFlags) DEFINE_TFLAGS_OPERATORS (ActorBounceFlags) @@ -1022,6 +1028,7 @@ public: ActorFlags5 flags5; // OMG! We need another one. ActorFlags6 flags6; // Shit! Where did all the flags go? ActorFlags7 flags7; // WHO WANTS TO BET ON 8!? + ActorFlags8 flags8; // I see your 8, and raise you a bet for 9. double Floorclip; // value to use for floor clipping double radius, Height; // for movement checking diff --git a/src/p_actionfunctions.cpp b/src/p_actionfunctions.cpp index 838c885e6..51c37f23d 100644 --- a/src/p_actionfunctions.cpp +++ b/src/p_actionfunctions.cpp @@ -3765,6 +3765,7 @@ DEFINE_ACTION_FUNCTION(AActor, A_Respawn) self->flags5 = defs->flags5; self->flags6 = defs->flags6; self->flags7 = defs->flags7; + self->flags8 = defs->flags8; self->SetState (self->SpawnState); self->renderflags &= ~RF_INVISIBLE; diff --git a/src/p_enemy.cpp b/src/p_enemy.cpp index 3aefe7b9f..076e5772a 100644 --- a/src/p_enemy.cpp +++ b/src/p_enemy.cpp @@ -996,7 +996,8 @@ void P_NewChaseDir(AActor * actor) if (!(actor->flags6 & MF6_NOFEAR)) { if ((actor->target->player != NULL && (actor->target->player->cheats & CF_FRIGHTENING)) || - (actor->flags4 & MF4_FRIGHTENED)) + (actor->flags4 & MF4_FRIGHTENED) || + (actor->target->flags8 & MF8_FRIGHTENING)) { delta = -delta; } @@ -2655,7 +2656,7 @@ void A_DoChase (AActor *actor, bool fastchase, FState *meleestate, FState *missi // [RH] Scared monsters attack less frequently if (((actor->target->player == NULL || - !(actor->target->player->cheats & CF_FRIGHTENING)) && + !((actor->target->player->cheats & CF_FRIGHTENING) || (actor->target->flags8 & MF8_FRIGHTENING))) && !(actor->flags4 & MF4_FRIGHTENED)) || pr_scaredycat() < 43) { diff --git a/src/p_mobj.cpp b/src/p_mobj.cpp index b87d37fd6..2e16347db 100644 --- a/src/p_mobj.cpp +++ b/src/p_mobj.cpp @@ -407,6 +407,7 @@ void AActor::Serialize(FSerializer &arc) A("flags5", flags5) A("flags6", flags6) A("flags7", flags7) + A("flags8", flags8) A("weaponspecial", weaponspecial) A("special1", special1) A("special2", special2) @@ -8394,6 +8395,9 @@ void PrintMiscActorInfo(AActor *query) Printf("\n flags7: %x", query->flags7.GetValue()); for (flagi = 0; flagi <= 31; flagi++) if (query->flags7 & ActorFlags7::FromInt(1<flags8.GetValue()); + for (flagi = 0; flagi <= 31; flagi++) + if (query->flags8 & ActorFlags8::FromInt(1<BounceFlags.GetValue(), query->bouncefactor, query->wallbouncefactor); diff --git a/src/scripting/thingdef_data.cpp b/src/scripting/thingdef_data.cpp index 0c3962c7d..f62ba0c88 100644 --- a/src/scripting/thingdef_data.cpp +++ b/src/scripting/thingdef_data.cpp @@ -324,6 +324,8 @@ static FFlagDef ActorFlagDefs[]= DEFINE_FLAG(MF7, FORCEINFIGHTING, AActor, flags7), DEFINE_FLAG(MF7, SPRITEFLIP, AActor, flags7), + DEFINE_FLAG(MF8, FRIGHTENING, AActor, flags8), + // Effect flags DEFINE_FLAG(FX, VISIBILITYPULSE, AActor, effects), DEFINE_FLAG2(FX_ROCKET, ROCKETTRAIL, AActor, effects), diff --git a/src/scripting/thingdef_properties.cpp b/src/scripting/thingdef_properties.cpp index c948d05e3..170fa1148 100644 --- a/src/scripting/thingdef_properties.cpp +++ b/src/scripting/thingdef_properties.cpp @@ -989,6 +989,7 @@ DEFINE_PROPERTY(clearflags, 0, Actor) defaults->flags5 = 0; defaults->flags6 = 0; defaults->flags7 = 0; + defaults->flags8 = 0; } //========================================================================== From 6bbbd28a08184c1138ba3f8fbc8b8ac51b9bbaa9 Mon Sep 17 00:00:00 2001 From: Major Cooke Date: Mon, 15 May 2017 10:03:05 -0500 Subject: [PATCH 02/10] - Added missing LAXTELEFRAGDMG support to SelfDamageFactor. --- src/p_interaction.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/p_interaction.cpp b/src/p_interaction.cpp index 069967a7f..e0ebfbcdb 100644 --- a/src/p_interaction.cpp +++ b/src/p_interaction.cpp @@ -963,7 +963,7 @@ static int DamageMobj (AActor *target, AActor *inflictor, AActor *source, int da } return 0; } - if (target == source && damage < TELEFRAG_DAMAGE) + if (target == source && (!telefragDamage || target->flags7 & MF7_LAXTELEFRAGDMG)) { damage = int(damage * target->SelfDamageFactor); } From b1a8ef54f6726992b171ab8a4a7ddcb9142eadcf Mon Sep 17 00:00:00 2001 From: Major Cooke Date: Mon, 15 May 2017 06:02:28 -0500 Subject: [PATCH 03/10] - Fixed bitwise comparison. --- src/p_interaction.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/p_interaction.cpp b/src/p_interaction.cpp index e0ebfbcdb..351ba47ec 100644 --- a/src/p_interaction.cpp +++ b/src/p_interaction.cpp @@ -1360,7 +1360,7 @@ static int DamageMobj (AActor *target, AActor *inflictor, AActor *source, int da // but telefragging should still do enough damage to kill the player) // Ignore players that are already dead. // [MC]Buddha2 absorbs telefrag damage, and anything else thrown their way. - if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA|CF_POWERBUDDHA) || (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) + if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA) || (player->cheats & CF_POWERBUDDHA) || (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) { // If this is a voodoo doll we need to handle the real player as well. player->mo->health = target->health = player->health = 1; From fe023b5ca4bb1fb0332d4a42b97957f27803b20a Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Tue, 16 May 2017 01:44:38 -0400 Subject: [PATCH 04/10] - changed Buddha powerup from a flag to an inventory check --- src/namedef.h | 1 + src/p_interaction.cpp | 2 +- src/p_lnspec.cpp | 5 +++-- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/namedef.h b/src/namedef.h index f4f9a22c8..db492c1b2 100644 --- a/src/namedef.h +++ b/src/namedef.h @@ -207,6 +207,7 @@ xx(QuestItem28) xx(QuestItem29) xx(PowerDoubleFiringSpeed) xx(PowerInfiniteAmmo) +xx(PowerBuddha) xx(AcolyteBlue) xx(SpectralLightningV1) diff --git a/src/p_interaction.cpp b/src/p_interaction.cpp index 351ba47ec..1ccae9a8c 100644 --- a/src/p_interaction.cpp +++ b/src/p_interaction.cpp @@ -1360,7 +1360,7 @@ static int DamageMobj (AActor *target, AActor *inflictor, AActor *source, int da // but telefragging should still do enough damage to kill the player) // Ignore players that are already dead. // [MC]Buddha2 absorbs telefrag damage, and anything else thrown their way. - if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA) || (player->cheats & CF_POWERBUDDHA) || (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) + if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA) || (player->mo->FindInventory (PClass::FindActor(NAME_PowerBuddha),true) != nullptr) || (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) { // If this is a voodoo doll we need to handle the real player as well. player->mo->health = target->health = player->health = 1; diff --git a/src/p_lnspec.cpp b/src/p_lnspec.cpp index 130ea00f3..368a8a776 100644 --- a/src/p_lnspec.cpp +++ b/src/p_lnspec.cpp @@ -2873,7 +2873,7 @@ FUNC(LS_SetPlayerProperty) // Add or remove a power if (arg2 >= PROP_INVULNERABILITY && arg2 <= PROP_SPEED) { - static ENamedName powers[13] = + static ENamedName powers[14] = { NAME_PowerInvulnerable, NAME_PowerStrength, @@ -2887,7 +2887,8 @@ FUNC(LS_SetPlayerProperty) NAME_None, NAME_PowerSpeed, NAME_PowerInfiniteAmmo, - NAME_PowerDoubleFiringSpeed + NAME_PowerDoubleFiringSpeed, + NAME_PowerBuddha }; int power = arg2 - PROP_INVULNERABILITY; From c6946cc672640cdd4ea9f0c9b7b4c1d9a32e7f5a Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Tue, 16 May 2017 01:57:37 -0400 Subject: [PATCH 05/10] - removed all instances of CF_POWERBUDDHA --- src/d_player.h | 1 - src/p_interaction.cpp | 8 ++++++-- src/p_lnspec.cpp | 2 +- src/p_user.cpp | 3 ++- 4 files changed, 9 insertions(+), 5 deletions(-) diff --git a/src/d_player.h b/src/d_player.h index 509f089d9..7d8dbf380 100644 --- a/src/d_player.h +++ b/src/d_player.h @@ -211,7 +211,6 @@ typedef enum CF_BUDDHA2 = 1 << 24, // [MC] Absolute buddha. No voodoo can kill it either. CF_GODMODE2 = 1 << 25, // [MC] Absolute godmode. No voodoo can kill it either. CF_BUDDHA = 1 << 27, // [SP] Buddha mode - take damage, but don't die - CF_POWERBUDDHA = 1 << 28, // [MC] Powerup version of Buddha to prevent interference with actual cheat. CF_NOCLIP2 = 1 << 30, // [RH] More Quake-like noclip } cheat_t; diff --git a/src/p_interaction.cpp b/src/p_interaction.cpp index 1ccae9a8c..7a6bb3ffa 100644 --- a/src/p_interaction.cpp +++ b/src/p_interaction.cpp @@ -1360,7 +1360,9 @@ static int DamageMobj (AActor *target, AActor *inflictor, AActor *source, int da // but telefragging should still do enough damage to kill the player) // Ignore players that are already dead. // [MC]Buddha2 absorbs telefrag damage, and anything else thrown their way. - if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA) || (player->mo->FindInventory (PClass::FindActor(NAME_PowerBuddha),true) != nullptr) || (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) + if (!(flags & DMG_FORCED) && (((player->cheats & CF_BUDDHA2) || (((player->cheats & CF_BUDDHA) || + (player->mo->FindInventory (PClass::FindActor(NAME_PowerBuddha),true) != nullptr) || + (player->mo->flags7 & MF7_BUDDHA)) && !telefragDamage)) && (player->playerstate != PST_DEAD))) { // If this is a voodoo doll we need to handle the real player as well. player->mo->health = target->health = player->health = 1; @@ -1896,7 +1898,9 @@ void P_PoisonDamage (player_t *player, AActor *source, int damage, bool playPain target->health -= damage; if (target->health <= 0) { // Death - if ((((player->cheats & CF_BUDDHA|CF_POWERBUDDHA) || (player->mo->flags7 & MF7_BUDDHA)) && damage < TELEFRAG_DAMAGE) || (player->cheats & CF_BUDDHA2)) + if ((((player->cheats & CF_BUDDHA) || + (player->mo->flags7 & MF7_BUDDHA)) && damage < TELEFRAG_DAMAGE) || (player->cheats & CF_BUDDHA2) || + (player->mo->FindInventory (PClass::FindActor(NAME_PowerBuddha),true) != nullptr)) { // [SP] Save the player... player->health = target->health = 1; } diff --git a/src/p_lnspec.cpp b/src/p_lnspec.cpp index 368a8a776..001b39be8 100644 --- a/src/p_lnspec.cpp +++ b/src/p_lnspec.cpp @@ -2978,7 +2978,7 @@ FUNC(LS_SetPlayerProperty) switch (arg2) { case PROP_BUDDHA: - mask = CF_POWERBUDDHA; + mask = CF_BUDDHA; break; case PROP_FROZEN: mask = CF_FROZEN; diff --git a/src/p_user.cpp b/src/p_user.cpp index f01ea08ae..54a0acbaa 100644 --- a/src/p_user.cpp +++ b/src/p_user.cpp @@ -2156,7 +2156,8 @@ void P_FallingDamage (AActor *actor) { S_Sound (actor, CHAN_AUTO, "*land", 1, ATTN_NORM); P_NoiseAlert (actor, actor, true); - if (damage >= TELEFRAG_DAMAGE && (actor->player->cheats & (CF_GODMODE | CF_BUDDHA | CF_POWERBUDDHA ))) + if (damage >= TELEFRAG_DAMAGE && ((actor->player->cheats & (CF_GODMODE | CF_BUDDHA) || + (actor->FindInventory(PClass::FindActor(NAME_PowerBuddha), true) != nullptr)))) { damage = 999; } From 8192ad73bd98cef275ded34b063016264e67f4e9 Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Tue, 16 May 2017 01:58:39 -0400 Subject: [PATCH 06/10] - changed fall damage so it is max 'TELEFRAG_DAMAGE - 1' instead of a flat 999 (it used to check for >=1000). --- src/p_user.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/p_user.cpp b/src/p_user.cpp index 54a0acbaa..4d9ed3af2 100644 --- a/src/p_user.cpp +++ b/src/p_user.cpp @@ -2159,7 +2159,7 @@ void P_FallingDamage (AActor *actor) if (damage >= TELEFRAG_DAMAGE && ((actor->player->cheats & (CF_GODMODE | CF_BUDDHA) || (actor->FindInventory(PClass::FindActor(NAME_PowerBuddha), true) != nullptr)))) { - damage = 999; + damage = TELEFRAG_DAMAGE - 1; } } P_DamageMobj (actor, NULL, NULL, damage, NAME_Falling); From a93efb1e9efff7a4d9056c7c6bf86a374a66238f Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Tue, 16 May 2017 02:04:54 -0400 Subject: [PATCH 07/10] - slightly increase source code readability by moving a flag from one line to another. --- src/p_interaction.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/p_interaction.cpp b/src/p_interaction.cpp index 7a6bb3ffa..f9c027c35 100644 --- a/src/p_interaction.cpp +++ b/src/p_interaction.cpp @@ -1898,8 +1898,8 @@ void P_PoisonDamage (player_t *player, AActor *source, int damage, bool playPain target->health -= damage; if (target->health <= 0) { // Death - if ((((player->cheats & CF_BUDDHA) || - (player->mo->flags7 & MF7_BUDDHA)) && damage < TELEFRAG_DAMAGE) || (player->cheats & CF_BUDDHA2) || + if ((((player->cheats & CF_BUDDHA) || (player->cheats & CF_BUDDHA2) || + (player->mo->flags7 & MF7_BUDDHA)) && damage < TELEFRAG_DAMAGE) || (player->mo->FindInventory (PClass::FindActor(NAME_PowerBuddha),true) != nullptr)) { // [SP] Save the player... player->health = target->health = 1; From 625fc73f288b26191a178d1575954a46f28bc191 Mon Sep 17 00:00:00 2001 From: Rachael Alexanderson Date: Tue, 16 May 2017 04:10:46 -0400 Subject: [PATCH 08/10] - Missed a few CF_POWERBUDDHA references. --- wadsrc/static/zscript/constants.txt | 1 - wadsrc/static/zscript/inventory/powerups.txt | 20 -------------------- 2 files changed, 21 deletions(-) diff --git a/wadsrc/static/zscript/constants.txt b/wadsrc/static/zscript/constants.txt index 2d2be8ff7..5477d24ee 100644 --- a/wadsrc/static/zscript/constants.txt +++ b/wadsrc/static/zscript/constants.txt @@ -1114,7 +1114,6 @@ enum EPlayerCheats CF_BUDDHA2 = 1 << 24, // [MC] Absolute buddha. No voodoo can kill it either. CF_GODMODE2 = 1 << 25, // [MC] Absolute godmode. No voodoo can kill it either. CF_BUDDHA = 1 << 27, // [SP] Buddha mode - take damage, but don't die - CF_POWERBUDDHA = 1 << 28, // [MC] Powerup version of Buddha to prevent interference with actual cheat. CF_NOCLIP2 = 1 << 30, // [RH] More Quake-like noclip // These flags no longer exist, but keep the names for some stray mod that might have used them. diff --git a/wadsrc/static/zscript/inventory/powerups.txt b/wadsrc/static/zscript/inventory/powerups.txt index cf0dc2106..055fd518f 100644 --- a/wadsrc/static/zscript/inventory/powerups.txt +++ b/wadsrc/static/zscript/inventory/powerups.txt @@ -1450,26 +1450,6 @@ class PowerBuddha : Powerup { Powerup.Duration -60; } - - override void InitEffect () - { - Super.InitEffect(); - - if (Owner== null || Owner.player == null) - return; - - Owner.player.cheats |= CF_POWERBUDDHA; - } - - override void EndEffect () - { - Super.EndEffect(); - - if (Owner== null || Owner.player == null) - return; - - Owner.player.cheats &= ~CF_POWERBUDDHA; - } } //=========================================================================== From a92f889e447baa68cdf292acc11defba2a26489c Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Tue, 16 May 2017 16:39:07 +0300 Subject: [PATCH 09/10] Fixed recently introduced compilation warnings src\v_video.cpp(1771): warning C4244: '=': conversion from 'double' to 'int', possible loss of data src\v_video.cpp(1773): warning C4244: '=': conversion from 'double' to 'int', possible loss of data --- src/v_video.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/v_video.cpp b/src/v_video.cpp index a3c7d3878..44f634d00 100644 --- a/src/v_video.cpp +++ b/src/v_video.cpp @@ -1768,9 +1768,9 @@ void ScaleWithAspect (int &w, int &h, int Width, int Height) } double y = w/yratio; if (y > h) - w = h*yratio; + w = static_cast(h * yratio); else - h = y; + h = static_cast(y); } void IVideo::DumpAdapters () From ebf3a37394caea0029d0be3a1e68dfca33ecfbbe Mon Sep 17 00:00:00 2001 From: svdijk Date: Tue, 16 May 2017 22:32:37 +0200 Subject: [PATCH 10/10] Menu: Fix mouse handling for the autoaim slider. --- wadsrc/static/zscript/menu/playercontrols.txt | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/wadsrc/static/zscript/menu/playercontrols.txt b/wadsrc/static/zscript/menu/playercontrols.txt index b0f97cdbc..b5bd7c79e 100644 --- a/wadsrc/static/zscript/menu/playercontrols.txt +++ b/wadsrc/static/zscript/menu/playercontrols.txt @@ -363,6 +363,7 @@ class ListMenuItemSlider : ListMenuItemSelectable int mMinrange, mMaxrange; int mStep; int mSelection; + int mDrawX; //============================================================================= // @@ -380,6 +381,7 @@ class ListMenuItemSlider : ListMenuItemSelectable mMinrange = min; mMaxrange = max; mStep = step; + mDrawX = 0; } //============================================================================= @@ -398,6 +400,7 @@ class ListMenuItemSlider : ListMenuItemSelectable mMinrange = min; mMaxrange = max; mStep = step; + mDrawX = 0; } //============================================================================= @@ -466,8 +469,8 @@ class ListMenuItemSlider : ListMenuItemSelectable lm.ReleaseFocus(); } - int slide_left = SmallFont.StringWidth ("Green") + 8 + int(mXpos); - int slide_right = slide_left + 12*8; // 12 char cells with 8 pixels each. + int slide_left = mDrawX + 8; + int slide_right = slide_left + 10*8; // 12 char cells with 8 pixels each. if (type == Menu.MOUSE_Click) { @@ -520,6 +523,8 @@ class ListMenuItemSlider : ListMenuItemSelectable double x = SmallFont.StringWidth ("Green") + 8 + mXpos; double x2 = SmallFont.StringWidth (text) + 8 + mXpos; - DrawSlider (MAX(x2, x), mYpos); + mDrawX = MAX(x2, x); + + DrawSlider (mDrawX, mYpos); } } \ No newline at end of file