warscript 0.0.1-dev.724bf08 → 0.0.1-dev.7821093

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 (50) hide show
  1. package/core/types/effect.d.ts +1 -0
  2. package/core/types/effect.lua +80 -30
  3. package/core/util.d.ts +1 -1
  4. package/core/util.lua +6 -0
  5. package/engine/behaviour/ability/always-enabled.d.ts +7 -0
  6. package/engine/behaviour/ability/always-enabled.lua +31 -0
  7. package/engine/behaviour/ability/apply-buff.d.ts +5 -0
  8. package/engine/behaviour/ability/apply-buff.lua +32 -0
  9. package/engine/behaviour/ability/emulate-impact.lua +5 -7
  10. package/engine/behaviour/ability/on-command-impact.lua +7 -0
  11. package/engine/behaviour/ability.d.ts +8 -2
  12. package/engine/behaviour/ability.lua +52 -3
  13. package/engine/buff.d.ts +5 -0
  14. package/engine/buff.lua +21 -1
  15. package/engine/internal/ability.d.ts +11 -1
  16. package/engine/internal/ability.lua +67 -2
  17. package/engine/internal/item/ability.lua +106 -0
  18. package/engine/internal/item.d.ts +2 -2
  19. package/engine/internal/item.lua +56 -25
  20. package/engine/internal/misc/ability-disable-counter.d.ts +2 -0
  21. package/engine/internal/misc/ability-disable-counter.lua +13 -0
  22. package/engine/internal/object-data/auto-attack-speed-increase.d.ts +1 -1
  23. package/engine/internal/object-data/auto-attack-speed-increase.lua +2 -0
  24. package/engine/internal/object-data/evasion-probability.d.ts +2 -0
  25. package/engine/internal/object-data/evasion-probability.lua +16 -0
  26. package/engine/internal/unit/add-item-to-slot-init.d.ts +2 -0
  27. package/engine/internal/unit/add-item-to-slot-init.lua +23 -0
  28. package/engine/internal/unit/add-item-to-slot.d.ts +2 -0
  29. package/engine/internal/unit/add-item-to-slot.lua +52 -0
  30. package/engine/internal/unit/bonus.d.ts +2 -0
  31. package/engine/internal/unit/bonus.lua +17 -0
  32. package/engine/internal/unit/ignore-events-items.d.ts +2 -0
  33. package/engine/internal/unit/ignore-events-items.lua +5 -0
  34. package/engine/internal/unit/item.lua +6 -12
  35. package/engine/internal/unit.d.ts +3 -1
  36. package/engine/internal/unit.lua +63 -13
  37. package/engine/internal/utility.lua +12 -0
  38. package/engine/lightning.d.ts +8 -2
  39. package/engine/lightning.lua +27 -2
  40. package/engine/object-data/entry/ability-type.lua +8 -12
  41. package/engine/object-data/entry/item-type.d.ts +2 -0
  42. package/engine/object-data/entry/item-type.lua +13 -0
  43. package/engine/object-data/utility/object-data-entry-id-generator.lua +7 -0
  44. package/engine/object-field/ability.d.ts +5 -2
  45. package/engine/object-field/ability.lua +3 -0
  46. package/engine/object-field.d.ts +2 -2
  47. package/engine/object-field.lua +4 -0
  48. package/engine/unit.d.ts +1 -0
  49. package/engine/unit.lua +1 -0
  50. package/package.json +2 -2
@@ -8,6 +8,7 @@ declare const enum EffectPropertyKey {
8
8
  ROLL = 102
9
9
  }
10
10
  export type EffectParameters = {
11
+ readonly delay?: number;
11
12
  readonly scale?: number;
12
13
  readonly color?: PlayerColor;
13
14
  readonly pitch?: number;
@@ -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
5
4
  local __TS__SetDescriptor = ____lualib.__TS__SetDescriptor
5
+ local __TS__InstanceOf = ____lualib.__TS__InstanceOf
6
6
  local ____exports = {}
7
- local dummyPlayer
7
+ local dummyPlayer, flash
8
8
  local ____handle = require("core.types.handle")
9
9
  local Handle = ____handle.Handle
10
10
  local ____playerColor = require("core.types.playerColor")
@@ -123,6 +123,13 @@ dummyPlayer = Player.neutralExtra
123
123
  local temporaryEffects = {}
124
124
  local temporaryEffectsDurations = {}
125
125
  local temporaryEffectsCount = 0
126
+ local delayedEffectsModelPath = {}
127
+ local delayedEffectsXOrWidget = {}
128
+ local delayedEffectsYOrAttachmentPoint = {}
129
+ local delayedEffectsDuration = {}
130
+ local delayedEffectsParameters = {}
131
+ local delayedEffectsDelay = {}
132
+ local delayedEffectsCount = 0
126
133
  local period = 1 / 32
127
134
  Timer.onPeriod[period]:addListener(function()
128
135
  local i = 1
@@ -131,12 +138,36 @@ Timer.onPeriod[period]:addListener(function()
131
138
  if duration <= 0 then
132
139
  destroyEffect(temporaryEffects[i])
133
140
  temporaryEffects[i] = temporaryEffects[temporaryEffectsCount]
141
+ temporaryEffectsDurations[i] = temporaryEffectsDurations[temporaryEffectsCount]
134
142
  temporaryEffectsCount = temporaryEffectsCount - 1
135
143
  else
136
144
  temporaryEffectsDurations[i] = duration - period
137
145
  i = i + 1
138
146
  end
139
147
  end
148
+ i = 1
149
+ while i <= delayedEffectsCount do
150
+ local delay = delayedEffectsDelay[i]
151
+ if delay <= 0 then
152
+ flash(
153
+ delayedEffectsModelPath[i],
154
+ delayedEffectsXOrWidget[i],
155
+ delayedEffectsYOrAttachmentPoint[i],
156
+ delayedEffectsDuration[i],
157
+ delayedEffectsParameters[i]
158
+ )
159
+ delayedEffectsModelPath[i] = delayedEffectsModelPath[delayedEffectsCount]
160
+ delayedEffectsXOrWidget[i] = delayedEffectsXOrWidget[delayedEffectsCount]
161
+ delayedEffectsYOrAttachmentPoint[i] = delayedEffectsYOrAttachmentPoint[delayedEffectsCount]
162
+ delayedEffectsDuration[i] = delayedEffectsDuration[delayedEffectsCount]
163
+ delayedEffectsParameters[i] = delayedEffectsParameters[delayedEffectsCount]
164
+ delayedEffectsDelay[i] = delayedEffectsDelay[delayedEffectsCount]
165
+ delayedEffectsCount = delayedEffectsCount - 1
166
+ else
167
+ delayedEffectsDelay[i] = delay - period
168
+ i = i + 1
169
+ end
170
+ end
140
171
  end)
141
172
  ____exports.Effect = __TS__Class()
142
173
  local Effect = ____exports.Effect
@@ -157,36 +188,23 @@ function Effect.flash(self, modelPath, xOrWidget, yOrOrAttachmentPoint, paramete
157
188
  parameters = parametersOrDuration
158
189
  parametersOrDuration = nil
159
190
  end
160
- local coordinatesProvided = type(xOrWidget) == "number"
161
- local isPositional = coordinatesProvided or (parameters and parameters.detached) == true
162
- local x = not isPositional and 0 or (coordinatesProvided and xOrWidget or xOrWidget.x)
163
- local y = not isPositional and 0 or (coordinatesProvided and yOrOrAttachmentPoint or xOrWidget.y)
164
- local effect = isPositional and addSpecialEffect(modelPath, x, y) or addSpecialEffectTarget(modelPath, xOrWidget.handle, yOrOrAttachmentPoint or "origin")
165
- if isPositional and not coordinatesProvided and (parameters and parameters.scale) == nil and __TS__InstanceOf(xOrWidget, Unit) then
166
- setSpecialEffectScale(effect, xOrWidget.scale)
167
- end
168
- if parameters ~= nil then
169
- for key, value in ____pairs(parameters) do
170
- if key ~= "zOffset" and key ~= "detached" and key ~= "scaleZOffset" then
171
- setters[key](effect, value)
172
- end
173
- end
174
- if isPositional and parameters.zOffset ~= nil then
175
- moveLocation(location, x, y)
176
- local z = __TS__InstanceOf(xOrWidget, Unit) and getLocationZ(location) + xOrWidget.flyHeight or getLocationZ(location)
177
- BlzSetSpecialEffectZ(
178
- effect,
179
- z + parameters.zOffset * (parameters.scaleZOffset and getSpecialEffectScale(effect) or 1)
180
- )
181
- end
182
- end
183
- if parametersOrDuration ~= nil and parametersOrDuration > 0 then
184
- temporaryEffectsCount = temporaryEffectsCount + 1
185
- temporaryEffects[temporaryEffectsCount] = effect
186
- temporaryEffectsDurations[temporaryEffectsCount] = parametersOrDuration
191
+ if parameters and (parameters.delay or 0) > 0 then
192
+ delayedEffectsCount = delayedEffectsCount + 1
193
+ delayedEffectsModelPath[delayedEffectsCount] = modelPath
194
+ delayedEffectsXOrWidget[delayedEffectsCount] = xOrWidget
195
+ delayedEffectsYOrAttachmentPoint[delayedEffectsCount] = yOrOrAttachmentPoint
196
+ delayedEffectsDuration[delayedEffectsCount] = parametersOrDuration
197
+ delayedEffectsParameters[delayedEffectsCount] = parameters
198
+ delayedEffectsDelay[delayedEffectsCount] = parameters.delay
187
199
  return
188
200
  end
189
- destroyEffect(effect)
201
+ flash(
202
+ modelPath,
203
+ xOrWidget,
204
+ yOrOrAttachmentPoint,
205
+ parametersOrDuration,
206
+ parameters
207
+ )
190
208
  end
191
209
  function Effect.flashTarget(self, model, target, attachPoint, duration)
192
210
  local effect = addSpecialEffectTarget(model, target.handle, attachPoint)
@@ -255,4 +273,36 @@ __TS__SetDescriptor(
255
273
  },
256
274
  true
257
275
  )
276
+ flash = function(modelPath, xOrWidget, yOrOrAttachmentPoint, duration, parameters)
277
+ local coordinatesProvided = type(xOrWidget) == "number"
278
+ local isPositional = coordinatesProvided or (parameters and parameters.detached) == true
279
+ local x = not isPositional and 0 or (coordinatesProvided and xOrWidget or xOrWidget.x)
280
+ local y = not isPositional and 0 or (coordinatesProvided and yOrOrAttachmentPoint or xOrWidget.y)
281
+ local effect = isPositional and addSpecialEffect(modelPath, x, y) or addSpecialEffectTarget(modelPath, xOrWidget.handle, yOrOrAttachmentPoint or "origin")
282
+ if isPositional and not coordinatesProvided and (parameters and parameters.scale) == nil and __TS__InstanceOf(xOrWidget, Unit) then
283
+ setSpecialEffectScale(effect, xOrWidget.scale)
284
+ end
285
+ if parameters ~= nil then
286
+ for key, value in ____pairs(parameters) do
287
+ if key ~= "zOffset" and key ~= "detached" and key ~= "scaleZOffset" and key ~= "delay" then
288
+ setters[key](effect, value)
289
+ end
290
+ end
291
+ if isPositional and parameters.zOffset ~= nil then
292
+ moveLocation(location, x, y)
293
+ local z = __TS__InstanceOf(xOrWidget, Unit) and getLocationZ(location) + xOrWidget.flyHeight or getLocationZ(location)
294
+ BlzSetSpecialEffectZ(
295
+ effect,
296
+ z + parameters.zOffset * (parameters.scaleZOffset and getSpecialEffectScale(effect) or 1)
297
+ )
298
+ end
299
+ end
300
+ if duration ~= nil and duration > 0 then
301
+ temporaryEffectsCount = temporaryEffectsCount + 1
302
+ temporaryEffects[temporaryEffectsCount] = effect
303
+ temporaryEffectsDurations[temporaryEffectsCount] = duration
304
+ return
305
+ end
306
+ destroyEffect(effect)
307
+ end
258
308
  return ____exports
package/core/util.d.ts CHANGED
@@ -54,7 +54,7 @@ declare global {
54
54
  function fourCC(id: string): number;
55
55
  }
56
56
  declare namespace inner {
57
- const orderId: (id: "blink" | "stop" | "load" | "sleep" | "absorb" | "acidbomb" | "acolyteharvest" | "ambush" | "ancestralspirit" | "ancestralspirittarget" | "animatedead" | "antimagicshell" | "attack" | "attackground" | "attackonce" | "attributemodskill" | "auraunholy" | "auravampiric" | "autodispel" | "autodispeloff" | "autodispelon" | "autoentangle" | "autoentangleinstant" | "autoharvestgold" | "autoharvestlumber" | "avatar" | "avengerform" | "awaken" | "banish" | "barkskin" | "barkskinoff" | "barkskinon" | "battleroar" | "battlestations" | "bearform" | "berserk" | "blackarrow" | "blackarrowoff" | "blackarrowon" | "blight" | "blizzard" | "bloodlust" | "bloodlustoff" | "bloodluston" | "board" | "breathoffire" | "breathoffrost" | "build" | "burrow" | "cannibalize" | "carrionscarabs" | "carrionscarabsinstant" | "carrionscarabsoff" | "carrionscarabson" | "carrionswarm" | "chainlightning" | "channel" | "charm" | "chemicalrage" | "cloudoffog" | "clusterrockets" | "coldarrows" | "coldarrowstarg" | "controlmagic" | "corporealform" | "corrosivebreath" | "coupleinstant" | "coupletarget" | "creepanimatedead" | "creepdevour" | "creepheal" | "creephealoff" | "creephealon" | "creepthunderbolt" | "creepthunderclap" | "cripple" | "curse" | "curseoff" | "curseon" | "cyclone" | "darkconversion" | "darkportal" | "darkritual" | "darksummoning" | "deathanddecay" | "deathcoil" | "deathpact" | "decouple" | "defend" | "detectaoe" | "detonate" | "devour" | "devourmagic" | "disassociate" | "disenchant" | "dismount" | "dispel" | "divineshield" | "doom" | "drain" | "dreadlordinferno" | "dropitem" | "moveslot0" | "moveslot1" | "moveslot2" | "moveslot3" | "moveslot4" | "moveslot5" | "drunkenhaze" | "earthquake" | "eattree" | "elementalfury" | "ensnare" | "ensnareoff" | "ensnareon" | "entangle" | "entangleinstant" | "entanglingroots" | "etherealform" | "evileye" | "faeriefire" | "faeriefireoff" | "faeriefireon" | "fanofknives" | "farsight" | "fingerofdeath" | "firebolt" | "flamestrike" | "flamingarrows" | "flamingarrowstarg" | "flamingattack" | "flamingattacktarg" | "flare" | "forceboard" | "forceofnature" | "forkedlightning" | "freezingbreath" | "frenzy" | "frenzyoff" | "frenzyon" | "frostarmor" | "frostarmoroff" | "frostarmoron" | "frostnova" | "getitem" | "gold2lumber" | "grabtree" | "harvest" | "heal" | "healingspray" | "healingward" | "healingwave" | "healoff" | "healon" | "hex" | "holdposition" | "holybolt" | "howlofterror" | "humanbuild" | "immolation" | "impale" | "incineratearrow" | "incineratearrowoff" | "incineratearrowon" | "inferno" | "innerfire" | "innerfireoff" | "innerfireon" | "instant" | "invisibility" | "lavamonster" | "lightningshield" | "loadarcher" | "loadcorpse" | "loadcorpseinstant" | "locustswarm" | "lumber2gold" | "magicdefense" | "magicleash" | "magicundefense" | "manaburn" | "manaflareoff" | "manaflareon" | "manashieldoff" | "manashieldon" | "massteleport" | "mechanicalcritter" | "metamorphosis" | "militia" | "militiaconvert" | "militiaoff" | "militiaunconvert" | "mindrot" | "mirrorimage" | "monsoon" | "mount" | "mounthippogryph" | "move" | "moveAI" | "nagabuild" | "neutraldetectaoe" | "neutralinteract" | "neutralspell" | "nightelfbuild" | "orcbuild" | "parasite" | "parasiteoff" | "parasiteon" | "patrol" | "patrolAI" | "phaseshift" | "phaseshiftinstant" | "phaseshiftoff" | "phaseshifton" | "phoenixfire" | "phoenixmorph" | "poisonarrows" | "poisonarrowstarg" | "polymorph" | "possession" | "preservation" | "purge" | "rainofchaos" | "rainoffire" | "raisedead" | "raisedeadoff" | "raisedeadon" | "ravenform" | "recharge" | "rechargeoff" | "rechargeon" | "rejuvination" | "renew" | "renewoff" | "renewon" | "repair" | "repairoff" | "repairon" | "replenish" | "replenishlife" | "replenishlifeoff" | "replenishlifeon" | "replenishmana" | "replenishmanaoff" | "replenishmanaon" | "replenishoff" | "replenishon" | "request_hero" | "requestsacrifice" | "restoration" | "restorationoff" | "restorationon" | "resumebuild" | "resumeharvesting" | "resurrection" | "returnresources" | "revenge" | "revive" | "roar" | "robogoblin" | "root" | "sacrifice" | "sanctuary" | "scout" | "selfdestruct" | "selfdestructoff" | "selfdestructon" | "sentinel" | "follow" | "smart" | "setrally" | "shadowsight" | "shadowstrike" | "shockwave" | "silence" | "slow" | "slowoff" | "slowon" | "soulburn" | "soulpreservation" | "spellshield" | "spellshieldaoe" | "spellsteal" | "spellstealoff" | "spellstealon" | "spies" | "spiritlink" | "spiritofvengeance" | "spirittroll" | "spiritwolf" | "stampede" | "standdown" | "starfall" | "stasistrap" | "steal" | "stomp" | "stoneform" | "stunned" | "submerge" | "summonfactory" | "summongrizzly" | "summonphoenix" | "summonquillbeast" | "summonwareagle" | "tankdroppilot" | "tankloadpilot" | "tankpilot" | "taunt" | "thunderbolt" | "thunderclap" | "tornado" | "townbelloff" | "townbellon" | "tranquility" | "transmute" | "unavatar" | "unavengerform" | "unbearform" | "unburrow" | "uncoldarrows" | "uncorporealform" | "undeadbuild" | "undefend" | "undivineshield" | "unetherealform" | "unflamingarrows" | "unflamingattack" | "unholyfrenzy" | "unimmolation" | "unload" | "unloadall" | "unloadallcorpses" | "unloadallinstant" | "unpoisonarrows" | "unravenform" | "unrobogoblin" | "unroot" | "unstableconcoction" | "unstoneform" | "unsubmerge" | "unsummon" | "unwindwalk" | "vengeance" | "vengeanceinstant" | "vengeanceoff" | "vengeanceon" | "volcano" | "voodoo" | "ward" | "waterelemental" | "wateryminion" | "web" | "weboff" | "webon" | "whirlwind" | "windwalk" | "wispharvest") => number;
57
+ const orderId: (id: "blink" | "stop" | "load" | "sleep" | "absorb" | "acidbomb" | "acolyteharvest" | "ambush" | "ancestralspirit" | "ancestralspirittarget" | "animatedead" | "antimagicshell" | "attack" | "attackground" | "attackonce" | "attributemodskill" | "auraunholy" | "auravampiric" | "autodispel" | "autodispeloff" | "autodispelon" | "autoentangle" | "autoentangleinstant" | "autoharvestgold" | "autoharvestlumber" | "avatar" | "avengerform" | "awaken" | "banish" | "barkskin" | "barkskinoff" | "barkskinon" | "battleroar" | "battlestations" | "bearform" | "berserk" | "blackarrow" | "blackarrowoff" | "blackarrowon" | "blight" | "blizzard" | "bloodlust" | "bloodlustoff" | "bloodluston" | "board" | "breathoffire" | "breathoffrost" | "build" | "burrow" | "cannibalize" | "carrionscarabs" | "carrionscarabsinstant" | "carrionscarabsoff" | "carrionscarabson" | "carrionswarm" | "chainlightning" | "channel" | "charm" | "chemicalrage" | "cloudoffog" | "clusterrockets" | "coldarrows" | "coldarrowstarg" | "controlmagic" | "corporealform" | "corrosivebreath" | "coupleinstant" | "coupletarget" | "creepanimatedead" | "creepdevour" | "creepheal" | "creephealoff" | "creephealon" | "creepthunderbolt" | "creepthunderclap" | "cripple" | "curse" | "curseoff" | "curseon" | "cyclone" | "darkconversion" | "darkportal" | "darkritual" | "darksummoning" | "deathanddecay" | "deathcoil" | "deathpact" | "decouple" | "defend" | "detectaoe" | "detonate" | "devour" | "devourmagic" | "disassociate" | "disenchant" | "dismount" | "dispel" | "divineshield" | "doom" | "drain" | "dreadlordinferno" | "dropitem" | "moveslot0" | "moveslot1" | "moveslot2" | "moveslot3" | "moveslot4" | "moveslot5" | "useslot0" | "useslot1" | "useslot2" | "useslot3" | "useslot4" | "useslot5" | "drunkenhaze" | "earthquake" | "eattree" | "elementalfury" | "ensnare" | "ensnareoff" | "ensnareon" | "entangle" | "entangleinstant" | "entanglingroots" | "etherealform" | "evileye" | "faeriefire" | "faeriefireoff" | "faeriefireon" | "fanofknives" | "farsight" | "fingerofdeath" | "firebolt" | "flamestrike" | "flamingarrows" | "flamingarrowstarg" | "flamingattack" | "flamingattacktarg" | "flare" | "forceboard" | "forceofnature" | "forkedlightning" | "freezingbreath" | "frenzy" | "frenzyoff" | "frenzyon" | "frostarmor" | "frostarmoroff" | "frostarmoron" | "frostnova" | "getitem" | "gold2lumber" | "grabtree" | "harvest" | "heal" | "healingspray" | "healingward" | "healingwave" | "healoff" | "healon" | "hex" | "holdposition" | "holybolt" | "howlofterror" | "humanbuild" | "immolation" | "impale" | "incineratearrow" | "incineratearrowoff" | "incineratearrowon" | "inferno" | "innerfire" | "innerfireoff" | "innerfireon" | "instant" | "invisibility" | "lavamonster" | "lightningshield" | "loadarcher" | "loadcorpse" | "loadcorpseinstant" | "locustswarm" | "lumber2gold" | "magicdefense" | "magicleash" | "magicundefense" | "manaburn" | "manaflareoff" | "manaflareon" | "manashieldoff" | "manashieldon" | "massteleport" | "mechanicalcritter" | "metamorphosis" | "militia" | "militiaconvert" | "militiaoff" | "militiaunconvert" | "mindrot" | "mirrorimage" | "monsoon" | "mount" | "mounthippogryph" | "move" | "moveAI" | "nagabuild" | "neutraldetectaoe" | "neutralinteract" | "neutralspell" | "nightelfbuild" | "orcbuild" | "parasite" | "parasiteoff" | "parasiteon" | "patrol" | "patrolAI" | "phaseshift" | "phaseshiftinstant" | "phaseshiftoff" | "phaseshifton" | "phoenixfire" | "phoenixmorph" | "poisonarrows" | "poisonarrowstarg" | "polymorph" | "possession" | "preservation" | "purge" | "rainofchaos" | "rainoffire" | "raisedead" | "raisedeadoff" | "raisedeadon" | "ravenform" | "recharge" | "rechargeoff" | "rechargeon" | "rejuvination" | "renew" | "renewoff" | "renewon" | "repair" | "repairoff" | "repairon" | "replenish" | "replenishlife" | "replenishlifeoff" | "replenishlifeon" | "replenishmana" | "replenishmanaoff" | "replenishmanaon" | "replenishoff" | "replenishon" | "request_hero" | "requestsacrifice" | "restoration" | "restorationoff" | "restorationon" | "resumebuild" | "resumeharvesting" | "resurrection" | "returnresources" | "revenge" | "revive" | "roar" | "robogoblin" | "root" | "sacrifice" | "sanctuary" | "scout" | "selfdestruct" | "selfdestructoff" | "selfdestructon" | "sentinel" | "follow" | "smart" | "setrally" | "shadowsight" | "shadowstrike" | "shockwave" | "silence" | "slow" | "slowoff" | "slowon" | "soulburn" | "soulpreservation" | "spellshield" | "spellshieldaoe" | "spellsteal" | "spellstealoff" | "spellstealon" | "spies" | "spiritlink" | "spiritofvengeance" | "spirittroll" | "spiritwolf" | "stampede" | "standdown" | "starfall" | "stasistrap" | "steal" | "stomp" | "stoneform" | "stunned" | "submerge" | "summonfactory" | "summongrizzly" | "summonphoenix" | "summonquillbeast" | "summonwareagle" | "tankdroppilot" | "tankloadpilot" | "tankpilot" | "taunt" | "thunderbolt" | "thunderclap" | "tornado" | "townbelloff" | "townbellon" | "tranquility" | "transmute" | "unavatar" | "unavengerform" | "unbearform" | "unburrow" | "uncoldarrows" | "uncorporealform" | "undeadbuild" | "undefend" | "undivineshield" | "unetherealform" | "unflamingarrows" | "unflamingattack" | "unholyfrenzy" | "unimmolation" | "unload" | "unloadall" | "unloadallcorpses" | "unloadallinstant" | "unpoisonarrows" | "unravenform" | "unrobogoblin" | "unroot" | "unstableconcoction" | "unstoneform" | "unsubmerge" | "unsummon" | "unwindwalk" | "vengeance" | "vengeanceinstant" | "vengeanceoff" | "vengeanceon" | "volcano" | "voodoo" | "ward" | "waterelemental" | "wateryminion" | "web" | "weboff" | "webon" | "whirlwind" | "windwalk" | "wispharvest") => number;
58
58
  }
59
59
  declare global {
60
60
  function orderId(...args: Parameters<typeof inner.orderId>): ReturnType<typeof inner.orderId>;
package/core/util.lua CHANGED
@@ -202,6 +202,12 @@ do
202
202
  moveslot3 = 852005,
203
203
  moveslot4 = 852006,
204
204
  moveslot5 = 852007,
205
+ useslot0 = 852008,
206
+ useslot1 = 852009,
207
+ useslot2 = 852010,
208
+ useslot3 = 852011,
209
+ useslot4 = 852012,
210
+ useslot5 = 852013,
205
211
  drunkenhaze = 852585,
206
212
  earthquake = 852121,
207
213
  eattree = 852146,
@@ -0,0 +1,7 @@
1
+ /** @noSelfInFile */
2
+ import { AbilityBehavior } from "../ability";
3
+ import { Destructor } from "../../../destroyable";
4
+ export declare class AlwaysEnabledAbilityBehavior extends AbilityBehavior {
5
+ protected onCreate(): void;
6
+ protected onDestroy(): Destructor;
7
+ }
@@ -0,0 +1,31 @@
1
+ local ____lualib = require("lualib_bundle")
2
+ local __TS__Class = ____lualib.__TS__Class
3
+ local __TS__ClassExtends = ____lualib.__TS__ClassExtends
4
+ local __TS__InstanceOf = ____lualib.__TS__InstanceOf
5
+ local ____exports = {}
6
+ local ____ability = require("engine.behaviour.ability")
7
+ local AbilityBehavior = ____ability.AbilityBehavior
8
+ local ____ability = require("engine.internal.ability")
9
+ local UnitAbility = ____ability.UnitAbility
10
+ local ____ability_2Ddisable_2Dcounter = require("engine.internal.misc.ability-disable-counter")
11
+ local increaseAbilityDisableCounter = ____ability_2Ddisable_2Dcounter.increaseAbilityDisableCounter
12
+ ____exports.AlwaysEnabledAbilityBehavior = __TS__Class()
13
+ local AlwaysEnabledAbilityBehavior = ____exports.AlwaysEnabledAbilityBehavior
14
+ AlwaysEnabledAbilityBehavior.name = "AlwaysEnabledAbilityBehavior"
15
+ __TS__ClassExtends(AlwaysEnabledAbilityBehavior, AbilityBehavior)
16
+ function AlwaysEnabledAbilityBehavior.prototype.onCreate(self)
17
+ local ability = self.ability
18
+ if not __TS__InstanceOf(ability, UnitAbility) then
19
+ return
20
+ end
21
+ increaseAbilityDisableCounter(ability.owner.handle, ability.typeId, -10)
22
+ end
23
+ function AlwaysEnabledAbilityBehavior.prototype.onDestroy(self)
24
+ local ability = self.ability
25
+ if not __TS__InstanceOf(ability, UnitAbility) then
26
+ return AbilityBehavior.prototype.onDestroy(self)
27
+ end
28
+ increaseAbilityDisableCounter(ability.owner.handle, ability.typeId, 10)
29
+ return AbilityBehavior.prototype.onDestroy(self)
30
+ end
31
+ return ____exports
@@ -33,4 +33,9 @@ export declare class ApplyBuffTargetAreaAbilityBehavior<T extends BuffConstructo
33
33
  onPointTargetImpact(caster: Unit, x: number, y: number): void;
34
34
  onWidgetTargetImpact(caster: Unit, target: Widget): void;
35
35
  }
36
+ export declare class ApplyBuffChannelingTargetAbilityBehavior<T extends BuffConstructor = typeof Buff> extends ApplyBuffAbilityBehavior<T> {
37
+ private buff?;
38
+ onUnitTargetChannelingStart(caster: Unit, target: Unit): void;
39
+ onStop(): void;
40
+ }
36
41
  export {};
@@ -123,4 +123,36 @@ function ApplyBuffTargetAreaAbilityBehavior.prototype.onWidgetTargetImpact(self,
123
123
  self.applyBuff(unit)
124
124
  end
125
125
  end
126
+ local behaviorByBuff = {}
127
+ ____exports.ApplyBuffChannelingTargetAbilityBehavior = __TS__Class()
128
+ local ApplyBuffChannelingTargetAbilityBehavior = ____exports.ApplyBuffChannelingTargetAbilityBehavior
129
+ ApplyBuffChannelingTargetAbilityBehavior.name = "ApplyBuffChannelingTargetAbilityBehavior"
130
+ __TS__ClassExtends(ApplyBuffChannelingTargetAbilityBehavior, ____exports.ApplyBuffAbilityBehavior)
131
+ function ApplyBuffChannelingTargetAbilityBehavior.prototype.onUnitTargetChannelingStart(self, caster, target)
132
+ local previousBuff = self.buff
133
+ if previousBuff ~= nil then
134
+ behaviorByBuff[previousBuff] = nil
135
+ previousBuff:destroy()
136
+ end
137
+ local buff = self.applyBuff(target)
138
+ if buff ~= nil then
139
+ behaviorByBuff[buff] = self
140
+ end
141
+ self.buff = buff
142
+ end
143
+ function ApplyBuffChannelingTargetAbilityBehavior.prototype.onStop(self)
144
+ local buff = self.buff
145
+ if buff ~= nil then
146
+ behaviorByBuff[buff] = nil
147
+ buff:destroy()
148
+ self.buff = nil
149
+ end
150
+ end
151
+ Buff.destroyEvent:addListener(function(buff)
152
+ local behavior = behaviorByBuff[buff]
153
+ if behavior ~= nil then
154
+ behaviorByBuff[buff] = nil
155
+ behavior.ability:interruptCast()
156
+ end
157
+ end)
126
158
  return ____exports
@@ -7,23 +7,21 @@ local AbilityBehavior = ____ability.AbilityBehavior
7
7
  local ____ability = require("engine.standard.fields.ability")
8
8
  local COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD = ____ability.COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD
9
9
  local MANA_COST_ABILITY_INTEGER_LEVEL_FIELD = ____ability.MANA_COST_ABILITY_INTEGER_LEVEL_FIELD
10
+ local ____math = require("math")
11
+ local max = ____math.max
12
+ local MINIMUM_POSITIVE_NORMALIZED_FLOAT = ____math.MINIMUM_POSITIVE_NORMALIZED_FLOAT
10
13
  ____exports.EmulateImpactAbilityBehavior = __TS__Class()
11
14
  local EmulateImpactAbilityBehavior = ____exports.EmulateImpactAbilityBehavior
12
15
  EmulateImpactAbilityBehavior.name = "EmulateImpactAbilityBehavior"
13
16
  __TS__ClassExtends(EmulateImpactAbilityBehavior, AbilityBehavior)
14
17
  function EmulateImpactAbilityBehavior.prototype.emulateImpact(self, caster)
15
- local abilityTypeId = self.ability.typeId
16
18
  local manaCost = self:resolveCurrentAbilityDependentValue(MANA_COST_ABILITY_INTEGER_LEVEL_FIELD)
17
19
  local cooldown = self:resolveCurrentAbilityDependentValue(COOLDOWN_ABILITY_FLOAT_LEVEL_FIELD)
18
- if caster:getAbilityRemainingCooldown(abilityTypeId) ~= 0 or caster.mana < manaCost then
20
+ if self.ability.cooldownRemaining ~= 0 or caster.mana < manaCost then
19
21
  return
20
22
  end
21
23
  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
24
+ self.ability.cooldownRemaining = max(cooldown, MINIMUM_POSITIVE_NORMALIZED_FLOAT)
27
25
  self:flashCasterEffect(caster)
28
26
  AbilityBehavior:forAll(self.ability, "onImpact", caster)
29
27
  end
@@ -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
@@ -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,21 @@ 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;
22
25
  protected resolveCurrentAbilityDependentValue<T extends boolean | number | string>(value: AbilityDependentValue<T>): T;
23
26
  protected resolveCurrentAbilityDependentValue<T extends boolean | number | string>(value?: AbilityDependentValue<T>): T | undefined;
24
- protected flashCasterEffect(widget: Widget): void;
27
+ protected flashCasterEffect(widget: Widget, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
28
+ protected flashTargetEffect(widget: Widget, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
25
29
  protected flashAreaEffect(x: number, y: number, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
26
30
  protected flashEffect(x: number, y: number, ...parametersOrDuration: [parameters?: EffectParameters] | [duration?: number, parameters?: EffectParameters]): void;
27
31
  protected flashSpecialEffect(...args: [...pointOrWidget: [x: number, y: number] | [widget: Widget], duration?: number]): void;
28
32
  private static MissileLaunchConfig;
29
33
  private get missileLaunchConfig();
34
+ protected onCreate(): void;
35
+ onValueChange(_value: ReadonlySubscribableAbilityDependentValue<string | number | boolean>): void;
30
36
  onMissileArrival(...parameters: NonNullable<Parameters["missileParameters"]>): void;
31
37
  onUnitGainAbility(_unit: Unit): void;
32
38
  onUnitLoseAbility(_unit: Unit): void;
@@ -1,6 +1,7 @@
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 = {}
@@ -23,7 +24,11 @@ local MISSILE_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.MISSILE_MODEL
23
24
  local MISSILE_SPEED_ABILITY_INTEGER_FIELD = ____ability.MISSILE_SPEED_ABILITY_INTEGER_FIELD
24
25
  local SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD = ____ability.SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD
25
26
  local SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD
27
+ local TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD = ____ability.TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD
28
+ local TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD = ____ability.TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD
26
29
  local ____ability = require("engine.object-field.ability")
30
+ local AbilityField = ____ability.AbilityField
31
+ local AbilityLevelField = ____ability.AbilityLevelField
27
32
  local resolveCurrentAbilityDependentValue = ____ability.resolveCurrentAbilityDependentValue
28
33
  local ____timer = require("core.types.timer")
29
34
  local Timer = ____timer.Timer
@@ -41,6 +46,7 @@ createUnitEventListener = function(key)
41
46
  end
42
47
  end
43
48
  local registeredCommandEventIds = {}
49
+ local subscribedValuesByAbilityBehavior = {}
44
50
  local ____class_2 = __TS__Class()
45
51
  ____class_2.name = ""
46
52
  function ____class_2.prototype.____constructor(self, abilityBehavior)
@@ -79,6 +85,21 @@ function AbilityBehavior.prototype.____constructor(self, ability, parameters)
79
85
  if parameters and parameters.isExclusiveOnImpactHandler then
80
86
  exclusiveOnImpactHandlerAbilityBehaviorByAbility[ability] = self
81
87
  end
88
+ self:onCreate()
89
+ end
90
+ function AbilityBehavior.prototype.onDestroy(self)
91
+ subscribedValuesByAbilityBehavior[self] = nil
92
+ return Behavior.prototype.onDestroy(self)
93
+ end
94
+ function AbilityBehavior.prototype.subscribe(self, value)
95
+ if __TS__InstanceOf(value, AbilityField) or __TS__InstanceOf(value, AbilityLevelField) then
96
+ local subscribedValues = subscribedValuesByAbilityBehavior[self]
97
+ if subscribedValues == nil then
98
+ subscribedValues = {}
99
+ subscribedValuesByAbilityBehavior[self] = subscribedValues
100
+ end
101
+ subscribedValues[value] = true
102
+ end
82
103
  end
83
104
  function AbilityBehavior.prototype.registerCommandEvent(self, orderTypeStringId)
84
105
  if orderTypeStringId == nil then
@@ -93,11 +114,22 @@ end
93
114
  function AbilityBehavior.prototype.resolveCurrentAbilityDependentValue(self, value)
94
115
  return resolveCurrentAbilityDependentValue(self.ability, value)
95
116
  end
96
- function AbilityBehavior.prototype.flashCasterEffect(self, widget)
117
+ function AbilityBehavior.prototype.flashCasterEffect(self, widget, ...)
118
+ local attachmentPoint = CASTER_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
97
119
  Effect:flash(
98
120
  CASTER_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
99
121
  widget,
100
- CASTER_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
122
+ attachmentPoint ~= "" and attachmentPoint or "origin",
123
+ ...
124
+ )
125
+ end
126
+ function AbilityBehavior.prototype.flashTargetEffect(self, widget, ...)
127
+ local attachmentPoint = TARGET_EFFECT_FIRST_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
128
+ Effect:flash(
129
+ TARGET_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
130
+ widget,
131
+ attachmentPoint ~= "" and attachmentPoint or "origin",
132
+ ...
101
133
  )
102
134
  end
103
135
  function AbilityBehavior.prototype.flashAreaEffect(self, x, y, ...)
@@ -125,14 +157,19 @@ function AbilityBehavior.prototype.flashSpecialEffect(self, xOrWidget, yOrDurati
125
157
  duration
126
158
  )
127
159
  else
160
+ local attachmentPoint = SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability)
128
161
  Effect:flash(
129
162
  SPECIAL_EFFECT_MODEL_PATHS_ABILITY_STRING_ARRAY_FIELD:getValue(self.ability, 0),
130
163
  xOrWidget,
131
- SPECIAL_EFFECT_ATTACHMENT_POINT_STRING_FIELD:getValue(self.ability),
164
+ attachmentPoint ~= "" and attachmentPoint or "origin",
132
165
  yOrDuration
133
166
  )
134
167
  end
135
168
  end
169
+ function AbilityBehavior.prototype.onCreate(self)
170
+ end
171
+ function AbilityBehavior.prototype.onValueChange(self, _value)
172
+ end
136
173
  function AbilityBehavior.prototype.onMissileArrival(self, ...)
137
174
  end
138
175
  function AbilityBehavior.prototype.onUnitGainAbility(self, _unit)
@@ -233,6 +270,18 @@ __TS__SetDescriptor(
233
270
  Unit.abilityChannelingFinishEvent:addListener(createUnitEventListener("onChannelingFinish"))
234
271
  Unit.abilityStopEvent:addListener(createUnitEventListener("onStop"))
235
272
  end)(AbilityBehavior)
273
+ local function checkBehaviorOnValueChange(behavior, field)
274
+ local subscribedValues = subscribedValuesByAbilityBehavior[behavior]
275
+ if subscribedValues ~= nil and subscribedValues[field] ~= nil then
276
+ behavior:onValueChange(field)
277
+ end
278
+ end
279
+ AbilityField.valueChangeEvent:addListener(function(ability, field)
280
+ ____exports.AbilityBehavior:forAll(ability, checkBehaviorOnValueChange, field)
281
+ end)
282
+ AbilityLevelField.valueChangeEvent:addListener(function(ability, field)
283
+ ____exports.AbilityBehavior:forAll(ability, checkBehaviorOnValueChange, field)
284
+ end)
236
285
  Ability.onCreate:addListener(function(ability)
237
286
  local createBehaviorFunctions = createBehaviorFunctionsByAbilityTypeId[ability.typeId]
238
287
  if createBehaviorFunctions ~= nil then
package/engine/buff.d.ts CHANGED
@@ -12,6 +12,7 @@ import { EffectParameters } from "../core/types/effect";
12
12
  import { UnitBehavior } from "./behaviour/unit";
13
13
  import type { Widget } from "../core/types/widget";
14
14
  import { Destructor } from "../destroyable";
15
+ import { Event } from "../event";
15
16
  export type BuffConstructor<T extends Buff<any> = Buff<any>, Args extends any[] = any> = OmitConstructor<typeof Buff<any>> & (new (...args: Args) => T);
16
17
  type EnumParameterValueType<T extends number> = T | AbilityEnumLevelField<T>;
17
18
  type NumberParameterValueType = number | AbilityNumberField | AbilityNumberLevelField;
@@ -55,6 +56,7 @@ export type BuffParameters<T extends Buff<any> = Buff> = Buff extends T ? {
55
56
  armorIncreaseFactor?: NumberParameterValueType;
56
57
  attackSpeedIncreaseFactor?: NumberParameterValueType;
57
58
  movementSpeedIncreaseFactor?: NumberParameterValueType;
59
+ evasionProbability?: NumberParameterValueType;
58
60
  damageFactor?: NumberParameterValueType;
59
61
  receivedDamageFactor?: NumberParameterValueType;
60
62
  receivedMagicDamageFactor?: NumberParameterValueType;
@@ -248,6 +250,8 @@ export declare class Buff<AdditionalParameters extends Prohibit<Record<string, a
248
250
  set attackSpeedIncreaseFactor(attackSpeedIncreaseFactor: number);
249
251
  get movementSpeedIncreaseFactor(): number;
250
252
  set movementSpeedIncreaseFactor(movementSpeedIncreaseFactor: number);
253
+ get evasionProbability(): number;
254
+ set evasionProbability(evasionProbability: number);
251
255
  get duration(): number;
252
256
  get remainingDuration(): number;
253
257
  set remainingDuration(remainingDuration: number);
@@ -264,5 +268,6 @@ export declare class Buff<AdditionalParameters extends Prohibit<Record<string, a
264
268
  onDeath(source: Unit | undefined): void;
265
269
  onDamageDealt(target: Unit, event: DamageEvent): void;
266
270
  onDamageReceived(source: Unit | undefined, event: DamageEvent): void;
271
+ static readonly destroyEvent: Event<[Buff<object>]>;
267
272
  }
268
273
  export {};
package/engine/buff.lua CHANGED
@@ -44,6 +44,8 @@ local ____unit = require("engine.behaviour.unit")
44
44
  local UnitBehavior = ____unit.UnitBehavior
45
45
  local ____arrays = require("utility.arrays")
46
46
  local forEach = ____arrays.forEach
47
+ local ____event = require("event")
48
+ local Event = ____event.Event
47
49
  local ____ability_2Dduration = require("engine.internal.mechanics.ability-duration")
48
50
  local getAbilityDuration = ____ability_2Dduration.getAbilityDuration
49
51
  local ____item = require("engine.internal.item")
@@ -98,6 +100,7 @@ local buffParametersKeys = {
98
100
  armorIncreaseFactor = true,
99
101
  attackSpeedIncreaseFactor = true,
100
102
  movementSpeedIncreaseFactor = true,
103
+ evasionProbability = true,
101
104
  damageFactor = true,
102
105
  receivedDamageFactor = true,
103
106
  receivedMagicDamageFactor = true,
@@ -180,6 +183,7 @@ local buffNumberParameters = {
180
183
  "durationIncreaseOnAutoAttack",
181
184
  "attackSpeedIncreaseFactor",
182
185
  "movementSpeedIncreaseFactor",
186
+ "evasionProbability",
183
187
  "armorIncrease",
184
188
  "damageFactor",
185
189
  "receivedDamageFactor",
@@ -296,6 +300,7 @@ buffHealingIntervalTimerCallback = function(buff)
296
300
  source:healTarget(buff[100], healingPerInterval)
297
301
  end
298
302
  end
303
+ local buffDestroyEvent = __TS__New(Event)
299
304
  ____exports.Buff = __TS__Class()
300
305
  local Buff = ____exports.Buff
301
306
  Buff.name = "Buff"
@@ -592,6 +597,7 @@ function Buff.prototype.onDestroy(self)
592
597
  removeUnitBonus(unit, bonusType, bonusId)
593
598
  end
594
599
  end
600
+ Event.invoke(buffDestroyEvent, self)
595
601
  return UnitBehavior.prototype.onDestroy(self)
596
602
  end
597
603
  function Buff.apply(self, ...)
@@ -1174,6 +1180,19 @@ __TS__SetDescriptor(
1174
1180
  },
1175
1181
  true
1176
1182
  )
1183
+ __TS__SetDescriptor(
1184
+ Buff.prototype,
1185
+ "evasionProbability",
1186
+ {
1187
+ get = function(self)
1188
+ return self:getUnitBonus(UnitBonusType.EVASION_PROBABILITY)
1189
+ end,
1190
+ set = function(self, evasionProbability)
1191
+ self:addOrUpdateOrRemoveUnitBonus(UnitBonusType.EVASION_PROBABILITY, evasionProbability)
1192
+ end
1193
+ },
1194
+ true
1195
+ )
1177
1196
  __TS__SetDescriptor(
1178
1197
  Buff.prototype,
1179
1198
  "duration",
@@ -1221,7 +1240,8 @@ __TS__SetDescriptor(
1221
1240
  end
1222
1241
  },
1223
1242
  true
1224
- );
1243
+ )
1244
+ Buff.destroyEvent = buffDestroyEvent;
1225
1245
  (function(self)
1226
1246
  local function destroyBuffIfNeeded(buff)
1227
1247
  if getUnitAbility(buff[100].handle, buff.typeId) ~= buff.handle then
@@ -35,6 +35,9 @@ export declare abstract class Ability extends Handle<jability> {
35
35
  setField(field: jabilitystringlevelfield, level: number, value: string): boolean;
36
36
  get levelCount(): number;
37
37
  abstract get level(): number;
38
+ abstract get cooldownRemaining(): number;
39
+ abstract set cooldownRemaining(cooldownRemaining: number);
40
+ abstract interruptCast(): void;
38
41
  static get onCreate(): Event<[Ability]>;
39
42
  static get destroyEvent(): Event<[Ability]>;
40
43
  }
@@ -45,6 +48,9 @@ export declare class UnrecognizedAbility extends Ability {
45
48
  readonly owner: Unit;
46
49
  constructor(typeId: number, owner: Unit);
47
50
  get level(): number;
51
+ get cooldownRemaining(): number;
52
+ set cooldownRemaining(_: number);
53
+ interruptCast(): void;
48
54
  }
49
55
  export declare class UnitAbility extends Ability {
50
56
  readonly owner: Unit;
@@ -55,7 +61,8 @@ export declare class UnitAbility extends Ability {
55
61
  get level(): number;
56
62
  set level(v: number);
57
63
  get cooldownRemaining(): number;
58
- set cooldownRemaining(v: number);
64
+ set cooldownRemaining(cooldownRemaining: number);
65
+ interruptCast(): void;
59
66
  static get onCreate(): Event<[UnitAbility]>;
60
67
  static get onDestroy(): Event<[UnitAbility]>;
61
68
  }
@@ -79,6 +86,9 @@ export declare class ItemAbility extends Ability {
79
86
  setField(field: jabilitybooleanlevelfield, level: number, value: boolean): boolean;
80
87
  setField(field: jabilitystringlevelfield, level: number, value: string): boolean;
81
88
  get level(): number;
89
+ get cooldownRemaining(): number;
90
+ set cooldownRemaining(cooldownRemaining: number);
91
+ interruptCast(): void;
82
92
  static get onCreate(): Event<[ItemAbility]>;
83
93
  static get onDestroy(): Event<[ItemAbility]>;
84
94
  }