warscript 0.0.1-dev.db137e7 → 0.0.1-dev.dc37dce

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 (111) hide show
  1. package/attributes.d.ts +1 -0
  2. package/attributes.lua +9 -0
  3. package/binarywriter.lua +0 -12
  4. package/core/types/player.d.ts +16 -0
  5. package/core/types/player.lua +57 -14
  6. package/core/types/sound.lua +1 -1
  7. package/core/types/tileCell.d.ts +2 -1
  8. package/core/types/tileCell.lua +5 -0
  9. package/core/types/timer.d.ts +3 -2
  10. package/core/types/timer.lua +8 -2
  11. package/destroyable.d.ts +1 -0
  12. package/destroyable.lua +9 -0
  13. package/engine/behavior.d.ts +10 -2
  14. package/engine/behavior.lua +157 -76
  15. package/engine/behaviour/ability/apply-buff.lua +4 -4
  16. package/engine/behaviour/ability/remove-buffs.d.ts +9 -0
  17. package/engine/behaviour/ability/remove-buffs.lua +21 -0
  18. package/engine/behaviour/ability.d.ts +11 -6
  19. package/engine/behaviour/ability.lua +31 -1
  20. package/engine/behaviour/unit/stun-immunity.d.ts +7 -5
  21. package/engine/behaviour/unit/stun-immunity.lua +6 -5
  22. package/engine/behaviour/unit.d.ts +9 -3
  23. package/engine/behaviour/unit.lua +106 -24
  24. package/engine/buff.d.ts +64 -18
  25. package/engine/buff.lua +354 -151
  26. package/engine/internal/item.d.ts +12 -12
  27. package/engine/internal/item.lua +41 -26
  28. package/engine/internal/mechanics/cast-ability.lua +6 -3
  29. package/engine/internal/object-data/attribute-bonus.lua +2 -2
  30. package/engine/internal/object-data/health-bonus.d.ts +2 -0
  31. package/engine/internal/object-data/health-bonus.lua +16 -0
  32. package/engine/internal/object-data/mana-bonus.d.ts +2 -0
  33. package/engine/internal/object-data/mana-bonus.lua +16 -0
  34. package/engine/internal/object-data/mana-regeneration-rate-increase-factor.d.ts +2 -0
  35. package/engine/internal/object-data/mana-regeneration-rate-increase-factor.lua +16 -0
  36. package/engine/internal/unit/ability.d.ts +14 -14
  37. package/engine/internal/unit/ability.lua +72 -45
  38. package/engine/internal/unit/attributes.d.ts +17 -0
  39. package/engine/internal/unit/attributes.lua +46 -0
  40. package/engine/internal/unit/bonus.d.ts +6 -0
  41. package/engine/internal/unit/bonus.lua +33 -3
  42. package/engine/internal/unit/fly-height.d.ts +7 -0
  43. package/engine/internal/unit/fly-height.lua +20 -0
  44. package/engine/internal/unit/interrupts.d.ts +12 -0
  45. package/engine/internal/unit/interrupts.lua +28 -0
  46. package/engine/internal/unit/item.lua +1 -1
  47. package/engine/internal/unit/main-selected.lua +12 -27
  48. package/engine/internal/unit/range-event.d.ts +12 -0
  49. package/engine/internal/unit/range-event.lua +90 -0
  50. package/engine/internal/unit/scale.d.ts +7 -0
  51. package/engine/internal/unit/scale.lua +20 -0
  52. package/engine/internal/unit+bonus.lua +3 -3
  53. package/engine/internal/unit-missile-launch.lua +51 -20
  54. package/engine/internal/unit.d.ts +15 -19
  55. package/engine/internal/unit.lua +160 -183
  56. package/engine/local-client.d.ts +2 -0
  57. package/engine/local-client.lua +30 -0
  58. package/engine/object-data/auxiliary/health-regeneration-type.d.ts +8 -0
  59. package/engine/object-data/auxiliary/health-regeneration-type.lua +2 -0
  60. package/engine/object-data/auxiliary/unit-attribute.lua +1 -1
  61. package/engine/object-data/entry/ability-type/{armor-increase.d.ts → armor-bonus.d.ts} +3 -3
  62. package/engine/object-data/entry/ability-type/{armor-increase.lua → armor-bonus.lua} +9 -9
  63. package/engine/object-data/entry/ability-type/health-bonus.d.ts +8 -0
  64. package/engine/object-data/entry/ability-type/health-bonus.lua +26 -0
  65. package/engine/object-data/entry/ability-type/mana-bonus.d.ts +8 -0
  66. package/engine/object-data/entry/ability-type/mana-bonus.lua +26 -0
  67. package/engine/object-data/entry/ability-type/mana-regeneration.d.ts +8 -0
  68. package/engine/object-data/entry/ability-type/mana-regeneration.lua +26 -0
  69. package/engine/object-data/entry/ability-type/reincarnation.d.ts +8 -0
  70. package/engine/object-data/entry/ability-type/reincarnation.lua +26 -0
  71. package/engine/object-data/entry/ability-type.d.ts +2 -0
  72. package/engine/object-data/entry/ability-type.lua +88 -5
  73. package/engine/object-data/entry/buff-type/applicable.lua +113 -109
  74. package/engine/object-data/entry/destructible-type.d.ts +27 -1
  75. package/engine/object-data/entry/destructible-type.lua +155 -0
  76. package/engine/object-data/entry/unit-type.d.ts +4 -0
  77. package/engine/object-data/entry/unit-type.lua +76 -32
  78. package/engine/object-field/unit.d.ts +20 -5
  79. package/engine/object-field/unit.lua +61 -0
  80. package/engine/object-field.d.ts +9 -1
  81. package/engine/object-field.lua +265 -122
  82. package/engine/random.d.ts +1 -0
  83. package/engine/random.lua +8 -0
  84. package/engine/standard/fields/ability.d.ts +2 -2
  85. package/engine/standard/fields/ability.lua +2 -2
  86. package/engine/standard/fields/unit.d.ts +11 -3
  87. package/engine/standard/fields/unit.lua +15 -2
  88. package/engine/synchronization.d.ts +11 -0
  89. package/engine/synchronization.lua +77 -0
  90. package/engine/text-tag.lua +3 -2
  91. package/engine/unit.d.ts +5 -0
  92. package/engine/unit.lua +5 -0
  93. package/lualib_bundle.lua +118 -47
  94. package/net/socket.lua +1 -1
  95. package/objutil/buff.lua +10 -8
  96. package/objutil/object.lua +1 -1
  97. package/operation.lua +23 -17
  98. package/package.json +5 -5
  99. package/patch-lua.lua +15 -0
  100. package/utility/callback-array.d.ts +5 -1
  101. package/utility/callback-array.lua +16 -1
  102. package/utility/linked-map.d.ts +34 -0
  103. package/utility/linked-map.lua +101 -0
  104. package/utility/linked-set.d.ts +3 -1
  105. package/utility/linked-set.lua +40 -1
  106. package/utility/records.lua +20 -1
  107. package/utility/types.d.ts +3 -0
  108. /package/engine/internal/object-data/{armor-increase.d.ts → armor-bonus.d.ts} +0 -0
  109. /package/engine/internal/object-data/{armor-increase.lua → armor-bonus.lua} +0 -0
  110. /package/engine/object-data/entry/ability-type/{attribute-increase.d.ts → attribute-bonus.d.ts} +0 -0
  111. /package/engine/object-data/entry/ability-type/{attribute-increase.lua → attribute-bonus.lua} +0 -0
@@ -0,0 +1,77 @@
1
+ local ____lualib = require("lualib_bundle")
2
+ local __TS__New = ____lualib.__TS__New
3
+ local __TS__Promise = ____lualib.__TS__Promise
4
+ local __TS__Class = ____lualib.__TS__Class
5
+ local ____exports = {}
6
+ local ____player = require("core.types.player")
7
+ local Player = ____player.Player
8
+ local ____math = require("math")
9
+ local MAXIMUM_INTEGER = ____math.MAXIMUM_INTEGER
10
+ local MINIMUM_INTEGER = ____math.MINIMUM_INTEGER
11
+ local ____linked_2Dset = require("utility.linked-set")
12
+ local LinkedSet = ____linked_2Dset.LinkedSet
13
+ local ____event = require("event")
14
+ local Event = ____event.Event
15
+ local eventInvoke = Event.invoke
16
+ local createFrameByType = BlzCreateFrameByType
17
+ local createTrigger = CreateTrigger
18
+ local getOriginFrame = BlzGetOriginFrame
19
+ local getTriggerFrameValue = BlzGetTriggerFrameValue
20
+ local getTriggerPlayer = GetTriggerPlayer
21
+ local frameSetMinMaxValue = BlzFrameSetMinMaxValue
22
+ local frameSetValue = BlzFrameSetValue
23
+ local triggerAddAction = TriggerAddAction
24
+ local triggerRegisterFrameEvent = BlzTriggerRegisterFrameEvent
25
+ ____exports.synchronizer = function(getSyncId, getObject)
26
+ local queue = __TS__New(LinkedSet)
27
+ local socket = __TS__New(____exports.ObjectBus, getSyncId, getObject)
28
+ socket.event:addListener(function(_, object)
29
+ local ____opt_0 = queue:pop()
30
+ if ____opt_0 ~= nil then
31
+ ____opt_0(object)
32
+ end
33
+ end)
34
+ local function executor(____, resolve)
35
+ queue:add(resolve)
36
+ end
37
+ return function(player, object)
38
+ if player.isLocal then
39
+ socket:send(object)
40
+ end
41
+ return __TS__New(__TS__Promise, executor)
42
+ end
43
+ end
44
+ ____exports.ObjectBus = __TS__Class()
45
+ local ObjectBus = ____exports.ObjectBus
46
+ ObjectBus.name = "ObjectBus"
47
+ function ObjectBus.prototype.____constructor(self, getSyncId, getObject)
48
+ self.getSyncId = getSyncId
49
+ local syncSlider = createFrameByType(
50
+ "SLIDER",
51
+ "Synchronizer",
52
+ getOriginFrame(ORIGIN_FRAME_WORLD_FRAME, 0),
53
+ "",
54
+ 0
55
+ )
56
+ frameSetMinMaxValue(syncSlider, MINIMUM_INTEGER, MAXIMUM_INTEGER)
57
+ self.syncSlider = syncSlider
58
+ local event = __TS__New(Event)
59
+ local trigger = createTrigger()
60
+ triggerRegisterFrameEvent(trigger, syncSlider, FRAMEEVENT_SLIDER_VALUE_CHANGED)
61
+ triggerAddAction(
62
+ trigger,
63
+ function()
64
+ eventInvoke(
65
+ event,
66
+ Player:of(getTriggerPlayer()),
67
+ getObject(getTriggerFrameValue())
68
+ )
69
+ end
70
+ )
71
+ self.event = event
72
+ end
73
+ function ObjectBus.prototype.send(self, object)
74
+ local syncId = object ~= nil and self.getSyncId(object) or 0
75
+ frameSetValue(self.syncSlider, syncId)
76
+ end
77
+ return ____exports
@@ -36,6 +36,7 @@ local isUnitVisible = IsUnitVisible
36
36
  local getUnitFlyHeight = GetUnitFlyHeight
37
37
  local getUnitX = GetUnitX
38
38
  local getUnitY = GetUnitY
39
+ local unitAlive = UnitAlive
39
40
  local DEFAULT_FONT_SIZE = 0.024
40
41
  local function applyConfiguration(textTag, configuration)
41
42
  setTextTagFadepoint(textTag, configuration.fadepoint)
@@ -141,7 +142,7 @@ __TS__SetDescriptor(
141
142
  setTextTagText(
142
143
  ensureHandle(self),
143
144
  self[103] or "",
144
- DEFAULT_FONT_SIZE
145
+ fontSize
145
146
  )
146
147
  self[104] = fontSize
147
148
  end
@@ -333,7 +334,7 @@ Timer.onPeriod[1 / 64]:addListener(function()
333
334
  y,
334
335
  getUnitFlyHeight(unit) + getTerrainZ(x, y)
335
336
  )
336
- if isInView and not isUnitHidden(unit) and not isUnitLoaded(unit) and isUnitVisible(unit, PLAYER_LOCAL_HANDLE) then
337
+ if isInView and not isUnitHidden(unit) and not isUnitLoaded(unit) and isUnitVisible(unit, PLAYER_LOCAL_HANDLE) and unitAlive(unit) then
337
338
  setTextTagPosUnit(
338
339
  ensureHandle(textTag),
339
340
  unit,
package/engine/unit.d.ts CHANGED
@@ -19,6 +19,11 @@ import "./internal/unit/invulnerability-counter";
19
19
  import "./internal/unit/detach-missiles";
20
20
  import "./internal/unit/main-selected";
21
21
  import "./internal/unit/add-item-to-slot-init";
22
+ import "./internal/unit/attributes";
23
+ import "./internal/unit/fly-height";
24
+ import "./internal/unit/scale";
25
+ import "./internal/unit/interrupts";
26
+ import "./internal/unit/range-event";
22
27
  import "./internal/unit/band-aids/ancestral-spirit-cannibalize";
23
28
  export { Unit, DamagingEvent, DamageEvent } from "./internal/unit";
24
29
  export * from "./internal/unit+damage";
package/engine/unit.lua CHANGED
@@ -19,6 +19,11 @@ require("engine.internal.unit.invulnerability-counter")
19
19
  require("engine.internal.unit.detach-missiles")
20
20
  require("engine.internal.unit.main-selected")
21
21
  require("engine.internal.unit.add-item-to-slot-init")
22
+ require("engine.internal.unit.attributes")
23
+ require("engine.internal.unit.fly-height")
24
+ require("engine.internal.unit.scale")
25
+ require("engine.internal.unit.interrupts")
26
+ require("engine.internal.unit.range-event")
22
27
  require("engine.internal.unit.band-aids.ancestral-spirit-cannibalize")
23
28
  do
24
29
  local ____unit = require("engine.internal.unit")
package/lualib_bundle.lua CHANGED
@@ -653,7 +653,6 @@ do
653
653
  self.state = 0
654
654
  self.fulfilledCallbacks = {}
655
655
  self.rejectedCallbacks = {}
656
- self.finallyCallbacks = {}
657
656
  local success, ____error = ____pcall(
658
657
  executor,
659
658
  nil,
@@ -703,14 +702,40 @@ do
703
702
  return self["then"](self, nil, onRejected)
704
703
  end
705
704
  function __TS__Promise.prototype.finally(self, onFinally)
706
- if onFinally then
707
- local ____self_finallyCallbacks_2 = self.finallyCallbacks
708
- ____self_finallyCallbacks_2[#____self_finallyCallbacks_2 + 1] = onFinally
709
- if self.state ~= 0 then
710
- onFinally(nil)
711
- end
705
+ if type(onFinally) ~= "function" then
706
+ return self["then"](self, onFinally, onFinally)
712
707
  end
713
- return self
708
+ return self["then"](
709
+ self,
710
+ function(____, x)
711
+ local ____self_2 = __TS__New(
712
+ __TS__Promise,
713
+ function(____, resolve) return resolve(
714
+ nil,
715
+ onFinally(nil)
716
+ ) end
717
+ )
718
+ return ____self_2["then"](
719
+ ____self_2,
720
+ function() return x end
721
+ )
722
+ end,
723
+ function(____, e)
724
+ local ____self_3 = __TS__New(
725
+ __TS__Promise,
726
+ function(____, resolve) return resolve(
727
+ nil,
728
+ onFinally(nil)
729
+ ) end
730
+ )
731
+ return ____self_3["then"](
732
+ ____self_3,
733
+ function()
734
+ error(e, 0)
735
+ end
736
+ )
737
+ end
738
+ )
714
739
  end
715
740
  function __TS__Promise.prototype.resolve(self, value)
716
741
  if isPromiseLike(value) then
@@ -734,22 +759,11 @@ do
734
759
  end
735
760
  function __TS__Promise.prototype.invokeCallbacks(self, callbacks, value)
736
761
  local callbacksLength = #callbacks
737
- local finallyCallbacks = self.finallyCallbacks
738
- local finallyCallbacksLength = #finallyCallbacks
739
762
  if callbacksLength ~= 0 then
740
763
  for i = 1, callbacksLength - 1 do
741
764
  callbacks[i](callbacks, value)
742
765
  end
743
- if finallyCallbacksLength == 0 then
744
- return callbacks[callbacksLength](callbacks, value)
745
- end
746
- callbacks[callbacksLength](callbacks, value)
747
- end
748
- if finallyCallbacksLength ~= 0 then
749
- for i = 1, finallyCallbacksLength - 1 do
750
- finallyCallbacks[i](finallyCallbacks)
751
- end
752
- return finallyCallbacks[finallyCallbacksLength](finallyCallbacks)
766
+ return callbacks[callbacksLength](callbacks, value)
753
767
  end
754
768
  end
755
769
  function __TS__Promise.prototype.createPromiseResolvingCallback(self, f, resolve, reject)
@@ -904,8 +918,10 @@ local function __TS__ObjectAssign(target, ...)
904
918
  local sources = {...}
905
919
  for i = 1, #sources do
906
920
  local source = sources[i]
907
- for key in pairs(source) do
908
- target[key] = source[key]
921
+ if type(source) == "table" then
922
+ for key in pairs(source) do
923
+ target[key] = source[key]
924
+ end
909
925
  end
910
926
  end
911
927
  return target
@@ -1011,6 +1027,13 @@ do
1011
1027
  metatable = {}
1012
1028
  setmetatable(target, metatable)
1013
1029
  end
1030
+ if not isPrototype and not rawget(metatable, "_isOwnDescriptorMetatable") then
1031
+ local instanceMetatable = {}
1032
+ instanceMetatable._isOwnDescriptorMetatable = true
1033
+ setmetatable(instanceMetatable, metatable)
1034
+ setmetatable(target, instanceMetatable)
1035
+ metatable = instanceMetatable
1036
+ end
1014
1037
  local value = rawget(target, key)
1015
1038
  if value ~= nil then
1016
1039
  rawset(target, key, nil)
@@ -1383,46 +1406,70 @@ do
1383
1406
  return self:entries()
1384
1407
  end
1385
1408
  function Map.prototype.entries(self)
1409
+ local function getFirstKey()
1410
+ return self.firstKey
1411
+ end
1386
1412
  local items = self.items
1387
1413
  local nextKey = self.nextKey
1388
- local key = self.firstKey
1414
+ local key
1415
+ local started = false
1389
1416
  return {
1390
1417
  [Symbol.iterator] = function(self)
1391
1418
  return self
1392
1419
  end,
1393
1420
  next = function(self)
1394
- local result = {done = not key, value = {key, items[key]}}
1395
- key = nextKey[key]
1396
- return result
1421
+ if not started then
1422
+ started = true
1423
+ key = getFirstKey(nil)
1424
+ else
1425
+ key = nextKey[key]
1426
+ end
1427
+ return {done = not key, value = {key, items[key]}}
1397
1428
  end
1398
1429
  }
1399
1430
  end
1400
1431
  function Map.prototype.keys(self)
1432
+ local function getFirstKey()
1433
+ return self.firstKey
1434
+ end
1401
1435
  local nextKey = self.nextKey
1402
- local key = self.firstKey
1436
+ local key
1437
+ local started = false
1403
1438
  return {
1404
1439
  [Symbol.iterator] = function(self)
1405
1440
  return self
1406
1441
  end,
1407
1442
  next = function(self)
1408
- local result = {done = not key, value = key}
1409
- key = nextKey[key]
1410
- return result
1443
+ if not started then
1444
+ started = true
1445
+ key = getFirstKey(nil)
1446
+ else
1447
+ key = nextKey[key]
1448
+ end
1449
+ return {done = not key, value = key}
1411
1450
  end
1412
1451
  }
1413
1452
  end
1414
1453
  function Map.prototype.values(self)
1454
+ local function getFirstKey()
1455
+ return self.firstKey
1456
+ end
1415
1457
  local items = self.items
1416
1458
  local nextKey = self.nextKey
1417
- local key = self.firstKey
1459
+ local key
1460
+ local started = false
1418
1461
  return {
1419
1462
  [Symbol.iterator] = function(self)
1420
1463
  return self
1421
1464
  end,
1422
1465
  next = function(self)
1423
- local result = {done = not key, value = items[key]}
1424
- key = nextKey[key]
1425
- return result
1466
+ if not started then
1467
+ started = true
1468
+ key = getFirstKey(nil)
1469
+ else
1470
+ key = nextKey[key]
1471
+ end
1472
+ return {done = not key, value = items[key]}
1426
1473
  end
1427
1474
  }
1428
1475
  end
@@ -1999,44 +2046,68 @@ do
1999
2046
  return self:values()
2000
2047
  end
2001
2048
  function Set.prototype.entries(self)
2049
+ local function getFirstKey()
2050
+ return self.firstKey
2051
+ end
2002
2052
  local nextKey = self.nextKey
2003
- local key = self.firstKey
2053
+ local key
2054
+ local started = false
2004
2055
  return {
2005
2056
  [Symbol.iterator] = function(self)
2006
2057
  return self
2007
2058
  end,
2008
2059
  next = function(self)
2009
- local result = {done = not key, value = {key, key}}
2010
- key = nextKey[key]
2011
- return result
2060
+ if not started then
2061
+ started = true
2062
+ key = getFirstKey(nil)
2063
+ else
2064
+ key = nextKey[key]
2065
+ end
2066
+ return {done = not key, value = {key, key}}
2012
2067
  end
2013
2068
  }
2014
2069
  end
2015
2070
  function Set.prototype.keys(self)
2071
+ local function getFirstKey()
2072
+ return self.firstKey
2073
+ end
2016
2074
  local nextKey = self.nextKey
2017
- local key = self.firstKey
2075
+ local key
2076
+ local started = false
2018
2077
  return {
2019
2078
  [Symbol.iterator] = function(self)
2020
2079
  return self
2021
2080
  end,
2022
2081
  next = function(self)
2023
- local result = {done = not key, value = key}
2024
- key = nextKey[key]
2025
- return result
2082
+ if not started then
2083
+ started = true
2084
+ key = getFirstKey(nil)
2085
+ else
2086
+ key = nextKey[key]
2087
+ end
2088
+ return {done = not key, value = key}
2026
2089
  end
2027
2090
  }
2028
2091
  end
2029
2092
  function Set.prototype.values(self)
2093
+ local function getFirstKey()
2094
+ return self.firstKey
2095
+ end
2030
2096
  local nextKey = self.nextKey
2031
- local key = self.firstKey
2097
+ local key
2098
+ local started = false
2032
2099
  return {
2033
2100
  [Symbol.iterator] = function(self)
2034
2101
  return self
2035
2102
  end,
2036
2103
  next = function(self)
2037
- local result = {done = not key, value = key}
2038
- key = nextKey[key]
2039
- return result
2104
+ if not started then
2105
+ started = true
2106
+ key = getFirstKey(nil)
2107
+ else
2108
+ key = nextKey[key]
2109
+ end
2110
+ return {done = not key, value = key}
2040
2111
  end
2041
2112
  }
2042
2113
  end
@@ -2241,7 +2312,7 @@ local function __TS__SourceMapTraceBack(fileName, sourceMap)
2241
2312
  end
2242
2313
  local result = string.gsub(
2243
2314
  trace,
2244
- "(%S+)%.lua:(%d+)",
2315
+ "([^%s<]+)%.lua:(%d+)",
2245
2316
  function(file, line) return replacer(nil, file .. ".lua", file .. ".ts", line) end
2246
2317
  )
2247
2318
  local function stringReplacer(____, file, line)
package/net/socket.lua CHANGED
@@ -28,13 +28,13 @@ function Socket.prototype.____constructor(self)
28
28
  onReceive[self[0]]:addListener(function(sender, data)
29
29
  local chunks = chunksByPlayer[sender]
30
30
  if chunks ~= nil then
31
+ chunksByPlayer[sender] = nil
31
32
  chunks[#chunks + 1] = data
32
33
  Event.invoke(
33
34
  self.onMessage,
34
35
  sender,
35
36
  tableConcat(chunks)
36
37
  )
37
- chunksByPlayer[sender] = nil
38
38
  else
39
39
  Event.invoke(self.onMessage, sender, data)
40
40
  end
package/objutil/buff.lua CHANGED
@@ -29,6 +29,8 @@ local ____timer = require("core.types.timer")
29
29
  local Timer = ____timer.Timer
30
30
  local ____exception = require("exception")
31
31
  local IllegalStateException = ____exception.IllegalStateException
32
+ local ____linked_2Dmap = require("utility.linked-map")
33
+ local LinkedMap = ____linked_2Dmap.LinkedMap
32
34
  local ____assert = _G.assert
33
35
  local ____pairs = _G.pairs
34
36
  ____exports.BuffDefinition = __TS__Class()
@@ -461,7 +463,7 @@ local buffs = setmetatable(
461
463
  {
462
464
  __mode = "k",
463
465
  __index = function(self, unit)
464
- local ____table = {}
466
+ local ____table = __TS__New(LinkedMap)
465
467
  self[unit] = ____table
466
468
  return ____table
467
469
  end
@@ -494,7 +496,7 @@ function Buff.prototype.____constructor(self, unit, source, duration, level, pre
494
496
  end
495
497
  local constructor = self.constructor
496
498
  local instances = buffs[unit]
497
- local instance = instances[constructor]
499
+ local instance = instances:get(constructor)
498
500
  if instance then
499
501
  instance:destroy()
500
502
  if not instance.destroyed then
@@ -507,7 +509,7 @@ function Buff.prototype.____constructor(self, unit, source, duration, level, pre
507
509
  )
508
510
  end
509
511
  end
510
- instances[constructor] = self
512
+ instances:put(constructor, self)
511
513
  if preset then
512
514
  local unitHandle = unit.handle
513
515
  local slowPoisonMethod = not preset.positive and not preset.magic
@@ -586,13 +588,13 @@ function Buff.apply(self, ...)
586
588
  end
587
589
  end
588
590
  function Buff.getInstance(self, unit)
589
- return buffs[unit][self]
591
+ return buffs[unit]:get(self)
590
592
  end
591
593
  function Buff.isApplied(self, unit)
592
- return buffs[unit][self] ~= nil
594
+ return buffs[unit]:get(self) ~= nil
593
595
  end
594
596
  function Buff.ifApplied(self, unit, action)
595
- local instance = buffs[unit][self]
597
+ local instance = buffs[unit]:get(self)
596
598
  if instance then
597
599
  ____assert(__TS__InstanceOf(instance, self))
598
600
  action(instance)
@@ -615,7 +617,7 @@ function Buff.prototype.destroy(self)
615
617
  if self.preset then
616
618
  self.unit:removeAbility(self.preset.buffId)
617
619
  end
618
- buffs[self.unit][self.constructor] = nil
620
+ buffs[self.unit]:remove(self.constructor)
619
621
  self.destroyed = true
620
622
  end
621
623
  function Buff.prototype.onDispel(self, source)
@@ -762,7 +764,7 @@ Unit.onDamaging:addListener(function(source, target, event)
762
764
  end
763
765
  end)
764
766
  Unit.itemPickedUpEvent:addListener(function(unit, item)
765
- if item.powerup and item:hasAbility(fourCC("APdi")) then
767
+ if item.isPowerUp and item:hasAbility(fourCC("APdi")) then
766
768
  end
767
769
  end)
768
770
  return ____exports
@@ -153,7 +153,7 @@ end
153
153
  function ObjectDefinition.getLevelArrayFieldValue(self, level, value, values)
154
154
  return type(values) == "function" and values(level, value) or (__TS__ArrayIsArray(values[1]) and values[1] or values)
155
155
  end
156
- ____exports.ObjectType = ObjectType or ({})
156
+ ____exports.ObjectType = ____exports.ObjectType or ({})
157
157
  ____exports.ObjectType.ABILITY = 0
158
158
  ____exports.ObjectType[____exports.ObjectType.ABILITY] = "ABILITY"
159
159
  ____exports.ObjectType.ITEM = 1
package/operation.lua CHANGED
@@ -22,10 +22,7 @@ OperationMonitor.name = "OperationMonitor"
22
22
  __TS__ClassExtends(OperationMonitor, __TS__Promise)
23
23
  function OperationMonitor.prototype.____constructor(self, operation, ...)
24
24
  local args = {...}
25
- __TS__Promise.prototype.____constructor(
26
- self,
27
- table.unpack(args)
28
- )
25
+ __TS__Promise.prototype.____constructor(self, ...)
29
26
  self.o = operation
30
27
  end
31
28
  function OperationMonitor.prototype.cancel(self)
@@ -57,6 +54,7 @@ function Operation.prototype.execute(self)
57
54
  return __TS__AsyncAwaiter(function(____awaiter_resolve)
58
55
  local result
59
56
  local progress = self.progress
57
+ local ____hasReturned, ____returnValue
60
58
  local ____try = __TS__AsyncAwaiter(function()
61
59
  local maximum = __TS__Await(self:estimate())
62
60
  self.maximum = maximum
@@ -79,7 +77,8 @@ function Operation.prototype.execute(self)
79
77
  if onComplete ~= nil then
80
78
  Event.invoke(onComplete, self, false, reason)
81
79
  end
82
- return ____awaiter_resolve(nil)
80
+ ____hasReturned = true
81
+ return
83
82
  end
84
83
  result = __TS__Await(self:work())
85
84
  if self.progress ~= progress or self.maximum ~= maximum then
@@ -93,21 +92,28 @@ function Operation.prototype.execute(self)
93
92
  end
94
93
  until not (result == OperationContinue)
95
94
  end)
96
- __TS__Await(____try.catch(
95
+ ____try = ____try.catch(
97
96
  ____try,
98
97
  function(____, reason)
99
- reject(nil, reason)
100
- local onFailure = ____rawget(self, "onFailure")
101
- if onFailure ~= nil then
102
- Event.invoke(onFailure, self, reason)
103
- end
104
- local onComplete = ____rawget(self, "onComplete")
105
- if onComplete ~= nil then
106
- Event.invoke(onComplete, self, false, reason)
107
- end
108
- return ____awaiter_resolve(nil)
98
+ return __TS__AsyncAwaiter(function()
99
+ reject(nil, reason)
100
+ local onFailure = ____rawget(self, "onFailure")
101
+ if onFailure ~= nil then
102
+ Event.invoke(onFailure, self, reason)
103
+ end
104
+ local onComplete = ____rawget(self, "onComplete")
105
+ if onComplete ~= nil then
106
+ Event.invoke(onComplete, self, false, reason)
107
+ end
108
+ ____hasReturned = true
109
+ return
110
+ end)
109
111
  end
110
- ))
112
+ )
113
+ __TS__Await(____try)
114
+ if ____hasReturned then
115
+ return ____awaiter_resolve(nil, ____returnValue)
116
+ end
111
117
  resolve(nil, result)
112
118
  local onSuccess = ____rawget(self, "onSuccess")
113
119
  if onSuccess ~= nil then
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "$schema": "https://json.schemastore.org/package",
3
3
  "name": "warscript",
4
- "version": "0.0.1-dev.db137e7",
4
+ "version": "0.0.1-dev.dc37dce",
5
5
  "description": "A typescript library for Warcraft III using Warpack.",
6
6
  "keywords": [
7
7
  "warcraft",
@@ -22,13 +22,13 @@
22
22
  },
23
23
  "peerDependencies": {
24
24
  "@warscript/language-extensions": "^0.0.1",
25
- "@warscript/tstl-plugin": "^0.0.4",
25
+ "@warscript/tstl-plugin": "^0.0.5",
26
26
  "lua-types": "^2.13.1",
27
- "warpack": "0.0.1-dev.251db08"
27
+ "warpack": "0.0.1-dev.e490aaf"
28
28
  },
29
29
  "devDependencies": {
30
- "@typescript-eslint/eslint-plugin": "^8.13.0",
31
- "@typescript-eslint/parser": "^8.13.0",
30
+ "@typescript-eslint/eslint-plugin": "^8.61.1",
31
+ "@typescript-eslint/parser": "^8.61.1",
32
32
  "async": "^3.2.6",
33
33
  "copyfiles": "^2.4.1",
34
34
  "eslint": "^9.14.0",
package/patch-lua.lua CHANGED
@@ -1,5 +1,9 @@
1
+ local error = _G.error
1
2
  local getmetatable = _G.getmetatable
2
3
  local ipairs = _G.ipairs
4
+ local select = _G.select
5
+ local tostring = _G.tostring
6
+ local tableconcat = table.concat
3
7
 
4
8
  _G.ipairs = function(t)
5
9
  local metatable = getmetatable(t)
@@ -8,3 +12,14 @@ _G.ipairs = function(t)
8
12
  end
9
13
  return ipairs(t)
10
14
  end
15
+
16
+ _G.assert = function(v, ...)
17
+ if not v then
18
+ local args = {}
19
+ for i = 1, select("#", ...) do
20
+ args[i] = tostring(select(i, ...))
21
+ end
22
+ error(tableconcat(args, " "))
23
+ end
24
+ return v, ...
25
+ end
@@ -2,12 +2,16 @@
2
2
  type Callback = {
3
3
  readonly __callback: unique symbol;
4
4
  };
5
+ export type CallbackId = number & {
6
+ readonly __callbackId: unique symbol;
7
+ };
5
8
  export type CallbackArray = {
6
9
  readonly __callbackArray: unique symbol;
7
10
  } & Callback[];
8
11
  export declare const callbackArray: () => CallbackArray;
9
- export declare function addCallback<Args extends any[]>(this: void, array: CallbackArray, callback: (...args: Args) => unknown, ...args: Args): void;
12
+ export declare function addCallback<Args extends any[]>(this: void, array: CallbackArray, callback: (...args: Args) => unknown, ...args: Args): CallbackId;
10
13
  export declare function clearCallbacks(this: void, array: CallbackArray): void;
14
+ export declare function consumeCallback(this: void, array: CallbackArray, id: CallbackId): void;
11
15
  export declare function consumeCallbacks(this: void, array: CallbackArray): void;
12
16
  export declare function invokeCallbacks(this: void, array: CallbackArray): void;
13
17
  export {};