warscript 0.0.1-dev.d30161d → 0.0.1-dev.d3ce64a

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 (179) hide show
  1. package/attributes.d.ts +5 -0
  2. package/attributes.lua +8 -1
  3. package/config.d.ts +5 -0
  4. package/config.lua +10 -0
  5. package/core/types/effect.d.ts +14 -6
  6. package/core/types/effect.lua +131 -35
  7. package/core/types/frame.d.ts +6 -0
  8. package/core/types/frame.lua +91 -1
  9. package/core/types/order.d.ts +1 -0
  10. package/core/types/order.lua +11 -1
  11. package/core/types/sound.d.ts +17 -24
  12. package/core/types/sound.lua +99 -24
  13. package/core/types/timer.d.ts +6 -7
  14. package/core/types/timer.lua +18 -21
  15. package/core/util.d.ts +1 -1
  16. package/core/util.lua +18 -1
  17. package/decl/native.d.ts +840 -786
  18. package/engine/behavior.d.ts +2 -2
  19. package/engine/behavior.lua +6 -6
  20. package/engine/behaviour/ability/always-enabled.d.ts +7 -0
  21. package/engine/behaviour/ability/always-enabled.lua +31 -0
  22. package/engine/behaviour/ability/apply-buff.d.ts +8 -5
  23. package/engine/behaviour/ability/apply-buff.lua +32 -0
  24. package/engine/behaviour/ability/apply-unit-behavior.lua +1 -0
  25. package/engine/behaviour/ability/damage.d.ts +9 -3
  26. package/engine/behaviour/ability/damage.lua +26 -38
  27. package/engine/behaviour/ability/emulate-impact.d.ts +6 -0
  28. package/engine/behaviour/ability/emulate-impact.lua +35 -0
  29. package/engine/behaviour/ability/instant-impact.d.ts +2 -2
  30. package/engine/behaviour/ability/instant-impact.lua +4 -19
  31. package/engine/behaviour/ability/on-command-impact.d.ts +8 -0
  32. package/engine/behaviour/ability/on-command-impact.lua +25 -0
  33. package/engine/behaviour/ability/remove-buffs.d.ts +16 -0
  34. package/engine/behaviour/ability/remove-buffs.lua +28 -0
  35. package/engine/behaviour/ability.d.ts +20 -4
  36. package/engine/behaviour/ability.lua +111 -38
  37. package/engine/behaviour/unit.d.ts +17 -0
  38. package/engine/behaviour/unit.lua +105 -0
  39. package/engine/buff.d.ts +84 -43
  40. package/engine/buff.lua +385 -226
  41. package/engine/internal/ability.d.ts +18 -13
  42. package/engine/internal/ability.lua +87 -76
  43. package/engine/internal/item/ability.lua +106 -0
  44. package/engine/internal/item+owner.lua +2 -2
  45. package/engine/internal/item.d.ts +4 -3
  46. package/engine/internal/item.lua +56 -25
  47. package/engine/internal/mechanics/ability-duration.lua +1 -1
  48. package/engine/internal/misc/ability-disable-counter.d.ts +2 -0
  49. package/engine/internal/misc/ability-disable-counter.lua +13 -0
  50. package/engine/internal/misc/damage-metadata-by-target.d.ts +2 -0
  51. package/engine/internal/misc/damage-metadata-by-target.lua +5 -0
  52. package/engine/internal/object-data/auto-attack-speed-increase.d.ts +1 -1
  53. package/engine/internal/object-data/auto-attack-speed-increase.lua +2 -0
  54. package/engine/internal/object-data/evasion-probability.d.ts +2 -0
  55. package/engine/internal/object-data/evasion-probability.lua +16 -0
  56. package/engine/internal/unit/ability.d.ts +10 -1
  57. package/engine/internal/unit/ability.lua +36 -14
  58. package/engine/internal/unit/add-item-to-slot-init.d.ts +2 -0
  59. package/engine/internal/unit/add-item-to-slot-init.lua +23 -0
  60. package/engine/internal/unit/add-item-to-slot.d.ts +2 -0
  61. package/engine/internal/unit/add-item-to-slot.lua +52 -0
  62. package/engine/internal/unit/allowed-targets.d.ts +1 -1
  63. package/engine/internal/unit/allowed-targets.lua +9 -1
  64. package/engine/internal/unit/bonus.d.ts +6 -2
  65. package/engine/internal/unit/bonus.lua +23 -1
  66. package/engine/internal/unit/ignore-events-items.d.ts +2 -0
  67. package/engine/internal/unit/ignore-events-items.lua +5 -0
  68. package/engine/internal/unit/item.d.ts +24 -0
  69. package/engine/internal/unit/item.lua +78 -0
  70. package/engine/internal/unit/main-selected.d.ts +13 -0
  71. package/engine/internal/unit/main-selected.lua +51 -0
  72. package/engine/internal/unit+ability.lua +2 -2
  73. package/engine/internal/unit+damage.d.ts +2 -11
  74. package/engine/internal/unit+damage.lua +10 -14
  75. package/engine/internal/unit+spellSteal.lua +1 -2
  76. package/engine/internal/unit-missile-launch.lua +25 -6
  77. package/engine/internal/unit.d.ts +50 -13
  78. package/engine/internal/unit.lua +314 -116
  79. package/engine/internal/utility.lua +12 -0
  80. package/engine/lightning.d.ts +12 -5
  81. package/engine/lightning.lua +48 -14
  82. package/engine/local-client.d.ts +7 -2
  83. package/engine/local-client.lua +82 -0
  84. package/engine/object-data/auxiliary/animation-name.d.ts +1 -0
  85. package/engine/object-data/auxiliary/animation-name.lua +16 -0
  86. package/engine/object-data/auxiliary/attachment-preset.d.ts +7 -2
  87. package/engine/object-data/auxiliary/attachment-preset.lua +4 -3
  88. package/engine/object-data/auxiliary/attack-type.d.ts +7 -8
  89. package/engine/object-data/auxiliary/attack-type.lua +42 -0
  90. package/engine/object-data/auxiliary/movement-type.d.ts +7 -7
  91. package/engine/object-data/auxiliary/movement-type.lua +22 -0
  92. package/engine/object-data/auxiliary/sound-eax.d.ts +10 -0
  93. package/engine/object-data/auxiliary/sound-eax.lua +2 -0
  94. package/engine/object-data/auxiliary/sound-preset-name.d.ts +5 -1
  95. package/engine/object-data/auxiliary/tech-tree-dependency.d.ts +1 -1
  96. package/engine/object-data/auxiliary/unit-attribute.d.ts +6 -0
  97. package/engine/object-data/auxiliary/unit-attribute.lua +9 -0
  98. package/engine/object-data/entry/ability-type/berserk.d.ts +2 -0
  99. package/engine/object-data/entry/ability-type/berserk.lua +13 -0
  100. package/engine/object-data/entry/ability-type/blank-configurable.lua +12 -1
  101. package/engine/object-data/entry/ability-type/carrion-swarm.d.ts +14 -0
  102. package/engine/object-data/entry/ability-type/carrion-swarm.lua +65 -0
  103. package/engine/object-data/entry/ability-type/disease-cloud.lua +2 -2
  104. package/engine/object-data/entry/ability-type/engineering-upgrade.lua +2 -2
  105. package/engine/object-data/entry/ability-type/ensnare.d.ts +12 -0
  106. package/engine/object-data/entry/ability-type/ensnare.lua +52 -0
  107. package/engine/object-data/entry/ability-type/feral-spirit.lua +2 -2
  108. package/engine/object-data/entry/ability-type/permanent-invisibility.d.ts +8 -0
  109. package/engine/object-data/entry/ability-type/permanent-invisibility.lua +26 -0
  110. package/engine/object-data/entry/ability-type/phase-shift.d.ts +10 -0
  111. package/engine/object-data/entry/ability-type/phase-shift.lua +39 -0
  112. package/engine/object-data/entry/ability-type/phoenix-morph.lua +4 -4
  113. package/engine/object-data/entry/ability-type/raise-dead.d.ts +17 -0
  114. package/engine/object-data/entry/ability-type/raise-dead.lua +78 -0
  115. package/engine/object-data/entry/ability-type/shock-wave.d.ts +4 -0
  116. package/engine/object-data/entry/ability-type/shock-wave.lua +26 -0
  117. package/engine/object-data/entry/ability-type/slow-poison.d.ts +10 -0
  118. package/engine/object-data/entry/ability-type/slow-poison.lua +58 -0
  119. package/engine/object-data/entry/ability-type/summon-quilbeast.lua +2 -2
  120. package/engine/object-data/entry/ability-type/summon-water-elemental.lua +2 -2
  121. package/engine/object-data/entry/ability-type/web.d.ts +12 -0
  122. package/engine/object-data/entry/ability-type/web.lua +52 -0
  123. package/engine/object-data/entry/ability-type.d.ts +19 -17
  124. package/engine/object-data/entry/ability-type.lua +89 -33
  125. package/engine/object-data/entry/buff-type/applicable.lua +18 -37
  126. package/engine/object-data/entry/buff-type.d.ts +6 -12
  127. package/engine/object-data/entry/buff-type.lua +13 -29
  128. package/engine/object-data/entry/destructible-type.d.ts +1 -1
  129. package/engine/object-data/entry/item-type.d.ts +15 -1
  130. package/engine/object-data/entry/item-type.lua +93 -2
  131. package/engine/object-data/entry/lightning-type.d.ts +1 -1
  132. package/engine/object-data/entry/sound-preset.d.ts +33 -0
  133. package/engine/object-data/entry/sound-preset.lua +140 -0
  134. package/engine/object-data/entry/unit-type.d.ts +10 -3
  135. package/engine/object-data/entry/unit-type.lua +155 -92
  136. package/engine/object-data/entry/upgrade.d.ts +1 -1
  137. package/engine/object-data/entry/upgrade.lua +4 -4
  138. package/engine/object-data/entry.d.ts +16 -14
  139. package/engine/object-data/entry.lua +60 -32
  140. package/engine/object-data/utility/object-data-entry-id-generator.lua +7 -0
  141. package/engine/object-field/ability.d.ts +26 -3
  142. package/engine/object-field/ability.lua +54 -1
  143. package/engine/object-field/unit.d.ts +46 -3
  144. package/engine/object-field/unit.lua +173 -7
  145. package/engine/object-field.d.ts +11 -3
  146. package/engine/object-field.lua +162 -76
  147. package/engine/standard/entries/buff-type.d.ts +3 -0
  148. package/engine/standard/entries/buff-type.lua +3 -0
  149. package/engine/standard/entries/sound-preset.d.ts +10 -0
  150. package/engine/standard/entries/sound-preset.lua +10 -0
  151. package/engine/standard/fields/ability.d.ts +2 -0
  152. package/engine/standard/fields/ability.lua +2 -0
  153. package/engine/unit.d.ts +3 -0
  154. package/engine/unit.lua +3 -0
  155. package/index.d.ts +1 -0
  156. package/index.lua +1 -0
  157. package/net/socket.d.ts +7 -1
  158. package/net/socket.lua +45 -4
  159. package/network.d.ts +1 -0
  160. package/network.lua +3 -2
  161. package/objutil/buff.lua +2 -3
  162. package/objutil/unit.lua +8 -0
  163. package/package.json +2 -2
  164. package/patch-lua.d.ts +0 -0
  165. package/patch-lua.lua +10 -0
  166. package/utility/arrays.d.ts +9 -1
  167. package/utility/arrays.lua +37 -3
  168. package/utility/functions.d.ts +1 -0
  169. package/utility/functions.lua +1 -0
  170. package/utility/lazy.d.ts +2 -0
  171. package/utility/lazy.lua +14 -0
  172. package/utility/linked-set.d.ts +12 -2
  173. package/utility/linked-set.lua +8 -2
  174. package/utility/lua-maps.d.ts +3 -0
  175. package/utility/lua-maps.lua +16 -0
  176. package/utility/lua-sets.d.ts +1 -0
  177. package/utility/lua-sets.lua +3 -0
  178. package/utility/reflection.lua +11 -7
  179. package/utility/types.d.ts +1 -0
@@ -7,14 +7,33 @@ local ____event = require("event")
7
7
  local Event = ____event.Event
8
8
  local ____timer = require("core.types.timer")
9
9
  local Timer = ____timer.Timer
10
+ local ____lua_2Dsets = require("utility.lua-sets")
11
+ local luaSetOf = ____lua_2Dsets.luaSetOf
10
12
  local autoAttackFinishEvent = __TS__New(Event)
11
13
  rawset(Unit, "autoAttackFinishEvent", autoAttackFinishEvent)
12
14
  local eventTimerByUnit = {}
13
- local function reset(source)
14
- local eventTimer = eventTimerByUnit[source]
15
- if eventTimer then
16
- eventTimer:destroy()
17
- eventTimerByUnit[source] = nil
15
+ local instantOrderIds = luaSetOf(
16
+ orderId("avatar"),
17
+ orderId("berserk"),
18
+ orderId("divineshield"),
19
+ orderId("immolation"),
20
+ orderId("moveslot0"),
21
+ orderId("moveslot1"),
22
+ orderId("moveslot2"),
23
+ orderId("moveslot3"),
24
+ orderId("moveslot4"),
25
+ orderId("moveslot5"),
26
+ orderId("unavatar"),
27
+ orderId("undivineshield"),
28
+ orderId("unimmolation")
29
+ )
30
+ local function reset(source, orderId)
31
+ if not (instantOrderIds[orderId] ~= nil) then
32
+ local eventTimer = eventTimerByUnit[source]
33
+ if eventTimer then
34
+ eventTimer:destroy()
35
+ eventTimerByUnit[source] = nil
36
+ end
18
37
  end
19
38
  end
20
39
  Unit.onImmediateOrder:addListener(reset)
@@ -25,7 +44,7 @@ local function timerCallback(source, target)
25
44
  Event.invoke(autoAttackFinishEvent, source, target)
26
45
  end
27
46
  Unit.autoAttackStartEvent:addListener(function(source, target)
28
- local attackPoint = source.weapons[1].impactDelay
47
+ local attackPoint = (source:chooseWeapon(target) or source.firstWeapon).impactDelay
29
48
  local timer = Timer:simple(attackPoint, timerCallback, source, target)
30
49
  eventTimerByUnit[source] = timer
31
50
  end)
@@ -11,6 +11,10 @@ import { Ability, UnitAbility } from "./ability";
11
11
  import { Widget } from "../../core/types/widget";
12
12
  import type { UnitTypeId } from "../object-data/entry/unit-type";
13
13
  import { CombatClassification, CombatClassifications } from "../object-data/auxiliary/combat-classification";
14
+ import { MovementType } from "../object-data/auxiliary/movement-type";
15
+ import { UnitAttribute } from "../object-data/auxiliary/unit-attribute";
16
+ import { AttackType } from "../object-data/auxiliary/attack-type";
17
+ import { AttributesHolder } from "../../attributes";
14
18
  export type UnitClassification = junittype;
15
19
  export declare namespace UnitClassification {
16
20
  const STRUCTURE: junittype;
@@ -19,6 +23,7 @@ export declare namespace UnitClassification {
19
23
  const GROUND: junittype;
20
24
  const SUMMONED: junittype;
21
25
  const MECHANICAL: junittype;
26
+ const WORKER: junittype;
22
27
  const ANCIENT: junittype;
23
28
  const SUICIDAL: junittype;
24
29
  const TAUREN: junittype;
@@ -36,14 +41,18 @@ type AbilityDispatcherTable<T extends any[] = []> = {
36
41
  readonly [id: number]: Event<[Unit, Ability, ...T]>;
37
42
  };
38
43
  type AbilityEventDispatcher<T extends any[] = []> = Event<[Unit, Ability, ...T]> & AbilityDispatcherTable<T>;
39
- export interface DamagingEvent {
44
+ export interface DamagingEvent extends AttributesHolder {
40
45
  amount: number;
41
- attackType: jattacktype;
46
+ attackType: AttackType;
42
47
  damageType: jdamagetype;
43
48
  weaponType: jweapontype;
49
+ metadata: unknown;
44
50
  readonly isAttack: boolean;
51
+ readonly originalAmount: number;
52
+ readonly originalMetadata: unknown;
53
+ preventRetaliation(this: DamagingEvent): void;
45
54
  }
46
- export type DamageEvent = DamagingEvent & {
55
+ export type DamageEvent = Omit<DamagingEvent, "preventRetaliation"> & {
47
56
  preventDeath<P extends any[]>(this: DamageEvent, callback: (this: void, ...parameters: P) => any, ...parameters: P): void;
48
57
  };
49
58
  export type AttackDamageEvent = DamagingEvent & {
@@ -75,6 +84,8 @@ export declare class UnitWeapon {
75
84
  set cooldown(cooldown: number);
76
85
  get damage(): [minimumDamage: number, maximumDamage: number];
77
86
  set damage([minimumDamage, maximumDamage]: [number, number]);
87
+ get allowedTargetCombatClassifications(): CombatClassifications;
88
+ set allowedTargetCombatClassifications(allowedTargetCombatClassifications: CombatClassifications);
78
89
  get damageBase(): number;
79
90
  set damageBase(damageBase: number);
80
91
  get damageDiceCount(): number;
@@ -93,20 +104,29 @@ export declare class UnitWeapon {
93
104
  set missileSpeed(missileSpeed: number);
94
105
  }
95
106
  declare const enum UnitPropertyKey {
96
- IS_PAUSED = 100,
97
- STUN_COUNTER = 101,
98
- DELAY_HEALTH_CHECKS_COUNTER = 102,
99
- DELAY_HEALTH_CHECKS_HEALTH_BONUS = 103,
100
- PREVENT_DEATH_HEALTH_BONUS = 104,
101
- IS_TEAM_GLOW_HIDDEN = 105
107
+ SYNC_ID = 100,
108
+ IS_PAUSED = 101,
109
+ STUN_COUNTER = 102,
110
+ DELAY_HEALTH_CHECKS_COUNTER = 103,
111
+ DELAY_HEALTH_CHECKS_HEALTH_BONUS = 104,
112
+ PREVENT_DEATH_HEALTH_BONUS = 105,
113
+ IS_TEAM_GLOW_HIDDEN = 106,
114
+ LAST_X = 107,
115
+ LAST_Y = 108
102
116
  }
117
+ export type UnitSyncId = number & {
118
+ readonly __unitSyncId: unique symbol;
119
+ };
103
120
  export declare class Unit extends Handle<junit> {
121
+ readonly syncId: UnitSyncId;
104
122
  private [UnitPropertyKey.IS_PAUSED]?;
105
123
  private [UnitPropertyKey.STUN_COUNTER]?;
106
124
  private [UnitPropertyKey.DELAY_HEALTH_CHECKS_COUNTER]?;
107
125
  private [UnitPropertyKey.DELAY_HEALTH_CHECKS_HEALTH_BONUS]?;
108
126
  private [UnitPropertyKey.PREVENT_DEATH_HEALTH_BONUS]?;
109
127
  private [UnitPropertyKey.IS_TEAM_GLOW_HIDDEN]?;
128
+ private [UnitPropertyKey.LAST_X]?;
129
+ private [UnitPropertyKey.LAST_Y]?;
110
130
  private _owner?;
111
131
  private _timeScale?;
112
132
  private events?;
@@ -127,6 +147,7 @@ export declare class Unit extends Handle<junit> {
127
147
  get isAlive(): boolean;
128
148
  get isDead(): boolean;
129
149
  get isIllusion(): boolean;
150
+ get isStunned(): boolean;
130
151
  get combatClassifications(): CombatClassifications;
131
152
  set combatClassifications(combatClassifications: CombatClassifications);
132
153
  hasCombatClassification(combatClassification: CombatClassification): boolean;
@@ -141,14 +162,18 @@ export declare class Unit extends Handle<junit> {
141
162
  isEnemyOf(unit: Unit): boolean;
142
163
  playAnimation(animation: string, rarity?: jraritycontrol): void;
143
164
  playAnimation(animation: number): void;
165
+ resetAnimation(): void;
144
166
  queueAnimation(animation: string): void;
145
167
  get weapons(): [UnitWeapon, UnitWeapon];
146
168
  get firstWeapon(): UnitWeapon;
147
169
  get secondWeapon(): UnitWeapon;
170
+ chooseWeapon(target: Unit): UnitWeapon | undefined;
148
171
  get level(): number;
149
172
  set level(v: number);
150
173
  get xp(): number;
151
174
  set xp(v: number);
175
+ get primaryAttribute(): UnitAttribute;
176
+ set primaryAttribute(primaryAttribute: UnitAttribute);
152
177
  get strengthBase(): number;
153
178
  set strengthBase(strengthBase: number);
154
179
  get strengthBonus(): number;
@@ -223,6 +248,8 @@ export declare class Unit extends Handle<junit> {
223
248
  set timeScale(v: number);
224
249
  get collisionSize(): number;
225
250
  get pathingCollisionRange(): number;
251
+ get movementType(): MovementType;
252
+ set movementType(movementType: MovementType);
226
253
  set pathing(v: boolean);
227
254
  isSelected(player: Player): boolean;
228
255
  explode(): void;
@@ -273,6 +300,7 @@ export declare class Unit extends Handle<junit> {
273
300
  get onUnitInRange(): Record<number, Event<[Unit]>>;
274
301
  get onManaEqual(): Record<number, Event<[Unit, number]>>;
275
302
  get manaEvent(): Record<Operator, Record<number, Event<[Unit]>>>;
303
+ get targetAcquiredEvent(): Event;
276
304
  get onSelect(): Event;
277
305
  get onDeselect(): Event;
278
306
  get onImmediateOrder(): Event<[number]>;
@@ -287,7 +315,7 @@ export declare class Unit extends Handle<junit> {
287
315
  static getInRange(x: number, y: number, range: number, predicate?: (unit: Unit) => boolean): Unit[];
288
316
  static getInCollisionRange(x: number, y: number, range: number, predicate?: (unit: Unit) => boolean): Unit[];
289
317
  static getInSector(pos: Vec2, range: number, offsetAngle: number, centralAngle: number): Unit[];
290
- static getSelectionOf(player: Player): Unit[];
318
+ static getSelectionOf(player: Player, target?: Unit[]): Unit[];
291
319
  static readonly deathEvent: UnitTriggerEvent<[Unit]>;
292
320
  static readonly onDecay: UnitTriggerEvent<[]>;
293
321
  static readonly onResurrect: InitializingEvent<[Unit], void>;
@@ -322,9 +350,17 @@ export declare class Unit extends Handle<junit> {
322
350
  static readonly autoAttackStartEvent: UnitTriggerEvent<[Unit]>;
323
351
  static readonly onDamaging: Event<[source: Unit | undefined, target: Unit, event: DamagingEvent]>;
324
352
  static readonly onDamage: InitializingEvent<[source: Unit | undefined, target: Unit, event: DamageEvent], jtrigger>;
325
- static onItemDrop: UnitTriggerEvent<[Item]>;
326
- static onItemPickup: UnitTriggerEvent<[Item]>;
327
- static onItemUse: UnitTriggerEvent<[Item]>;
353
+ static itemDroppedEvent: UnitTriggerEvent<[Item]>;
354
+ static itemPickedUpEvent: UnitTriggerEvent<[Item]>;
355
+ static itemUsedEvent: UnitTriggerEvent<[Item]>;
356
+ static itemStackedEvent: UnitTriggerEvent<[Item]>;
357
+ static get itemUseOrderEvent(): Event<[unit: Unit, item: Item]>;
358
+ static get itemMoveOrderEvent(): Event<[
359
+ unit: Unit,
360
+ item: Item,
361
+ slotFrom: 0 | 1 | 2 | 3 | 4 | 5,
362
+ slotTo: 0 | 1 | 2 | 3 | 4 | 5
363
+ ]>;
328
364
  static get onCreate(): EventDispatcher<[Unit], [Unit]>;
329
365
  static get destroyEvent(): EventDispatcher<[Unit], [Unit]>;
330
366
  getField(field: junitintegerfield | junitrealfield): number;
@@ -335,5 +371,6 @@ export declare class Unit extends Handle<junit> {
335
371
  setField(field: junitbooleanfield, value: boolean): boolean;
336
372
  setField(field: junitstringfield, value: string): boolean;
337
373
  toString(): string;
374
+ static getBySyncId(syncId: UnitSyncId): Unit | undefined;
338
375
  }
339
376
  export {};