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.
- package/attributes.d.ts +1 -0
- package/attributes.lua +9 -0
- package/binarywriter.lua +0 -12
- package/core/types/player.d.ts +16 -0
- package/core/types/player.lua +57 -14
- package/core/types/sound.lua +1 -1
- package/core/types/tileCell.d.ts +2 -1
- package/core/types/tileCell.lua +5 -0
- package/core/types/timer.d.ts +3 -2
- package/core/types/timer.lua +8 -2
- package/destroyable.d.ts +1 -0
- package/destroyable.lua +9 -0
- package/engine/behavior.d.ts +10 -2
- package/engine/behavior.lua +157 -76
- package/engine/behaviour/ability/apply-buff.lua +4 -4
- package/engine/behaviour/ability/remove-buffs.d.ts +9 -0
- package/engine/behaviour/ability/remove-buffs.lua +21 -0
- package/engine/behaviour/ability.d.ts +11 -6
- package/engine/behaviour/ability.lua +31 -1
- package/engine/behaviour/unit/stun-immunity.d.ts +7 -5
- package/engine/behaviour/unit/stun-immunity.lua +6 -5
- package/engine/behaviour/unit.d.ts +9 -3
- package/engine/behaviour/unit.lua +106 -24
- package/engine/buff.d.ts +64 -18
- package/engine/buff.lua +354 -151
- package/engine/internal/item.d.ts +12 -12
- package/engine/internal/item.lua +41 -26
- package/engine/internal/mechanics/cast-ability.lua +6 -3
- package/engine/internal/object-data/attribute-bonus.lua +2 -2
- package/engine/internal/object-data/health-bonus.d.ts +2 -0
- package/engine/internal/object-data/health-bonus.lua +16 -0
- package/engine/internal/object-data/mana-bonus.d.ts +2 -0
- package/engine/internal/object-data/mana-bonus.lua +16 -0
- package/engine/internal/object-data/mana-regeneration-rate-increase-factor.d.ts +2 -0
- package/engine/internal/object-data/mana-regeneration-rate-increase-factor.lua +16 -0
- package/engine/internal/unit/ability.d.ts +14 -14
- package/engine/internal/unit/ability.lua +72 -45
- package/engine/internal/unit/attributes.d.ts +17 -0
- package/engine/internal/unit/attributes.lua +46 -0
- package/engine/internal/unit/bonus.d.ts +6 -0
- package/engine/internal/unit/bonus.lua +33 -3
- package/engine/internal/unit/fly-height.d.ts +7 -0
- package/engine/internal/unit/fly-height.lua +20 -0
- package/engine/internal/unit/interrupts.d.ts +12 -0
- package/engine/internal/unit/interrupts.lua +28 -0
- package/engine/internal/unit/item.lua +1 -1
- package/engine/internal/unit/main-selected.lua +12 -27
- package/engine/internal/unit/range-event.d.ts +12 -0
- package/engine/internal/unit/range-event.lua +90 -0
- package/engine/internal/unit/scale.d.ts +7 -0
- package/engine/internal/unit/scale.lua +20 -0
- package/engine/internal/unit+bonus.lua +3 -3
- package/engine/internal/unit-missile-launch.lua +51 -20
- package/engine/internal/unit.d.ts +15 -19
- package/engine/internal/unit.lua +160 -183
- package/engine/local-client.d.ts +2 -0
- package/engine/local-client.lua +30 -0
- package/engine/object-data/auxiliary/health-regeneration-type.d.ts +8 -0
- package/engine/object-data/auxiliary/health-regeneration-type.lua +2 -0
- package/engine/object-data/auxiliary/unit-attribute.lua +1 -1
- package/engine/object-data/entry/ability-type/{armor-increase.d.ts → armor-bonus.d.ts} +3 -3
- package/engine/object-data/entry/ability-type/{armor-increase.lua → armor-bonus.lua} +9 -9
- package/engine/object-data/entry/ability-type/health-bonus.d.ts +8 -0
- package/engine/object-data/entry/ability-type/health-bonus.lua +26 -0
- package/engine/object-data/entry/ability-type/mana-bonus.d.ts +8 -0
- package/engine/object-data/entry/ability-type/mana-bonus.lua +26 -0
- package/engine/object-data/entry/ability-type/mana-regeneration.d.ts +8 -0
- package/engine/object-data/entry/ability-type/mana-regeneration.lua +26 -0
- package/engine/object-data/entry/ability-type/reincarnation.d.ts +8 -0
- package/engine/object-data/entry/ability-type/reincarnation.lua +26 -0
- package/engine/object-data/entry/ability-type.d.ts +2 -0
- package/engine/object-data/entry/ability-type.lua +88 -5
- package/engine/object-data/entry/buff-type/applicable.lua +113 -109
- package/engine/object-data/entry/destructible-type.d.ts +27 -1
- package/engine/object-data/entry/destructible-type.lua +155 -0
- package/engine/object-data/entry/unit-type.d.ts +4 -0
- package/engine/object-data/entry/unit-type.lua +76 -32
- package/engine/object-field/unit.d.ts +20 -5
- package/engine/object-field/unit.lua +61 -0
- package/engine/object-field.d.ts +9 -1
- package/engine/object-field.lua +265 -122
- package/engine/random.d.ts +1 -0
- package/engine/random.lua +8 -0
- package/engine/standard/fields/ability.d.ts +2 -2
- package/engine/standard/fields/ability.lua +2 -2
- package/engine/standard/fields/unit.d.ts +11 -3
- package/engine/standard/fields/unit.lua +15 -2
- package/engine/synchronization.d.ts +11 -0
- package/engine/synchronization.lua +77 -0
- package/engine/text-tag.lua +3 -2
- package/engine/unit.d.ts +5 -0
- package/engine/unit.lua +5 -0
- package/lualib_bundle.lua +118 -47
- package/net/socket.lua +1 -1
- package/objutil/buff.lua +10 -8
- package/objutil/object.lua +1 -1
- package/operation.lua +23 -17
- package/package.json +5 -5
- package/patch-lua.lua +15 -0
- package/utility/callback-array.d.ts +5 -1
- package/utility/callback-array.lua +16 -1
- package/utility/linked-map.d.ts +34 -0
- package/utility/linked-map.lua +101 -0
- package/utility/linked-set.d.ts +3 -1
- package/utility/linked-set.lua +40 -1
- package/utility/records.lua +20 -1
- package/utility/types.d.ts +3 -0
- /package/engine/internal/object-data/{armor-increase.d.ts → armor-bonus.d.ts} +0 -0
- /package/engine/internal/object-data/{armor-increase.lua → armor-bonus.lua} +0 -0
- /package/engine/object-data/entry/ability-type/{attribute-increase.d.ts → attribute-bonus.d.ts} +0 -0
- /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
|
package/engine/text-tag.lua
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
908
|
-
|
|
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
|
|
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
|
-
|
|
1395
|
-
|
|
1396
|
-
|
|
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
|
|
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
|
-
|
|
1409
|
-
|
|
1410
|
-
|
|
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
|
|
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
|
-
|
|
1424
|
-
|
|
1425
|
-
|
|
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
|
|
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
|
-
|
|
2010
|
-
|
|
2011
|
-
|
|
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
|
|
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
|
-
|
|
2024
|
-
|
|
2025
|
-
|
|
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
|
|
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
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
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
|
-
"(
|
|
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
|
|
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
|
|
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]
|
|
591
|
+
return buffs[unit]:get(self)
|
|
590
592
|
end
|
|
591
593
|
function Buff.isApplied(self, unit)
|
|
592
|
-
return buffs[unit]
|
|
594
|
+
return buffs[unit]:get(self) ~= nil
|
|
593
595
|
end
|
|
594
596
|
function Buff.ifApplied(self, unit, action)
|
|
595
|
-
local instance = buffs[unit]
|
|
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]
|
|
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.
|
|
767
|
+
if item.isPowerUp and item:hasAbility(fourCC("APdi")) then
|
|
766
768
|
end
|
|
767
769
|
end)
|
|
768
770
|
return ____exports
|
package/objutil/object.lua
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
95
|
+
____try = ____try.catch(
|
|
97
96
|
____try,
|
|
98
97
|
function(____, reason)
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
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.
|
|
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.
|
|
25
|
+
"@warscript/tstl-plugin": "^0.0.5",
|
|
26
26
|
"lua-types": "^2.13.1",
|
|
27
|
-
"warpack": "0.0.1-dev.
|
|
27
|
+
"warpack": "0.0.1-dev.e490aaf"
|
|
28
28
|
},
|
|
29
29
|
"devDependencies": {
|
|
30
|
-
"@typescript-eslint/eslint-plugin": "^8.
|
|
31
|
-
"@typescript-eslint/parser": "^8.
|
|
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):
|
|
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 {};
|