warscript 0.0.1-dev.f074376 → 0.0.1-dev.f0daa48
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/core/types/sound.lua +1 -1
- package/engine/behaviour/ability.d.ts +9 -5
- package/engine/behaviour/ability.lua +29 -0
- package/engine/behaviour/unit/stun-immunity.d.ts +1 -1
- package/engine/behaviour/unit/stun-immunity.lua +5 -4
- package/engine/behaviour/unit.lua +13 -3
- package/engine/buff.d.ts +52 -19
- package/engine/buff.lua +266 -141
- 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.lua +1 -1
- package/engine/internal/unit/attributes.d.ts +17 -0
- package/engine/internal/unit/attributes.lua +46 -0
- package/engine/internal/unit/bonus.d.ts +4 -0
- package/engine/internal/unit/bonus.lua +23 -3
- package/engine/internal/unit/fly-height.lua +3 -3
- 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/range-event.d.ts +12 -0
- package/engine/internal/unit/range-event.lua +90 -0
- package/engine/internal/unit/scale.lua +3 -3
- package/engine/internal/unit+bonus.lua +3 -3
- package/engine/internal/unit-missile-launch.lua +12 -5
- package/engine/internal/unit.d.ts +2 -9
- package/engine/internal/unit.lua +79 -121
- 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.lua +1 -1
- 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 +84 -4
- package/engine/object-data/entry/buff-type/applicable.lua +113 -109
- package/engine/object-field/ability.lua +2 -2
- package/engine/object-field.d.ts +3 -1
- package/engine/object-field.lua +42 -18
- package/engine/random.d.ts +1 -0
- package/engine/random.lua +8 -0
- package/engine/standard/fields/unit.d.ts +11 -6
- package/engine/standard/fields/unit.lua +12 -5
- package/engine/unit.d.ts +3 -0
- package/engine/unit.lua +3 -0
- package/lualib_bundle.lua +118 -47
- package/objutil/buff.lua +9 -7
- package/objutil/object.lua +1 -1
- package/operation.lua +23 -17
- package/package.json +5 -5
- package/patch-lua.lua +15 -0
- package/utility/linked-map.d.ts +34 -0
- package/utility/linked-map.lua +101 -0
- package/utility/linked-set.d.ts +2 -1
- package/utility/linked-set.lua +21 -0
- package/utility/records.lua +20 -1
- /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
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/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)
|
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.f0daa48",
|
|
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
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/** @noSelfInFile */
|
|
2
|
+
import { ReadonlyLinkedSet } from "./linked-set";
|
|
3
|
+
type IteratorState<K extends AnyNotNil, V> = {
|
|
4
|
+
n?: K;
|
|
5
|
+
t: LuaMap<K, K>;
|
|
6
|
+
v: LuaMap<K, V>;
|
|
7
|
+
};
|
|
8
|
+
type OneSidedTypeGuard = {
|
|
9
|
+
readonly __oneSidedTypeGuard: unique symbol;
|
|
10
|
+
};
|
|
11
|
+
export interface ReadonlyLinkedMap<K extends AnyNotNil, V> extends LuaPairsIterable<K, V> {
|
|
12
|
+
readonly keys: ReadonlyLinkedSet<K>;
|
|
13
|
+
get(key: K): V | undefined;
|
|
14
|
+
contains(key: AnyNotNil): key is K & OneSidedTypeGuard;
|
|
15
|
+
readonly size: number;
|
|
16
|
+
}
|
|
17
|
+
export interface LinkedMap<K extends AnyNotNil, V> extends LuaPairsIterable<K, V> {
|
|
18
|
+
readonly __linkedSet: unique symbol;
|
|
19
|
+
}
|
|
20
|
+
export declare class LinkedMap<K extends AnyNotNil, V> implements ReadonlyLinkedMap<K, V> {
|
|
21
|
+
private k;
|
|
22
|
+
private v;
|
|
23
|
+
get keys(): ReadonlyLinkedSet<K>;
|
|
24
|
+
get(key: K): V | undefined;
|
|
25
|
+
getOrPut(key: K, defaultValue: (this: void) => V): V;
|
|
26
|
+
put(key: K, value: V): void;
|
|
27
|
+
remove(key: K): boolean;
|
|
28
|
+
contains(key: AnyNotNil): key is K & OneSidedTypeGuard;
|
|
29
|
+
get size(): number;
|
|
30
|
+
protected __pairs(this: LinkedMap<K, V>): LuaIterator<LuaMultiReturn<[K | undefined, V | undefined]>, IteratorState<K, V>>;
|
|
31
|
+
}
|
|
32
|
+
export declare const emptyLinkedMap: <K extends AnyNotNil, V>() => ReadonlyLinkedMap<K, V>;
|
|
33
|
+
export declare const mutableLinkedMap: <K extends AnyNotNil, V>() => LinkedMap<K, V>;
|
|
34
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
local ____lualib = require("lualib_bundle")
|
|
2
|
+
local __TS__Class = ____lualib.__TS__Class
|
|
3
|
+
local __TS__New = ____lualib.__TS__New
|
|
4
|
+
local __TS__SetDescriptor = ____lualib.__TS__SetDescriptor
|
|
5
|
+
local __TS__ClassExtends = ____lualib.__TS__ClassExtends
|
|
6
|
+
local ____exports = {}
|
|
7
|
+
local ____linked_2Dset = require("utility.linked-set")
|
|
8
|
+
local LinkedSet = ____linked_2Dset.LinkedSet
|
|
9
|
+
local ____exception = require("exception")
|
|
10
|
+
local UnsupportedOperationException = ____exception.UnsupportedOperationException
|
|
11
|
+
local function linkedMapNext(state)
|
|
12
|
+
local n = state.n
|
|
13
|
+
state.n = state.t[n]
|
|
14
|
+
return n, state.v[n]
|
|
15
|
+
end
|
|
16
|
+
____exports.LinkedMap = __TS__Class()
|
|
17
|
+
local LinkedMap = ____exports.LinkedMap
|
|
18
|
+
LinkedMap.name = "LinkedMap"
|
|
19
|
+
function LinkedMap.prototype.____constructor(self)
|
|
20
|
+
self.k = __TS__New(LinkedSet)
|
|
21
|
+
self.v = {}
|
|
22
|
+
end
|
|
23
|
+
function LinkedMap.prototype.get(self, key)
|
|
24
|
+
return self.v[key]
|
|
25
|
+
end
|
|
26
|
+
function LinkedMap.prototype.getOrPut(self, key, defaultValue)
|
|
27
|
+
local value = self.v[key]
|
|
28
|
+
if value ~= nil then
|
|
29
|
+
return value
|
|
30
|
+
end
|
|
31
|
+
value = defaultValue()
|
|
32
|
+
self.k:add(key)
|
|
33
|
+
self.v[key] = value
|
|
34
|
+
return value
|
|
35
|
+
end
|
|
36
|
+
function LinkedMap.prototype.put(self, key, value)
|
|
37
|
+
self.k:add(key)
|
|
38
|
+
self.v[key] = value
|
|
39
|
+
end
|
|
40
|
+
function LinkedMap.prototype.remove(self, key)
|
|
41
|
+
if self.k:remove(key) then
|
|
42
|
+
self.v[key] = nil
|
|
43
|
+
return true
|
|
44
|
+
end
|
|
45
|
+
return false
|
|
46
|
+
end
|
|
47
|
+
function LinkedMap.prototype.contains(self, key)
|
|
48
|
+
return self.keys:contains(key)
|
|
49
|
+
end
|
|
50
|
+
function LinkedMap.prototype.__pairs(self)
|
|
51
|
+
return linkedMapNext, {n = self.k.f, t = self.k.n, v = self.v}, nil
|
|
52
|
+
end
|
|
53
|
+
__TS__SetDescriptor(
|
|
54
|
+
LinkedMap.prototype,
|
|
55
|
+
"keys",
|
|
56
|
+
{get = function(self)
|
|
57
|
+
return self.k
|
|
58
|
+
end},
|
|
59
|
+
true
|
|
60
|
+
)
|
|
61
|
+
__TS__SetDescriptor(
|
|
62
|
+
LinkedMap.prototype,
|
|
63
|
+
"size",
|
|
64
|
+
{get = function(self)
|
|
65
|
+
return self.keys.size
|
|
66
|
+
end},
|
|
67
|
+
true
|
|
68
|
+
)
|
|
69
|
+
local emptyIteratorState = {t = {}, v = {}}
|
|
70
|
+
local EmptyLinkedMap = __TS__Class()
|
|
71
|
+
EmptyLinkedMap.name = "EmptyLinkedMap"
|
|
72
|
+
__TS__ClassExtends(EmptyLinkedMap, ____exports.LinkedMap)
|
|
73
|
+
function EmptyLinkedMap.prototype.getOrPut(self)
|
|
74
|
+
error(
|
|
75
|
+
__TS__New(UnsupportedOperationException),
|
|
76
|
+
0
|
|
77
|
+
)
|
|
78
|
+
end
|
|
79
|
+
function EmptyLinkedMap.prototype.put(self)
|
|
80
|
+
error(
|
|
81
|
+
__TS__New(UnsupportedOperationException),
|
|
82
|
+
0
|
|
83
|
+
)
|
|
84
|
+
end
|
|
85
|
+
function EmptyLinkedMap.prototype.remove(self)
|
|
86
|
+
error(
|
|
87
|
+
__TS__New(UnsupportedOperationException),
|
|
88
|
+
0
|
|
89
|
+
)
|
|
90
|
+
end
|
|
91
|
+
function EmptyLinkedMap.prototype.__pairs(self)
|
|
92
|
+
return linkedMapNext, emptyIteratorState, nil
|
|
93
|
+
end
|
|
94
|
+
local EMPTY_LINKED_MAP = __TS__New(EmptyLinkedMap)
|
|
95
|
+
____exports.emptyLinkedMap = function()
|
|
96
|
+
return EMPTY_LINKED_MAP
|
|
97
|
+
end
|
|
98
|
+
____exports.mutableLinkedMap = function()
|
|
99
|
+
return __TS__New(____exports.LinkedMap)
|
|
100
|
+
end
|
|
101
|
+
return ____exports
|
package/utility/linked-set.d.ts
CHANGED
|
@@ -14,7 +14,7 @@ export interface ReadonlyLinkedSet<T extends AnyNotNil> extends LuaPairsKeyItera
|
|
|
14
14
|
next(key: T): T | undefined;
|
|
15
15
|
previous(key: T): T | undefined;
|
|
16
16
|
contains(key: AnyNotNil): key is T & OneSidedTypeGuard;
|
|
17
|
-
size: number;
|
|
17
|
+
readonly size: number;
|
|
18
18
|
forEach<Args extends any[]>(action: (value: T, ...args: Args) => void, ...args: Args): void;
|
|
19
19
|
toArray(): T[];
|
|
20
20
|
sumOf(selector: ((value: T) => number) | KeysOfType<T, number>): number;
|
|
@@ -40,6 +40,7 @@ export declare class LinkedSet<T extends AnyNotNil> implements ReadonlyLinkedSet
|
|
|
40
40
|
next(key: T): T | undefined;
|
|
41
41
|
previous(key: T): T | undefined;
|
|
42
42
|
add(key: T): boolean;
|
|
43
|
+
protected addBefore(value: T, key: T): boolean;
|
|
43
44
|
remove(key: T): boolean;
|
|
44
45
|
contains(key: AnyNotNil): key is T & OneSidedTypeGuard;
|
|
45
46
|
clear(): void;
|
package/utility/linked-set.lua
CHANGED
|
@@ -85,6 +85,23 @@ function LinkedSet.prototype.add(self, key)
|
|
|
85
85
|
end
|
|
86
86
|
return true
|
|
87
87
|
end
|
|
88
|
+
function LinkedSet.prototype.addBefore(self, value, key)
|
|
89
|
+
local n = self.n
|
|
90
|
+
local p = self.p
|
|
91
|
+
local previous = p[value]
|
|
92
|
+
if previous ~= nil then
|
|
93
|
+
n[previous] = key
|
|
94
|
+
p[key] = previous
|
|
95
|
+
elseif value == self.f then
|
|
96
|
+
self.f = key
|
|
97
|
+
else
|
|
98
|
+
return false
|
|
99
|
+
end
|
|
100
|
+
n[key] = value
|
|
101
|
+
p[value] = key
|
|
102
|
+
self.s = self.s + 1
|
|
103
|
+
return true
|
|
104
|
+
end
|
|
88
105
|
function LinkedSet.prototype.remove(self, key)
|
|
89
106
|
local n = self.n
|
|
90
107
|
local next = n[key]
|
|
@@ -182,6 +199,7 @@ __TS__SetDescriptor(
|
|
|
182
199
|
end},
|
|
183
200
|
true
|
|
184
201
|
)
|
|
202
|
+
local emptyIteratorState = {t = {}}
|
|
185
203
|
local EmptyLinkedSet = __TS__Class()
|
|
186
204
|
EmptyLinkedSet.name = "EmptyLinkedSet"
|
|
187
205
|
__TS__ClassExtends(EmptyLinkedSet, ____exports.LinkedSet)
|
|
@@ -191,6 +209,9 @@ function EmptyLinkedSet.prototype.add(self)
|
|
|
191
209
|
0
|
|
192
210
|
)
|
|
193
211
|
end
|
|
212
|
+
function EmptyLinkedSet.prototype.__pairs(self)
|
|
213
|
+
return linkedSetNext, emptyIteratorState, nil
|
|
214
|
+
end
|
|
194
215
|
local EMPTY_LINKED_SET = __TS__New(EmptyLinkedSet)
|
|
195
216
|
____exports.emptyLinkedSet = function()
|
|
196
217
|
return EMPTY_LINKED_SET
|