Skip to content

Commit

Permalink
Implements IsCanRecalcApproachTarget for TechnoTypes.
Browse files Browse the repository at this point in the history
  • Loading branch information
CCHyper committed Sep 22, 2022
1 parent 5c094ae commit 291f00b
Show file tree
Hide file tree
Showing 3 changed files with 72 additions and 0 deletions.
64 changes: 64 additions & 0 deletions src/extensions/foot/footext_hooks.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,11 @@
#include "technoext.h"
#include "technotype.h"
#include "technotypeext.h"
#include "tibsun_inline.h"
#include "house.h"
#include "rules.h"
#include "rulesext.h"
#include "target.h"
#include "fatal.h"
#include "asserthandler.h"
#include "debughandler.h"
Expand All @@ -39,6 +43,65 @@
#include "hooker_macros.h"


/**
* #issue-595
*
* Implements IsCanRecalcApproachTarget for TechnoTypes.
*
* @author: CCHyper
*/
static short NavCom_TarCom_Distance(FootClass *this_ptr) { return Distance(this_ptr->NavCom->Center_Coord(), this_ptr->TarCom->Center_Coord()); }
static int Multiply_Integer(int a, double b) { return (a * b); }
DECLARE_PATCH(_FootClass_Approach_Target_Can_Recalc_Approach_Target_Patch)
{
GET_REGISTER_STATIC(FootClass *, this_ptr, ebp);
GET_REGISTER_STATIC(bool, in_range, bl);
GET_STACK_STATIC(int, maxrange, esp, 0x34);
static TechnoTypeClassExtension *technotypeext;

if (Target_Legal(this_ptr->NavCom)) {

if (Target_Legal(this_ptr->TarCom)) {

technotypeext = TechnoTypeClassExtensions.find(this_ptr->Techno_Type_Class());
if (technotypeext && technotypeext->IsCanRecalcApproachTarget) {

//DEV_DEBUG_INFO("Approach_Target: CanRecalcApproachTarget branch.\n");

if (!in_range) {

static double reset_multiplier = 1.0;
if (RulesExtension) {
reset_multiplier = RulesExtension->ApproachTargetResetMultiplier;
}

if (NavCom_TarCom_Distance(this_ptr) > Multiply_Integer(maxrange, reset_multiplier)) {
DEV_DEBUG_INFO("Approach_Target: Clearing NavCom.\n");
this_ptr->NavCom = nullptr;
}

}

}

}

if (Target_Legal(this_ptr->NavCom)) {
if (!this_ptr->In_Air()) {
goto function_return;
}
}
}

_asm { mov bl, byte ptr [in_range] } // restore BL register.

JMP(0x004A2004);

function_return:
JMP(0x004A2813);
}


/**
* #issue-595
*
Expand Down Expand Up @@ -335,4 +398,5 @@ void FootClassExtension_Hooks()
Patch_Jump(0x004A1AAE, &_FootClass_Mission_Guard_Can_Passive_Acquire_Patch);
Patch_Jump(0x004A102F, &_FootClass_Mission_Move_Can_Passive_Acquire_Patch);
Patch_Jump(0x004A1EA8, &_FootClass_Approach_Target_Can_Approach_Patch);
Patch_Jump(0x004A1FEA, &_FootClass_Approach_Target_Can_Recalc_Approach_Target_Patch);
}
2 changes: 2 additions & 0 deletions src/extensions/technotype/technotypeext.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ TechnoTypeClassExtension::TechnoTypeClassExtension(TechnoTypeClass *this_ptr) :
IsCanPassiveAcquire(true),
IsCanRetaliate(true),
IsCanApproachTarget(true),
IsCanRecalcApproachTarget(true),
ShakePixelYHi(0),
ShakePixelYLo(0),
ShakePixelXHi(0),
Expand Down Expand Up @@ -261,6 +262,7 @@ bool TechnoTypeClassExtension::Read_INI(CCINIClass &ini)
IsCanPassiveAcquire = ini.Get_Bool(ini_name, "CanPassiveAcquire", IsCanPassiveAcquire);
IsCanRetaliate = ini.Get_Bool(ini_name, "CanRetaliate", IsCanRetaliate);
IsCanApproachTarget = ini.Get_Bool(ini_name, "CanApproachTarget", IsCanApproachTarget);
IsCanRecalcApproachTarget = ini.Get_Bool(ini_name, "CanRecalcApproachTarget", IsCanRecalcApproachTarget);
ShakePixelYHi = ini.Get_Int(ini_name, "ShakeYhi", ShakePixelYHi);
ShakePixelYLo = ini.Get_Int(ini_name, "ShakeYlo", ShakePixelYLo);
ShakePixelXHi = ini.Get_Int(ini_name, "ShakeXhi", ShakePixelXHi);
Expand Down
6 changes: 6 additions & 0 deletions src/extensions/technotype/technotypeext.h
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,12 @@ class TechnoTypeClassExtension final : public Extension<TechnoTypeClass>
*/
bool IsCanApproachTarget;

/**
* Can this unit recalculate what its next target will be when conducting
* its threat scan if its current target is out of range?
*/
bool IsCanRecalcApproachTarget;

/**
* These values are used to shake the screen when the object is destroyed.
*/
Expand Down

0 comments on commit 291f00b

Please sign in to comment.