warscript 0.0.1-dev.724bf08 → 0.0.1-dev.72f8823

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. package/attributes.d.ts +6 -0
  2. package/attributes.lua +17 -1
  3. package/config.d.ts +5 -0
  4. package/config.lua +10 -0
  5. package/core/types/effect.d.ts +2 -3
  6. package/core/types/effect.lua +95 -48
  7. package/core/types/frame.lua +24 -21
  8. package/core/types/player.d.ts +15 -0
  9. package/core/types/player.lua +56 -14
  10. package/core/types/playerCamera.d.ts +2 -0
  11. package/core/types/playerCamera.lua +123 -5
  12. package/core/types/sound.d.ts +17 -24
  13. package/core/types/sound.lua +99 -24
  14. package/core/types/tileCell.d.ts +11 -1
  15. package/core/types/tileCell.lua +97 -0
  16. package/core/types/timer.d.ts +9 -8
  17. package/core/types/timer.lua +45 -23
  18. package/core/util.d.ts +1 -1
  19. package/core/util.lua +12 -1
  20. package/decl/native.d.ts +846 -790
  21. package/engine/behavior.d.ts +12 -1
  22. package/engine/behavior.lua +172 -70
  23. package/engine/behaviour/ability/always-enabled.d.ts +7 -0
  24. package/engine/behaviour/ability/always-enabled.lua +31 -0
  25. package/engine/behaviour/ability/apply-buff.d.ts +5 -0
  26. package/engine/behaviour/ability/apply-buff.lua +32 -0
  27. package/engine/behaviour/ability/apply-unit-behavior.lua +1 -0
  28. package/engine/behaviour/ability/damage.d.ts +9 -3
  29. package/engine/behaviour/ability/damage.lua +26 -38
  30. package/engine/behaviour/ability/emulate-impact.d.ts +1 -1
  31. package/engine/behaviour/ability/emulate-impact.lua +22 -9
  32. package/engine/behaviour/ability/on-command-impact.lua +7 -0
  33. package/engine/behaviour/ability/remove-buffs.d.ts +9 -0
  34. package/engine/behaviour/ability/remove-buffs.lua +21 -0
  35. package/engine/behaviour/ability/restore-mana.d.ts +1 -1
  36. package/engine/behaviour/ability/restore-mana.lua +6 -6
  37. package/engine/behaviour/ability.d.ts +13 -3
  38. package/engine/behaviour/ability.lua +78 -24
  39. package/engine/behaviour/unit/stun-immunity.d.ts +11 -5
  40. package/engine/behaviour/unit/stun-immunity.lua +53 -28
  41. package/engine/behaviour/unit.d.ts +38 -2
  42. package/engine/behaviour/unit.lua +216 -6
  43. package/engine/buff.d.ts +66 -44
  44. package/engine/buff.lua +330 -225
  45. package/engine/internal/ability.d.ts +18 -2
  46. package/engine/internal/ability.lua +116 -11
  47. package/engine/internal/item/ability.lua +162 -4
  48. package/engine/internal/item+owner.lua +12 -6
  49. package/engine/internal/item.d.ts +20 -19
  50. package/engine/internal/item.lua +191 -74
  51. package/engine/internal/mechanics/ability-duration.lua +1 -1
  52. package/engine/internal/misc/ability-disable-counter.d.ts +2 -0
  53. package/engine/internal/misc/ability-disable-counter.lua +13 -0
  54. package/engine/internal/misc/damage-metadata-by-target.d.ts +2 -0
  55. package/engine/internal/misc/damage-metadata-by-target.lua +5 -0
  56. package/engine/internal/misc/frame-coordinates.d.ts +2 -0
  57. package/engine/internal/misc/frame-coordinates.lua +21 -0
  58. package/engine/internal/misc/get-terrain-z.d.ts +2 -0
  59. package/engine/internal/misc/get-terrain-z.lua +11 -0
  60. package/engine/internal/misc/player-local-handle.d.ts +2 -0
  61. package/engine/internal/misc/player-local-handle.lua +5 -0
  62. package/engine/internal/object-data/auto-attack-speed-increase.d.ts +1 -1
  63. package/engine/internal/object-data/auto-attack-speed-increase.lua +2 -0
  64. package/engine/internal/object-data/evasion-probability.d.ts +2 -0
  65. package/engine/internal/object-data/evasion-probability.lua +16 -0
  66. package/engine/internal/unit/ability.d.ts +35 -0
  67. package/engine/internal/unit/ability.lua +98 -9
  68. package/engine/internal/unit/add-item-to-slot-init.d.ts +2 -0
  69. package/engine/internal/unit/add-item-to-slot-init.lua +23 -0
  70. package/engine/internal/unit/add-item-to-slot.d.ts +2 -0
  71. package/engine/internal/unit/add-item-to-slot.lua +52 -0
  72. package/engine/internal/unit/allowed-targets.d.ts +1 -1
  73. package/engine/internal/unit/allowed-targets.lua +9 -1
  74. package/engine/internal/unit/bonus.d.ts +2 -0
  75. package/engine/internal/unit/bonus.lua +17 -0
  76. package/engine/internal/unit/fly-height.d.ts +7 -0
  77. package/engine/internal/unit/fly-height.lua +20 -0
  78. package/engine/internal/unit/ignore-events-items.d.ts +2 -0
  79. package/engine/internal/unit/ignore-events-items.lua +5 -0
  80. package/engine/internal/unit/item.lua +6 -12
  81. package/engine/internal/unit/main-selected.lua +12 -27
  82. package/engine/internal/unit/order.d.ts +20 -0
  83. package/engine/internal/unit/order.lua +136 -0
  84. package/engine/internal/unit/scale.d.ts +7 -0
  85. package/engine/internal/unit/scale.lua +20 -0
  86. package/engine/internal/unit+ability.lua +10 -1
  87. package/engine/internal/unit+damage.d.ts +2 -11
  88. package/engine/internal/unit+damage.lua +10 -14
  89. package/engine/internal/unit+spellSteal.lua +1 -2
  90. package/engine/internal/unit-missile-launch.lua +45 -14
  91. package/engine/internal/unit.d.ts +45 -18
  92. package/engine/internal/unit.lua +391 -175
  93. package/engine/internal/utility.lua +12 -0
  94. package/engine/lightning.d.ts +12 -5
  95. package/engine/lightning.lua +48 -14
  96. package/engine/local-client.d.ts +2 -0
  97. package/engine/local-client.lua +30 -0
  98. package/engine/object-data/auxiliary/animation-name.d.ts +1 -0
  99. package/engine/object-data/auxiliary/animation-name.lua +16 -0
  100. package/engine/object-data/auxiliary/armor-type.d.ts +11 -0
  101. package/engine/object-data/auxiliary/armor-type.lua +46 -0
  102. package/engine/object-data/auxiliary/attachment-preset.d.ts +7 -2
  103. package/engine/object-data/auxiliary/attachment-preset.lua +4 -3
  104. package/engine/object-data/auxiliary/attack-type.d.ts +7 -8
  105. package/engine/object-data/auxiliary/attack-type.lua +42 -0
  106. package/engine/object-data/auxiliary/movement-type.d.ts +7 -7
  107. package/engine/object-data/auxiliary/movement-type.lua +22 -0
  108. package/engine/object-data/auxiliary/sound-eax.d.ts +10 -0
  109. package/engine/object-data/auxiliary/sound-eax.lua +2 -0
  110. package/engine/object-data/auxiliary/tech-tree-dependency.d.ts +1 -1
  111. package/engine/object-data/auxiliary/unit-attribute.d.ts +6 -0
  112. package/engine/object-data/auxiliary/unit-attribute.lua +9 -0
  113. package/engine/object-data/entry/ability-type/berserk.d.ts +2 -0
  114. package/engine/object-data/entry/ability-type/berserk.lua +13 -0
  115. package/engine/object-data/entry/ability-type/blank-configurable.lua +12 -1
  116. package/engine/object-data/entry/ability-type/carrion-swarm.d.ts +14 -0
  117. package/engine/object-data/entry/ability-type/carrion-swarm.lua +65 -0
  118. package/engine/object-data/entry/ability-type/disease-cloud.lua +2 -2
  119. package/engine/object-data/entry/ability-type/engineering-upgrade.lua +2 -2
  120. package/engine/object-data/entry/ability-type/ensnare.d.ts +12 -0
  121. package/engine/object-data/entry/ability-type/ensnare.lua +52 -0
  122. package/engine/object-data/entry/ability-type/feral-spirit.lua +2 -2
  123. package/engine/object-data/entry/ability-type/permanent-invisibility.d.ts +8 -0
  124. package/engine/object-data/entry/ability-type/permanent-invisibility.lua +26 -0
  125. package/engine/object-data/entry/ability-type/phase-shift.d.ts +10 -0
  126. package/engine/object-data/entry/ability-type/phase-shift.lua +39 -0
  127. package/engine/object-data/entry/ability-type/phoenix-morph.lua +4 -4
  128. package/engine/object-data/entry/ability-type/raise-dead.d.ts +17 -0
  129. package/engine/object-data/entry/ability-type/raise-dead.lua +78 -0
  130. package/engine/object-data/entry/ability-type/shock-wave.d.ts +4 -0
  131. package/engine/object-data/entry/ability-type/shock-wave.lua +26 -0
  132. package/engine/object-data/entry/ability-type/slow-poison.d.ts +10 -0
  133. package/engine/object-data/entry/ability-type/slow-poison.lua +58 -0
  134. package/engine/object-data/entry/ability-type/summon-quilbeast.lua +2 -2
  135. package/engine/object-data/entry/ability-type/summon-water-elemental.lua +2 -2
  136. package/engine/object-data/entry/ability-type/web.d.ts +12 -0
  137. package/engine/object-data/entry/ability-type/web.lua +52 -0
  138. package/engine/object-data/entry/ability-type.d.ts +19 -17
  139. package/engine/object-data/entry/ability-type.lua +93 -36
  140. package/engine/object-data/entry/buff-type/applicable.lua +18 -37
  141. package/engine/object-data/entry/buff-type.d.ts +6 -12
  142. package/engine/object-data/entry/buff-type.lua +13 -29
  143. package/engine/object-data/entry/destructible-type.d.ts +1 -1
  144. package/engine/object-data/entry/item-type.d.ts +3 -1
  145. package/engine/object-data/entry/item-type.lua +15 -2
  146. package/engine/object-data/entry/lightning-type.d.ts +1 -1
  147. package/engine/object-data/entry/sound-preset.d.ts +33 -0
  148. package/engine/object-data/entry/sound-preset.lua +140 -0
  149. package/engine/object-data/entry/unit-type.d.ts +21 -5
  150. package/engine/object-data/entry/unit-type.lua +214 -93
  151. package/engine/object-data/entry/upgrade.d.ts +1 -1
  152. package/engine/object-data/entry/upgrade.lua +4 -4
  153. package/engine/object-data/entry.d.ts +16 -14
  154. package/engine/object-data/entry.lua +60 -32
  155. package/engine/object-data/utility/object-data-entry-id-generator.lua +7 -0
  156. package/engine/object-field/ability.d.ts +8 -5
  157. package/engine/object-field/ability.lua +8 -4
  158. package/engine/object-field/unit.d.ts +69 -3
  159. package/engine/object-field/unit.lua +264 -7
  160. package/engine/object-field.d.ts +23 -6
  161. package/engine/object-field.lua +311 -124
  162. package/engine/random.d.ts +9 -0
  163. package/engine/random.lua +13 -0
  164. package/engine/standard/entries/buff-type.d.ts +3 -0
  165. package/engine/standard/entries/buff-type.lua +3 -0
  166. package/engine/standard/entries/sound-preset.d.ts +10 -0
  167. package/engine/standard/entries/sound-preset.lua +10 -0
  168. package/engine/standard/fields/unit.d.ts +6 -0
  169. package/engine/standard/fields/unit.lua +11 -0
  170. package/engine/synchronization.d.ts +11 -0
  171. package/engine/synchronization.lua +77 -0
  172. package/engine/text-tag.d.ts +36 -2
  173. package/engine/text-tag.lua +250 -10
  174. package/engine/unit.d.ts +4 -0
  175. package/engine/unit.lua +4 -0
  176. package/net/socket.lua +1 -1
  177. package/objutil/buff.lua +2 -3
  178. package/objutil/unit.lua +8 -0
  179. package/package.json +2 -2
  180. package/patch-lualib.lua +1 -1
  181. package/utility/arrays.d.ts +2 -0
  182. package/utility/arrays.lua +11 -0
  183. package/utility/callback-array.d.ts +17 -0
  184. package/utility/callback-array.lua +61 -0
  185. package/utility/functions.d.ts +8 -0
  186. package/utility/functions.lua +13 -0
  187. package/utility/linked-set.d.ts +2 -0
  188. package/utility/linked-set.lua +22 -1
  189. package/utility/lua-maps.d.ts +15 -2
  190. package/utility/lua-maps.lua +53 -2
  191. package/utility/lua-sets.d.ts +2 -0
  192. package/utility/lua-sets.lua +7 -0
  193. package/utility/reflection.lua +11 -7
  194. package/utility/types.d.ts +3 -0
  195. package/core/types/order.d.ts +0 -25
  196. package/core/types/order.lua +0 -55
@@ -1,30 +1,43 @@
1
1
  local ____lualib = require("lualib_bundle")
2
2
  local __TS__Class = ____lualib.__TS__Class
3
3
  local __TS__ClassExtends = ____lualib.__TS__ClassExtends
4
+ local __TS__InstanceOf = ____lualib.__TS__InstanceOf
4
5
  local ____exports = {}
5
6
  local ____ability = require("engine.behaviour.ability")
6
7
  local AbilityBehavior = ____ability.AbilityBehavior
8
+ local ____unit = require("engine.internal.unit")
9
+ local Unit = ____unit.Unit
7
10
  local ____ability = require("engine.standard.fields.ability")
8
11
  local COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD = ____ability.COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD
9
12
  local MANA_COST_ABILITY_INTEGER_LEVEL_FIELD = ____ability.MANA_COST_ABILITY_INTEGER_LEVEL_FIELD
13
+ local ____math = require("math")
14
+ local max = ____math.max
15
+ local MINIMUM_POSITIVE_NORMALIZED_FLOAT = ____math.MINIMUM_POSITIVE_NORMALIZED_FLOAT
16
+ local ____sound = require("core.types.sound")
17
+ local Sound3D = ____sound.Sound3D
18
+ local SoundSettings = ____sound.SoundSettings
19
+ local ____ability = require("engine.internal.ability")
20
+ local UnitAbility = ____ability.UnitAbility
21
+ local ____event = require("event")
22
+ local Event = ____event.Event
10
23
  ____exports.EmulateImpactAbilityBehavior = __TS__Class()
11
24
  local EmulateImpactAbilityBehavior = ____exports.EmulateImpactAbilityBehavior
12
25
  EmulateImpactAbilityBehavior.name = "EmulateImpactAbilityBehavior"
13
26
  __TS__ClassExtends(EmulateImpactAbilityBehavior, AbilityBehavior)
14
27
  function EmulateImpactAbilityBehavior.prototype.emulateImpact(self, caster)
15
- local abilityTypeId = self.ability.typeId
16
28
  local manaCost = self:resolveCurrentAbilityDependentValue(MANA_COST_ABILITY_INTEGER_LEVEL_FIELD)
17
29
  local cooldown = self:resolveCurrentAbilityDependentValue(COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD)
18
- if caster:getAbilityRemainingCooldown(abilityTypeId) ~= 0 or caster.mana < manaCost then
19
- return
30
+ if self.ability.cooldownRemaining ~= 0 or caster.mana < manaCost or __TS__InstanceOf(self.ability, UnitAbility) and self.ability.isDisabled then
31
+ return false
20
32
  end
21
33
  caster.mana = caster.mana - manaCost
22
- if cooldown == 0 then
23
- caster:interruptCast(self.ability.typeId)
24
- else
25
- caster:startAbilityCooldown(self.ability.typeId, cooldown)
26
- end
34
+ self.ability.cooldownRemaining = max(cooldown, MINIMUM_POSITIVE_NORMALIZED_FLOAT)
27
35
  self:flashCasterEffect(caster)
28
- AbilityBehavior:forAll(self.ability, "onImpact", caster)
36
+ local soundPresetId = self.ability:getField(ABILITY_SF_EFFECT_SOUND)
37
+ if soundPresetId ~= "" then
38
+ Sound3D:playFromLabel(soundPresetId, SoundSettings.Ability, caster)
39
+ end
40
+ Event.invoke(Unit.abilityImpactEvent, caster, self.ability)
41
+ return true
29
42
  end
30
43
  return ____exports
@@ -2,6 +2,8 @@ local ____lualib = require("lualib_bundle")
2
2
  local __TS__Class = ____lualib.__TS__Class
3
3
  local __TS__ClassExtends = ____lualib.__TS__ClassExtends
4
4
  local ____exports = {}
5
+ local ____unit = require("engine.internal.unit")
6
+ local Unit = ____unit.Unit
5
7
  local ____emulate_2Dimpact = require("engine.behaviour.ability.emulate-impact")
6
8
  local EmulateImpactAbilityBehavior = ____emulate_2Dimpact.EmulateImpactAbilityBehavior
7
9
  ____exports.OnCommandImpactAbilityBehavior = __TS__Class()
@@ -15,4 +17,9 @@ end
15
17
  function OnCommandImpactAbilityBehavior.prototype.onCommand(self, caster)
16
18
  self:emulateImpact(caster)
17
19
  end
20
+ Unit.itemUseOrderEvent:addListener(function(unit, item)
21
+ for ____, ability in ipairs(item.abilities) do
22
+ ____exports.OnCommandImpactAbilityBehavior:forAll(ability, "onCommand", unit)
23
+ end
24
+ end)
18
25
  return ____exports
@@ -14,3 +14,12 @@ export declare class RemoveBuffsSelfAbilityBehavior extends AbilityBehavior {
14
14
  constructor(ability: Ability, polarity?: AbilityDependentValue<BuffPolarity> | undefined, resistanceType?: AbilityDependentValue<BuffResistanceType> | undefined, includeExpirationTimers?: AbilityDependentValue<boolean> | undefined, includeAuras?: AbilityDependentValue<boolean> | undefined, autoDispel?: AbilityDependentValue<boolean> | undefined);
15
15
  onImpact(caster: Unit): void;
16
16
  }
17
+ export declare class RemoveBuffsTargetAbilityBehavior extends AbilityBehavior {
18
+ private readonly polarity?;
19
+ private readonly resistanceType?;
20
+ private readonly includeExpirationTimers?;
21
+ private readonly includeAuras?;
22
+ private readonly autoDispel?;
23
+ constructor(ability: Ability, polarity?: AbilityDependentValue<BuffPolarity> | undefined, resistanceType?: AbilityDependentValue<BuffResistanceType> | undefined, includeExpirationTimers?: AbilityDependentValue<boolean> | undefined, includeAuras?: AbilityDependentValue<boolean> | undefined, autoDispel?: AbilityDependentValue<boolean> | undefined);
24
+ onUnitTargetImpact(_: Unit, target: Unit): void;
25
+ }
@@ -25,4 +25,25 @@ function RemoveBuffsSelfAbilityBehavior.prototype.onImpact(self, caster)
25
25
  self:resolveCurrentAbilityDependentValue(self.autoDispel)
26
26
  )
27
27
  end
28
+ ____exports.RemoveBuffsTargetAbilityBehavior = __TS__Class()
29
+ local RemoveBuffsTargetAbilityBehavior = ____exports.RemoveBuffsTargetAbilityBehavior
30
+ RemoveBuffsTargetAbilityBehavior.name = "RemoveBuffsTargetAbilityBehavior"
31
+ __TS__ClassExtends(RemoveBuffsTargetAbilityBehavior, AbilityBehavior)
32
+ function RemoveBuffsTargetAbilityBehavior.prototype.____constructor(self, ability, polarity, resistanceType, includeExpirationTimers, includeAuras, autoDispel)
33
+ AbilityBehavior.prototype.____constructor(self, ability)
34
+ self.polarity = polarity
35
+ self.resistanceType = resistanceType
36
+ self.includeExpirationTimers = includeExpirationTimers
37
+ self.includeAuras = includeAuras
38
+ self.autoDispel = autoDispel
39
+ end
40
+ function RemoveBuffsTargetAbilityBehavior.prototype.onUnitTargetImpact(self, _, target)
41
+ target:removeBuffs(
42
+ self:resolveCurrentAbilityDependentValue(self.polarity),
43
+ self:resolveCurrentAbilityDependentValue(self.resistanceType),
44
+ self:resolveCurrentAbilityDependentValue(self.includeExpirationTimers),
45
+ self:resolveCurrentAbilityDependentValue(self.includeAuras),
46
+ self:resolveCurrentAbilityDependentValue(self.autoDispel)
47
+ )
48
+ end
28
49
  return ____exports
@@ -8,7 +8,7 @@ export declare class RestoreManaSelfAbilityBehavior extends AbilityBehavior {
8
8
  constructor(ability: Ability, mana: AbilityDependentValue<number>);
9
9
  onImpact(caster: Unit): void;
10
10
  }
11
- export declare class RestoreManaAbilityBehavior extends AbilityBehavior {
11
+ export declare class RestoreManaTargetAbilityBehavior extends AbilityBehavior {
12
12
  private readonly mana;
13
13
  constructor(ability: Ability, mana: AbilityDependentValue<number>);
14
14
  onUnitTargetImpact(caster: Unit, target: Unit): void;
@@ -15,15 +15,15 @@ end
15
15
  function RestoreManaSelfAbilityBehavior.prototype.onImpact(self, caster)
16
16
  caster.mana = caster.mana + self:resolveCurrentAbilityDependentValue(self.mana)
17
17
  end
18
- ____exports.RestoreManaAbilityBehavior = __TS__Class()
19
- local RestoreManaAbilityBehavior = ____exports.RestoreManaAbilityBehavior
20
- RestoreManaAbilityBehavior.name = "RestoreManaAbilityBehavior"
21
- __TS__ClassExtends(RestoreManaAbilityBehavior, AbilityBehavior)
22
- function RestoreManaAbilityBehavior.prototype.____constructor(self, ability, mana)
18
+ ____exports.RestoreManaTargetAbilityBehavior = __TS__Class()
19
+ local RestoreManaTargetAbilityBehavior = ____exports.RestoreManaTargetAbilityBehavior
20
+ RestoreManaTargetAbilityBehavior.name = "RestoreManaTargetAbilityBehavior"
21
+ __TS__ClassExtends(RestoreManaTargetAbilityBehavior, AbilityBehavior)
22
+ function RestoreManaTargetAbilityBehavior.prototype.____constructor(self, ability, mana)
23
23
  AbilityBehavior.prototype.____constructor(self, ability)
24
24
  self.mana = mana
25
25
  end
26
- function RestoreManaAbilityBehavior.prototype.onUnitTargetImpact(self, caster, target)
26
+ function RestoreManaTargetAbilityBehavior.prototype.onUnitTargetImpact(self, caster, target)
27
27
  target.mana = target.mana + self:resolveCurrentAbilityDependentValue(self.mana)
28
28
  end
29
29
  return ____exports
@@ -7,7 +7,8 @@ import { Widget } from "../../core/types/widget";
7
7
  import { Item } from "../internal/item";
8
8
  import { Destructable } from "../../core/types/destructable";
9
9
  import { EffectParameters } from "../../core/types/effect";
10
- import { AbilityDependentValue } from "../object-field/ability";
10
+ import { AbilityDependentValue, ReadonlySubscribableAbilityDependentValue, SubscribableAbilityDependentValue } from "../object-field/ability";
11
+ import { Destructor } from "../../destroyable";
11
12
  export type AbilityBehaviorConstructor<Args extends any[]> = new (ability: Ability, ...args: Args) => AbilityBehavior;
12
13
  export type AbilityBehaviorParameters = {
13
14
  isExclusiveOnImpactHandler?: boolean;
@@ -17,16 +18,25 @@ export declare abstract class AbilityBehavior<Parameters extends {
17
18
  missileParameters?: any[];
18
19
  } = {}> extends Behavior<Ability, NonNullable<Parameters["periodicActionParameters"]>> {
19
20
  constructor(ability: Ability, parameters?: AbilityBehaviorParameters);
21
+ protected onDestroy(): Destructor;
22
+ protected subscribe<T extends boolean | number | string>(value: SubscribableAbilityDependentValue<T>): void;
20
23
  protected registerCommandEvent(orderTypeStringId?: string): void;
21
24
  get ability(): Ability;
25
+ get unit(): Unit | undefined;
22
26
  protected resolveCurrentAbilityDependentValue<T extends boolean | number | string>(value: AbilityDependentValue<T>): T;
23
27
  protected resolveCurrentAbilityDependentValue<T extends boolean | number | string>(value?: AbilityDependentValue<T>): T | undefined;
24
- protected flashCasterEffect(widget: Widget): void;
28
+ protected flashCasterEffect(widget: Widget, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
29
+ protected flashTargetEffect(widget: Widget, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
25
30
  protected flashAreaEffect(x: number, y: number, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
26
31
  protected flashEffect(x: number, y: number, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
27
- protected flashSpecialEffect(...args: [...pointOrWidget: [x: number, y: number] | [widget: Widget], duration?: number]): void;
32
+ protected flashSpecialEffect(...args: [
33
+ ...pointOrWidget: [x: number, y: number] | [widget: Widget],
34
+ ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]
35
+ ]): void;
28
36
  private static MissileLaunchConfig;
29
37
  private get missileLaunchConfig();
38
+ protected onCreate(): void;
39
+ onValueChange(_value: ReadonlySubscribableAbilityDependentValue<string | number | boolean>): void;
30
40
  onMissileArrival(...parameters: NonNullable<Parameters["missileParameters"]>): void;
31
41
  onUnitGainAbility(_unit: Unit): void;
32
42
  onUnitLoseAbility(_unit: Unit): void;
@@ -1,10 +1,10 @@
1
1
  local ____lualib = require("lualib_bundle")
2
2
  local __TS__Class = ____lualib.__TS__Class
3
3
  local __TS__ClassExtends = ____lualib.__TS__ClassExtends
4
+ local __TS__InstanceOf = ____lualib.__TS__InstanceOf
4
5
  local __TS__New = ____lualib.__TS__New
5
6
  local __TS__SetDescriptor = ____lualib.__TS__SetDescriptor
6
7
  local ____exports = {}
7
- local createUnitEventListener
8
8
  local ____behavior = require("engine.behavior")
9
9
  local Behavior = ____behavior.Behavior
10
10
  local ____unit = require("engine.unit")
@@ -23,24 +23,21 @@ local MISSILE_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.MISSILE_MODEL
23
23
  local MISSILE_SPEED_ABILITY_INTEGER_FIELD = ____ability.MISSILE_SPEED_ABILITY_INTEGER_FIELD
24
24
  local SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD = ____ability.SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD
25
25
  local SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD
26
+ local TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD = ____ability.TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD
27
+ local TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD
26
28
  local ____ability = require("engine.object-field.ability")
29
+ local AbilityField = ____ability.AbilityField
30
+ local AbilityLevelField = ____ability.AbilityLevelField
27
31
  local resolveCurrentAbilityDependentValue = ____ability.resolveCurrentAbilityDependentValue
28
- local ____timer = require("core.types.timer")
29
- local Timer = ____timer.Timer
30
32
  local createBehaviorFunctionsByAbilityTypeId = {}
31
33
  local exclusiveOnImpactHandlerAbilityBehaviorByAbility = setmetatable({}, {__mode = "k"})
32
- local function createZeroTimerUnitEventListener(key)
33
- local unitEventListener = createUnitEventListener(key)
34
- return function(unit, ability, ...)
35
- Timer:run(unitEventListener, unit, ability, ...)
36
- end
37
- end
38
- createUnitEventListener = function(key)
34
+ local function createUnitEventListener(key)
39
35
  return function(unit, ability, ...)
40
36
  ____exports.AbilityBehavior:forAll(ability, key, unit, ...)
41
37
  end
42
38
  end
43
39
  local registeredCommandEventIds = {}
40
+ local subscribedValuesByAbilityBehavior = {}
44
41
  local ____class_2 = __TS__Class()
45
42
  ____class_2.name = ""
46
43
  function ____class_2.prototype.____constructor(self, abilityBehavior)
@@ -79,6 +76,21 @@ function AbilityBehavior.prototype.____constructor(self, ability, parameters)
79
76
  if parameters and parameters.isExclusiveOnImpactHandler then
80
77
  exclusiveOnImpactHandlerAbilityBehaviorByAbility[ability] = self
81
78
  end
79
+ self:onCreate()
80
+ end
81
+ function AbilityBehavior.prototype.onDestroy(self)
82
+ subscribedValuesByAbilityBehavior[self] = nil
83
+ return Behavior.prototype.onDestroy(self)
84
+ end
85
+ function AbilityBehavior.prototype.subscribe(self, value)
86
+ if __TS__InstanceOf(value, AbilityField) or __TS__InstanceOf(value, AbilityLevelField) then
87
+ local subscribedValues = subscribedValuesByAbilityBehavior[self]
88
+ if subscribedValues == nil then
89
+ subscribedValues = {}
90
+ subscribedValuesByAbilityBehavior[self] = subscribedValues
91
+ end
92
+ subscribedValues[value] = true
93
+ end
82
94
  end
83
95
  function AbilityBehavior.prototype.registerCommandEvent(self, orderTypeStringId)
84
96
  if orderTypeStringId == nil then
@@ -93,11 +105,22 @@ end
93
105
  function AbilityBehavior.prototype.resolveCurrentAbilityDependentValue(self, value)
94
106
  return resolveCurrentAbilityDependentValue(self.ability, value)
95
107
  end
96
- function AbilityBehavior.prototype.flashCasterEffect(self, widget)
108
+ function AbilityBehavior.prototype.flashCasterEffect(self, widget, ...)
109
+ local attachmentPoint = CASTER_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
97
110
  Effect:flash(
98
111
  CASTER_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
99
112
  widget,
100
- CASTER_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
113
+ attachmentPoint ~= "" and attachmentPoint or "origin",
114
+ ...
115
+ )
116
+ end
117
+ function AbilityBehavior.prototype.flashTargetEffect(self, widget, ...)
118
+ local attachmentPoint = TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
119
+ Effect:flash(
120
+ TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
121
+ widget,
122
+ attachmentPoint ~= "" and attachmentPoint or "origin",
123
+ ...
101
124
  )
102
125
  end
103
126
  function AbilityBehavior.prototype.flashAreaEffect(self, x, y, ...)
@@ -116,23 +139,30 @@ function AbilityBehavior.prototype.flashEffect(self, x, y, ...)
116
139
  ...
117
140
  )
118
141
  end
119
- function AbilityBehavior.prototype.flashSpecialEffect(self, xOrWidget, yOrDuration, duration)
142
+ function AbilityBehavior.prototype.flashSpecialEffect(self, xOrWidget, yOrParametersOrDuration, durationOrParameters, parameters)
120
143
  if type(xOrWidget) == "number" then
121
144
  Effect:flash(
122
145
  SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
123
146
  xOrWidget,
124
- yOrDuration,
125
- duration
147
+ yOrParametersOrDuration,
148
+ durationOrParameters,
149
+ parameters
126
150
  )
127
151
  else
152
+ local attachmentPoint = SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
128
153
  Effect:flash(
129
154
  SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
130
155
  xOrWidget,
131
- SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability),
132
- yOrDuration
156
+ attachmentPoint ~= "" and attachmentPoint or "origin",
157
+ yOrParametersOrDuration,
158
+ durationOrParameters
133
159
  )
134
160
  end
135
161
  end
162
+ function AbilityBehavior.prototype.onCreate(self)
163
+ end
164
+ function AbilityBehavior.prototype.onValueChange(self, _value)
165
+ end
136
166
  function AbilityBehavior.prototype.onMissileArrival(self, ...)
137
167
  end
138
168
  function AbilityBehavior.prototype.onUnitGainAbility(self, _unit)
@@ -200,6 +230,18 @@ __TS__SetDescriptor(
200
230
  end},
201
231
  true
202
232
  )
233
+ __TS__SetDescriptor(
234
+ AbilityBehavior.prototype,
235
+ "unit",
236
+ {get = function(self)
237
+ local owner = self.object.owner
238
+ if __TS__InstanceOf(owner, Unit) then
239
+ return owner
240
+ end
241
+ return owner.owner
242
+ end},
243
+ true
244
+ )
203
245
  AbilityBehavior.MissileLaunchConfig = ____class_2
204
246
  __TS__SetDescriptor(
205
247
  AbilityBehavior.prototype,
@@ -223,16 +265,28 @@ __TS__SetDescriptor(
223
265
  Unit.abilityDestructibleTargetChannelingStartEvent:addListener(createUnitEventListener("onDestructibleTargetChannelingStart"))
224
266
  Unit.abilityPointTargetChannelingStartEvent:addListener(createUnitEventListener("onPointTargetChannelingStart"))
225
267
  Unit.abilityNoTargetChannelingStartEvent:addListener(createUnitEventListener("onNoTargetChannelingStart"))
226
- Unit.abilityChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onImpact"))
227
- Unit.abilityWidgetTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onWidgetTargetImpact"))
228
- Unit.abilityUnitTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onUnitTargetImpact"))
229
- Unit.abilityItemTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onItemTargetImpact"))
230
- Unit.abilityDestructibleTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onDestructibleTargetImpact"))
231
- Unit.abilityPointTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onPointTargetImpact"))
232
- Unit.abilityNoTargetChannelingStartEvent:addListener(createZeroTimerUnitEventListener("onNoTargetImpact"))
268
+ Unit.abilityImpactEvent:addListener(createUnitEventListener("onImpact"))
269
+ Unit.abilityWidgetTargetImpactEvent:addListener(createUnitEventListener("onWidgetTargetImpact"))
270
+ Unit.abilityUnitTargetImpactEvent:addListener(createUnitEventListener("onUnitTargetImpact"))
271
+ Unit.abilityItemTargetImpactEvent:addListener(createUnitEventListener("onItemTargetImpact"))
272
+ Unit.abilityDestructibleTargetImpactEvent:addListener(createUnitEventListener("onDestructibleTargetImpact"))
273
+ Unit.abilityPointTargetImpactEvent:addListener(createUnitEventListener("onPointTargetImpact"))
274
+ Unit.abilityNoTargetImpactEvent:addListener(createUnitEventListener("onNoTargetImpact"))
233
275
  Unit.abilityChannelingFinishEvent:addListener(createUnitEventListener("onChannelingFinish"))
234
276
  Unit.abilityStopEvent:addListener(createUnitEventListener("onStop"))
235
277
  end)(AbilityBehavior)
278
+ local function checkBehaviorOnValueChange(behavior, field)
279
+ local subscribedValues = subscribedValuesByAbilityBehavior[behavior]
280
+ if subscribedValues ~= nil and subscribedValues[field] ~= nil then
281
+ behavior:onValueChange(field)
282
+ end
283
+ end
284
+ AbilityField.valueChangeEvent:addListener(function(ability, field)
285
+ ____exports.AbilityBehavior:forAll(ability, checkBehaviorOnValueChange, field)
286
+ end)
287
+ AbilityLevelField.valueChangeEvent:addListener(function(ability, field)
288
+ ____exports.AbilityBehavior:forAll(ability, checkBehaviorOnValueChange, field)
289
+ end)
236
290
  Ability.onCreate:addListener(function(ability)
237
291
  local createBehaviorFunctions = createBehaviorFunctionsByAbilityTypeId[ability.typeId]
238
292
  if createBehaviorFunctions ~= nil then
@@ -4,15 +4,21 @@ import { Unit } from "../../unit";
4
4
  import { BuffTypeId } from "../../object-data/entry/buff-type";
5
5
  import { TextTagPreset } from "../../text-tag";
6
6
  import { Destructor } from "../../../destroyable";
7
- export type StunImmunityUnitBehaviourParameters = {
7
+ import { BehaviorPriority } from "../../behavior";
8
+ export type StunImmunityUnitBehaviorParameters = {
9
+ readonly priority?: BehaviorPriority;
8
10
  buffTypeIds?: LuaSet<BuffTypeId>;
9
11
  textTagPreset?: TextTagPreset;
10
12
  textTagText?: string;
13
+ additionalAction?: (this: void, unit: Unit) => void;
11
14
  };
12
15
  export declare class StunImmunityUnitBehavior extends UnitBehavior {
13
- private readonly parameters;
14
- static defaultParameters: StunImmunityUnitBehaviourParameters;
15
- constructor(unit: Unit, parameters?: StunImmunityUnitBehaviourParameters);
16
+ readonly parameters: Readonly<StunImmunityUnitBehaviorParameters>;
17
+ static defaultParameters: StunImmunityUnitBehaviorParameters;
18
+ constructor(unit: Unit, parameters?: Readonly<StunImmunityUnitBehaviorParameters>);
16
19
  protected onDestroy(): Destructor;
17
- private onBuffsCheck;
20
+ onDamageReceived(): void;
21
+ onTargetingAbilityChannelingStart(): void;
22
+ onTargetingAbilityImpact(): void;
23
+ protected onEffect(): void;
18
24
  }
@@ -12,31 +12,53 @@ local flatMapToLuaSet = ____arrays.flatMapToLuaSet
12
12
  local map = ____arrays.map
13
13
  local ____text_2Dtag = require("engine.text-tag")
14
14
  local TextTag = ____text_2Dtag.TextTag
15
+ local ____timer = require("core.types.timer")
16
+ local Timer = ____timer.Timer
15
17
  local DEFAULT_BUFF_TYPE_IDS = postcompile(function()
16
18
  return flatMapToLuaSet(
17
19
  AbilityType:getAllByBaseIds(map({
18
- "Aslo",
19
- "AHtc",
20
- "Aens",
21
- "Aprg",
22
- "Apg2",
23
- "AOeq",
24
- "SNeq",
25
- "Aweb",
26
- "Afra",
27
- "Afrb",
28
- "Afrc",
29
- "Afr2",
30
- "Acri",
31
- "Scri",
32
- "AUfn",
33
- "Aspo",
34
- "AEer",
35
- "ACwb"
20
+ "AHtb",
21
+ "AHbh",
22
+ "AOws",
23
+ "AOw2",
24
+ "AUim",
25
+ "Acyc",
26
+ "ANfb",
27
+ "ANsb",
28
+ "ANcs",
29
+ "ANc1",
30
+ "ANc2",
31
+ "ANc3",
32
+ "ACbh",
33
+ "ANbh",
34
+ "SCc1",
35
+ "ACcy",
36
+ "ANb2",
37
+ "Awrs",
38
+ "Awrh",
39
+ "Awrg",
40
+ "ACtb",
41
+ "ACcb"
36
42
  }, fourCC)),
37
43
  function(abilityType) return __TS__ArrayFlat(abilityType.buffTypeIds) end
38
44
  )
39
45
  end)
46
+ local function process(behavior)
47
+ local hasRemovedBuffs = false
48
+ for buffTypeId in pairs(behavior.parameters.buffTypeIds or DEFAULT_BUFF_TYPE_IDS) do
49
+ hasRemovedBuffs = hasRemovedBuffs or behavior.unit:removeBuff(buffTypeId)
50
+ end
51
+ if hasRemovedBuffs then
52
+ behavior.onEffect(behavior)
53
+ if behavior.parameters.textTagText ~= nil then
54
+ TextTag:flash(TextTag.MISS, behavior.parameters.textTagText, behavior.unit.x, behavior.unit.y)
55
+ end
56
+ local ____opt_0 = behavior.parameters.additionalAction
57
+ if ____opt_0 ~= nil then
58
+ ____opt_0(behavior.unit)
59
+ end
60
+ end
61
+ end
40
62
  ____exports.StunImmunityUnitBehavior = __TS__Class()
41
63
  local StunImmunityUnitBehavior = ____exports.StunImmunityUnitBehavior
42
64
  StunImmunityUnitBehavior.name = "StunImmunityUnitBehavior"
@@ -45,23 +67,26 @@ function StunImmunityUnitBehavior.prototype.____constructor(self, unit, paramete
45
67
  if parameters == nil then
46
68
  parameters = ____exports.StunImmunityUnitBehavior.defaultParameters
47
69
  end
48
- UnitBehavior.prototype.____constructor(self, unit)
70
+ UnitBehavior.prototype.____constructor(self, unit, parameters.priority)
49
71
  self.parameters = parameters
50
72
  unit:decrementStunCounter()
51
- self:onBuffsCheck()
73
+ process(self)
52
74
  end
53
75
  function StunImmunityUnitBehavior.prototype.onDestroy(self)
54
76
  self.unit:incrementStunCounter()
55
77
  return UnitBehavior.prototype.onDestroy(self)
56
78
  end
57
- function StunImmunityUnitBehavior.prototype.onBuffsCheck(self)
58
- local hasRemovedBuffs = false
59
- for buffTypeId in pairs(self.parameters.buffTypeIds or DEFAULT_BUFF_TYPE_IDS) do
60
- hasRemovedBuffs = hasRemovedBuffs or self.unit:removeBuff(buffTypeId)
61
- end
62
- if hasRemovedBuffs and self.parameters.textTagText ~= nil then
63
- TextTag:flash(TextTag.MISS, self.parameters.textTagText, self.unit.x, self.unit.y)
64
- end
79
+ function StunImmunityUnitBehavior.prototype.onDamageReceived(self)
80
+ process(self)
81
+ Timer:run(process, self)
82
+ end
83
+ function StunImmunityUnitBehavior.prototype.onTargetingAbilityChannelingStart(self)
84
+ process(self)
85
+ end
86
+ function StunImmunityUnitBehavior.prototype.onTargetingAbilityImpact(self)
87
+ process(self)
88
+ end
89
+ function StunImmunityUnitBehavior.prototype.onEffect(self)
65
90
  end
66
91
  StunImmunityUnitBehavior.defaultParameters = {buffTypeIds = DEFAULT_BUFF_TYPE_IDS, textTagPreset = TextTag.MISS, textTagText = nil}
67
92
  return ____exports
@@ -1,26 +1,62 @@
1
1
  /** @noSelfInFile */
2
- import { Behavior } from "../behavior";
2
+ import { Behavior, BehaviorPriority } from "../behavior";
3
3
  import { Ability } from "../internal/ability";
4
4
  import { DamageEvent, DamagingEvent, Unit } from "../internal/unit";
5
5
  import "../internal/unit+ability";
6
6
  import "../internal/unit-missile-launch";
7
7
  import { Item } from "../internal/item";
8
+ import { AbilityBehavior } from "./ability";
9
+ import { Event } from "../../event";
10
+ import { Destructor } from "../../destroyable";
11
+ import type { Widget } from "../../core/types/widget";
12
+ import { Destructable } from "../../core/types/destructable";
13
+ import type { Buff } from "../buff";
14
+ import { UnitBonusType } from "../internal/unit/bonus";
15
+ import { Player } from "../../core/types/player";
16
+ import { UnitTypeId } from "../object-data/entry/unit-type";
8
17
  export type UnitBehaviorConstructor<Args extends any[]> = new (unit: Unit, ...args: Args) => UnitBehavior;
9
18
  export declare abstract class UnitBehavior<PeriodicActionParameters extends any[] = any[]> extends Behavior<Unit, PeriodicActionParameters> {
10
- constructor(unit: Unit);
19
+ readonly sourceAbilityBehavior?: AbilityBehavior;
20
+ private _bonusIdByBonusType?;
21
+ constructor(unit: Unit, priority?: BehaviorPriority);
22
+ protected onDestroy(): Destructor;
11
23
  get unit(): Unit;
24
+ protected getUnitBonus(bonusType: UnitBonusType): number;
25
+ protected addOrUpdateOrRemoveUnitBonus(bonusType: UnitBonusType, value: number): void;
26
+ protected registerInRangeUnitEvent<T extends string, Args extends any[]>(this: UnitBehavior<PeriodicActionParameters> & Record<T, (this: this, ...args: Args) => unknown>, event: Event<[...Args]>, extractUnit: (...args: Args) => Unit | undefined, range: number, listener: T): void;
27
+ onImmediateOrder(orderId: number): void;
28
+ onTargetOrder(orderId: number, target: Widget): void;
29
+ onPointOrder(orderId: number, x: number, y: number): void;
12
30
  onAutoAttackStart(target: Unit): void;
13
31
  onAutoAttackFinish(target: Unit): void;
32
+ onTargetingAutoAttackStart(source: Unit): void;
33
+ onTargetingAutoAttackFinish(source: Unit): void;
14
34
  onDamageDealing(target: Unit, event: DamagingEvent): void;
15
35
  onDamageDealt(target: Unit, event: DamageEvent): void;
16
36
  onDamageReceiving(source: Unit | undefined, event: DamagingEvent): void;
17
37
  onDamageReceived(source: Unit | undefined, event: DamageEvent): void;
18
38
  onAbilityGained(ability: Ability): void;
19
39
  onAbilityLost(ability: Ability): void;
40
+ onAbilityChannelingStart(ability: Ability): void;
41
+ onAbilityImpact(ability: Ability): void;
42
+ onAbilityWidgetTargetImpact(ability: Ability, target: Widget): void;
43
+ onAbilityUnitTargetImpact(ability: Ability, target: Unit): void;
44
+ onAbilityItemTargetImpact(ability: Ability, target: Item): void;
45
+ onAbilityDestructibleTargetImpact(ability: Ability, target: Destructable): void;
46
+ onAbilityPointTargetImpact(ability: Ability, x: number, y: number): void;
47
+ onAbilityNoTargetImpact(ability: Ability): void;
48
+ onAbilityChannelingFinish(ability: Ability): void;
49
+ onAbilityStop(ability: Ability): void;
50
+ onTargetingAbilityChannelingStart(ability: Ability, source: Unit): void;
51
+ onTargetingAbilityImpact(ability: Ability, source: Unit): void;
52
+ onBuffGained(buff: Buff): void;
20
53
  onItemDropped(item: Item): void;
21
54
  onItemPickedUp(item: Item): void;
22
55
  onItemUsed(item: Item): void;
23
56
  onItemStacked(item: Item): void;
57
+ onItemChargesChanged(item: Item): void;
24
58
  onKill(target: Unit): void;
25
59
  onDeath(source: Unit | undefined): void;
60
+ onOwnerChange(previousOwner: Player): void;
61
+ static bindUnitType<Args extends any[]>(this: UnitBehaviorConstructor<Args>, unitTypeId: UnitTypeId, ...args: Args): void;
26
62
  }