warscript 0.0.1-dev.f024cc2 → 0.0.1-dev.f074376
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/core/types/frame.lua +14 -9
- package/core/types/player.d.ts +16 -0
- package/core/types/player.lua +57 -14
- package/core/types/playerCamera.lua +44 -0
- package/core/types/tileCell.d.ts +11 -1
- package/core/types/tileCell.lua +97 -0
- package/core/types/timer.d.ts +3 -2
- package/core/types/timer.lua +22 -2
- package/decl/native.d.ts +2 -2
- package/destroyable.d.ts +1 -0
- package/destroyable.lua +9 -0
- package/engine/behavior.d.ts +12 -1
- package/engine/behavior.lua +199 -65
- 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 +2 -1
- package/engine/behaviour/ability.lua +2 -1
- package/engine/behaviour/unit/stun-immunity.d.ts +8 -4
- package/engine/behaviour/unit/stun-immunity.lua +12 -3
- package/engine/behaviour/unit.d.ts +15 -5
- package/engine/behaviour/unit.lua +116 -22
- package/engine/buff.d.ts +15 -5
- package/engine/buff.lua +151 -94
- package/engine/internal/ability.d.ts +3 -1
- package/engine/internal/ability.lua +26 -9
- package/engine/internal/item.d.ts +13 -15
- package/engine/internal/item.lua +63 -49
- 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/bonus.d.ts +2 -0
- package/engine/internal/unit/bonus.lua +10 -0
- package/engine/internal/unit/fly-height.d.ts +7 -0
- package/engine/internal/unit/fly-height.lua +20 -0
- package/engine/internal/unit/main-selected.lua +12 -27
- package/engine/internal/unit/scale.d.ts +7 -0
- package/engine/internal/unit/scale.lua +20 -0
- package/engine/internal/unit+ability.lua +9 -0
- package/engine/internal/unit-missile-launch.lua +44 -20
- package/engine/internal/unit.d.ts +15 -12
- package/engine/internal/unit.lua +93 -76
- 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/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.lua +4 -1
- 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/ability.d.ts +3 -3
- package/engine/object-field/ability.lua +7 -6
- package/engine/object-field/unit.d.ts +20 -5
- package/engine/object-field/unit.lua +61 -0
- package/engine/object-field.d.ts +9 -3
- package/engine/object-field.lua +237 -114
- package/engine/random.d.ts +9 -0
- package/engine/random.lua +13 -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 +4 -1
- package/engine/standard/fields/unit.lua +6 -0
- 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 +2 -0
- package/engine/unit.lua +2 -0
- package/net/socket.lua +1 -1
- package/objutil/buff.lua +1 -1
- package/package.json +2 -2
- package/patch-lualib.lua +1 -1
- package/utility/arrays.d.ts +1 -0
- package/utility/arrays.lua +8 -0
- package/utility/callback-array.d.ts +17 -0
- package/utility/callback-array.lua +61 -0
- package/utility/linked-set.d.ts +1 -0
- package/utility/linked-set.lua +19 -1
- package/utility/lua-maps.d.ts +11 -2
- package/utility/lua-maps.lua +33 -2
- package/utility/types.d.ts +3 -0
package/engine/object-field.d.ts
CHANGED
|
@@ -17,8 +17,8 @@ declare abstract class ObjectFieldBase<ObjectDataEntryType extends ObjectDataEnt
|
|
|
17
17
|
readonly id: ObjectFieldId;
|
|
18
18
|
protected abstract getNativeFieldById(id: number): NativeFieldType;
|
|
19
19
|
protected abstract getObjectDataEntryId(instance: InstanceType): ObjectDataEntryIdType<ObjectDataEntryType>;
|
|
20
|
-
protected abstract hasNativeFieldValue(
|
|
21
|
-
hasValue(
|
|
20
|
+
protected abstract hasNativeFieldValue(objectDataEntryId: ObjectDataEntryIdType<ObjectDataEntryType>): boolean;
|
|
21
|
+
hasValue(objectDataEntryId: ObjectDataEntryIdType<ObjectDataEntryType>): boolean;
|
|
22
22
|
constructor(id: number, isGlobal?: boolean);
|
|
23
23
|
static create<T extends ObjectFieldBase<any, any, any, any>>(this: ObjectFieldConstructor<T>, id?: number, isGlobal?: boolean): T & symbol;
|
|
24
24
|
static of<T extends ObjectFieldBase<any, any, any, any>>(this: ObjectFieldAbstractConstructor<T>, id: number): T | undefined;
|
|
@@ -36,7 +36,8 @@ export type ObjectFieldValueChangeEvent<T extends ObjectField<any, any, any, any
|
|
|
36
36
|
]> : never;
|
|
37
37
|
export type ReadonlyObjectFieldType<T extends ObjectField<any, any, any, any>> = Omit<T, "setValue" | "removeValue" | "trySetValue">;
|
|
38
38
|
type ReadonlyObjectFieldConstructor<T extends ObjectField> = OmitConstructor<typeof ObjectField> & (abstract new (...args: any[]) => ReadonlyObjectFieldType<T>);
|
|
39
|
-
type ObjectFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, currentValue: ValueType, originalValue: ValueType) => ValueType;
|
|
39
|
+
export type ObjectFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, currentValue: ValueType, originalValue: ValueType) => ValueType;
|
|
40
|
+
export type ObjectLevelFieldModifier<InstanceType extends AnyNotNil, ValueType extends number | string | boolean> = (instance: InstanceType, level: number, currentValue: ValueType, originalValue: ValueType) => ValueType;
|
|
40
41
|
export declare abstract class ObjectField<ObjectDataEntryType extends ObjectDataEntry = ObjectDataEntry, InstanceType extends AnyNotNil = AnyNotNil, ValueType extends number | string | boolean = number | string | boolean, NativeFieldType = unknown> extends ObjectFieldBase<ObjectDataEntryType, InstanceType, ValueType, NativeFieldType> {
|
|
41
42
|
protected abstract readonly defaultValue: ValueType;
|
|
42
43
|
protected abstract getNativeFieldValue(instance: InstanceType): ValueType;
|
|
@@ -88,7 +89,12 @@ export declare abstract class ObjectLevelField<ObjectDataEntryType extends Objec
|
|
|
88
89
|
protected abstract getLevelCount(entry: ObjectDataEntryType | InstanceType): number;
|
|
89
90
|
getValue<LevelType extends [number] | []>(entry: ObjectDataEntryType | InstanceType, ...[level]: LevelType): LevelType extends [number] ? ValueType : ValueType[];
|
|
90
91
|
setValue(entry: ObjectDataEntryType | InstanceType, ...[levelOrValue, value]: [value: ObjectDataEntryLevelFieldValueSupplier<InputValueType, ValueType>] | [level: number, value: InputValueType]): boolean;
|
|
92
|
+
applyModifier(instance: InstanceType, modifier: ObjectLevelFieldModifier<InstanceType, ValueType>): void;
|
|
93
|
+
removeModifier(instance: InstanceType, modifier: ObjectLevelFieldModifier<InstanceType, ValueType>): boolean;
|
|
91
94
|
trySetValue(entry: ObjectDataEntryType | InstanceType, levelOrValue: number | unknown, value?: unknown): boolean;
|
|
95
|
+
private getActualValue;
|
|
96
|
+
private setActualValue;
|
|
97
|
+
private calculateActualValue;
|
|
92
98
|
private invokeValueChangeEvent;
|
|
93
99
|
private invokeValueChangeEventRecursive;
|
|
94
100
|
protected static getOrCreateValueChangeEvent<T extends ObjectLevelField, R extends ReadonlyObjectLevelFieldType<T>>(this: ReadonlyObjectLevelFieldConstructor<T>): ObjectLevelFieldValueChangeEvent<R>;
|
package/engine/object-field.lua
CHANGED
|
@@ -25,6 +25,7 @@ local mutableLinkedSet = ____linked_2Dset.mutableLinkedSet
|
|
|
25
25
|
local ____lua_2Dmaps = require("utility.lua-maps")
|
|
26
26
|
local emptyLuaMap = ____lua_2Dmaps.emptyLuaMap
|
|
27
27
|
local getOrPut = ____lua_2Dmaps.getOrPut
|
|
28
|
+
local mutableLuaMap = ____lua_2Dmaps.mutableLuaMap
|
|
28
29
|
local mutableWeakLuaMap = ____lua_2Dmaps.mutableWeakLuaMap
|
|
29
30
|
local ____arrays = require("utility.arrays")
|
|
30
31
|
local emptyArray = ____arrays.emptyArray
|
|
@@ -58,9 +59,9 @@ end
|
|
|
58
59
|
function ObjectFieldBase.prototype.supports(self, instance)
|
|
59
60
|
return __TS__InstanceOf(instance, self.instanceClass)
|
|
60
61
|
end
|
|
61
|
-
function ObjectFieldBase.prototype.hasValue(self,
|
|
62
|
+
function ObjectFieldBase.prototype.hasValue(self, objectDataEntryId)
|
|
62
63
|
local defaultValueByObjectDataEntryId = defaultValueByObjectDataEntryIdByObjectFieldId[self.id]
|
|
63
|
-
return self.isGlobal or defaultValueByObjectDataEntryId ~= nil and defaultValueByObjectDataEntryId[
|
|
64
|
+
return self.isGlobal or defaultValueByObjectDataEntryId ~= nil and defaultValueByObjectDataEntryId[objectDataEntryId] ~= nil or self:hasNativeFieldValue(objectDataEntryId)
|
|
64
65
|
end
|
|
65
66
|
function ObjectFieldBase.create(self, id, isGlobal)
|
|
66
67
|
return __TS__New(
|
|
@@ -99,7 +100,7 @@ function ObjectField.prototype.getValue(self, entry, includeModifiers)
|
|
|
99
100
|
end
|
|
100
101
|
return self.defaultValue
|
|
101
102
|
end
|
|
102
|
-
if includeModifiers
|
|
103
|
+
if not includeModifiers then
|
|
103
104
|
local originalValueByInstance = self.originalValueByInstance
|
|
104
105
|
if originalValueByInstance ~= nil then
|
|
105
106
|
local originalValue = originalValueByInstance[entry]
|
|
@@ -123,6 +124,7 @@ function ObjectField.prototype.setValue(self, entry, value)
|
|
|
123
124
|
defaultValueByObjectDataEntryId[entry.id] = value
|
|
124
125
|
return true
|
|
125
126
|
end
|
|
127
|
+
local previousOriginalValue
|
|
126
128
|
local modifiersByInstance = self.modifiersByInstance
|
|
127
129
|
if modifiersByInstance ~= nil then
|
|
128
130
|
local modifiers = modifiersByInstance[entry]
|
|
@@ -132,11 +134,34 @@ function ObjectField.prototype.setValue(self, entry, value)
|
|
|
132
134
|
originalValueByInstance = mutableWeakLuaMap()
|
|
133
135
|
self.originalValueByInstance = originalValueByInstance
|
|
134
136
|
end
|
|
137
|
+
previousOriginalValue = originalValueByInstance[entry]
|
|
138
|
+
if value == previousOriginalValue then
|
|
139
|
+
return true
|
|
140
|
+
end
|
|
135
141
|
originalValueByInstance[entry] = value
|
|
136
142
|
value = self:calculateActualValue(entry)
|
|
137
143
|
end
|
|
138
144
|
end
|
|
139
|
-
|
|
145
|
+
local previousValue = self:setActualValue(entry, value)
|
|
146
|
+
if previousValue == nil then
|
|
147
|
+
return false
|
|
148
|
+
end
|
|
149
|
+
if previousOriginalValue ~= nil or value ~= previousValue then
|
|
150
|
+
local ____self_invokeValueChangeEvent_2 = self.invokeValueChangeEvent
|
|
151
|
+
local ____entry_1 = entry
|
|
152
|
+
local ____previousOriginalValue_0 = previousOriginalValue
|
|
153
|
+
if ____previousOriginalValue_0 == nil then
|
|
154
|
+
____previousOriginalValue_0 = previousValue
|
|
155
|
+
end
|
|
156
|
+
____self_invokeValueChangeEvent_2(
|
|
157
|
+
self,
|
|
158
|
+
____entry_1,
|
|
159
|
+
self,
|
|
160
|
+
____previousOriginalValue_0,
|
|
161
|
+
value
|
|
162
|
+
)
|
|
163
|
+
end
|
|
164
|
+
return true
|
|
140
165
|
end
|
|
141
166
|
function ObjectField.prototype.applyModifier(self, instance, modifier)
|
|
142
167
|
local modifiersByInstance = self.modifiersByInstance
|
|
@@ -150,7 +175,13 @@ function ObjectField.prototype.applyModifier(self, instance, modifier)
|
|
|
150
175
|
originalValueByInstance = mutableWeakLuaMap()
|
|
151
176
|
self.originalValueByInstance = originalValueByInstance
|
|
152
177
|
end
|
|
153
|
-
|
|
178
|
+
local ____originalValueByInstance_4 = originalValueByInstance
|
|
179
|
+
local ____instance_5 = instance
|
|
180
|
+
local ____originalValueByInstance_instance_3 = originalValueByInstance[instance]
|
|
181
|
+
if ____originalValueByInstance_instance_3 == nil then
|
|
182
|
+
____originalValueByInstance_instance_3 = self:getActualValue(instance)
|
|
183
|
+
end
|
|
184
|
+
____originalValueByInstance_4[____instance_5] = ____originalValueByInstance_instance_3
|
|
154
185
|
self:setActualValue(
|
|
155
186
|
instance,
|
|
156
187
|
self:calculateActualValue(instance)
|
|
@@ -196,61 +227,56 @@ function ObjectField.prototype.getActualValue(self, instance)
|
|
|
196
227
|
if defaultValueByObjectDataEntryId ~= nil or self.isGlobal then
|
|
197
228
|
local defaultValue = (defaultValueByObjectDataEntryId or emptyLuaMap())[self:getObjectDataEntryId(instance)]
|
|
198
229
|
if defaultValue ~= nil or self.isGlobal then
|
|
199
|
-
local
|
|
200
|
-
if
|
|
201
|
-
|
|
230
|
+
local ____self_valueByInstance_instance_6 = self.valueByInstance[instance]
|
|
231
|
+
if ____self_valueByInstance_instance_6 == nil then
|
|
232
|
+
____self_valueByInstance_instance_6 = defaultValue
|
|
202
233
|
end
|
|
203
|
-
local
|
|
204
|
-
if
|
|
205
|
-
|
|
234
|
+
local ____self_valueByInstance_instance_6_7 = ____self_valueByInstance_instance_6
|
|
235
|
+
if ____self_valueByInstance_instance_6_7 == nil then
|
|
236
|
+
____self_valueByInstance_instance_6_7 = self.defaultValue
|
|
206
237
|
end
|
|
207
|
-
return
|
|
238
|
+
return ____self_valueByInstance_instance_6_7
|
|
208
239
|
end
|
|
209
240
|
end
|
|
210
|
-
local
|
|
211
|
-
if
|
|
212
|
-
|
|
241
|
+
local ____temp_8 = self:getNativeFieldValue(instance)
|
|
242
|
+
if ____temp_8 == nil then
|
|
243
|
+
____temp_8 = self.defaultValue
|
|
213
244
|
end
|
|
214
|
-
return
|
|
245
|
+
return ____temp_8
|
|
215
246
|
end
|
|
216
247
|
function ObjectField.prototype.setActualValue(self, instance, value)
|
|
217
248
|
local defaultValueByObjectDataEntryId = defaultValueByObjectDataEntryIdByObjectFieldId[self.id]
|
|
249
|
+
local objectDataEntryId = self:getObjectDataEntryId(instance)
|
|
218
250
|
if defaultValueByObjectDataEntryId ~= nil or self.isGlobal then
|
|
219
|
-
local defaultValue = (defaultValueByObjectDataEntryId or emptyLuaMap())[
|
|
251
|
+
local defaultValue = (defaultValueByObjectDataEntryId or emptyLuaMap())[objectDataEntryId]
|
|
220
252
|
if defaultValue ~= nil or self.isGlobal then
|
|
221
|
-
local
|
|
222
|
-
if
|
|
223
|
-
|
|
224
|
-
end
|
|
225
|
-
local ____self_valueByInstance_instance_3_4 = ____self_valueByInstance_instance_3
|
|
226
|
-
if ____self_valueByInstance_instance_3_4 == nil then
|
|
227
|
-
____self_valueByInstance_instance_3_4 = self.defaultValue
|
|
253
|
+
local ____self_valueByInstance_instance_9 = self.valueByInstance[instance]
|
|
254
|
+
if ____self_valueByInstance_instance_9 == nil then
|
|
255
|
+
____self_valueByInstance_instance_9 = defaultValue
|
|
228
256
|
end
|
|
229
|
-
local
|
|
230
|
-
if
|
|
231
|
-
|
|
232
|
-
self:invokeValueChangeEvent(instance, self, previousValue, value)
|
|
257
|
+
local ____self_valueByInstance_instance_9_10 = ____self_valueByInstance_instance_9
|
|
258
|
+
if ____self_valueByInstance_instance_9_10 == nil then
|
|
259
|
+
____self_valueByInstance_instance_9_10 = self.defaultValue
|
|
233
260
|
end
|
|
234
|
-
|
|
261
|
+
local previousValue = ____self_valueByInstance_instance_9_10
|
|
262
|
+
self.valueByInstance[instance] = value
|
|
263
|
+
return previousValue
|
|
235
264
|
end
|
|
236
265
|
end
|
|
237
|
-
if not self:hasNativeFieldValue(
|
|
238
|
-
return
|
|
266
|
+
if not self:hasNativeFieldValue(objectDataEntryId) then
|
|
267
|
+
return nil
|
|
239
268
|
end
|
|
240
269
|
local previousValue = self:getNativeFieldValue(instance)
|
|
241
|
-
if value ~= previousValue then
|
|
242
|
-
|
|
243
|
-
return false
|
|
244
|
-
end
|
|
245
|
-
self:invokeValueChangeEvent(instance, self, previousValue, value)
|
|
270
|
+
if value ~= previousValue and not self:setNativeFieldValue(instance, value) then
|
|
271
|
+
return nil
|
|
246
272
|
end
|
|
247
|
-
return
|
|
273
|
+
return previousValue
|
|
248
274
|
end
|
|
249
275
|
function ObjectField.prototype.calculateActualValue(self, instance)
|
|
250
|
-
local
|
|
251
|
-
local originalValue =
|
|
252
|
-
local
|
|
253
|
-
local modifiers =
|
|
276
|
+
local ____opt_11 = self.originalValueByInstance
|
|
277
|
+
local originalValue = ____opt_11 and ____opt_11[instance]
|
|
278
|
+
local ____opt_13 = self.modifiersByInstance
|
|
279
|
+
local modifiers = ____opt_13 and ____opt_13[instance]
|
|
254
280
|
if originalValue ~= nil then
|
|
255
281
|
local value = originalValue
|
|
256
282
|
if modifiers ~= nil then
|
|
@@ -315,17 +341,17 @@ function ObjectArrayField.prototype.getValue(self, entry, index)
|
|
|
315
341
|
if defaultValueByObjectDataEntryId ~= nil then
|
|
316
342
|
local value = defaultValueByObjectDataEntryId[entry.id]
|
|
317
343
|
if value ~= nil then
|
|
318
|
-
local
|
|
344
|
+
local ____temp_16
|
|
319
345
|
if index == nil then
|
|
320
|
-
|
|
346
|
+
____temp_16 = value
|
|
321
347
|
else
|
|
322
|
-
local
|
|
323
|
-
if
|
|
324
|
-
|
|
348
|
+
local ____value_index_15 = value[index + 1]
|
|
349
|
+
if ____value_index_15 == nil then
|
|
350
|
+
____value_index_15 = self.defaultValue
|
|
325
351
|
end
|
|
326
|
-
|
|
352
|
+
____temp_16 = ____value_index_15
|
|
327
353
|
end
|
|
328
|
-
return
|
|
354
|
+
return ____temp_16
|
|
329
355
|
end
|
|
330
356
|
end
|
|
331
357
|
return index == nil and ({}) or self.defaultValue
|
|
@@ -335,17 +361,17 @@ function ObjectArrayField.prototype.getValue(self, entry, index)
|
|
|
335
361
|
local defaultValue = (defaultValueByObjectDataEntryId or emptyLuaMap())[self:getObjectDataEntryId(entry)]
|
|
336
362
|
if defaultValue ~= nil or self.isGlobal then
|
|
337
363
|
local value = self.valueByInstance[entry] or defaultValue or emptyArray()
|
|
338
|
-
local
|
|
364
|
+
local ____temp_18
|
|
339
365
|
if index == nil then
|
|
340
|
-
|
|
366
|
+
____temp_18 = value
|
|
341
367
|
else
|
|
342
|
-
local
|
|
343
|
-
if
|
|
344
|
-
|
|
368
|
+
local ____value_index_17 = value[index + 1]
|
|
369
|
+
if ____value_index_17 == nil then
|
|
370
|
+
____value_index_17 = self.defaultValue
|
|
345
371
|
end
|
|
346
|
-
|
|
372
|
+
____temp_18 = ____value_index_17
|
|
347
373
|
end
|
|
348
|
-
return
|
|
374
|
+
return ____temp_18
|
|
349
375
|
end
|
|
350
376
|
end
|
|
351
377
|
if index ~= nil then
|
|
@@ -390,36 +416,22 @@ function ObjectLevelField.prototype.getValue(self, entry, level)
|
|
|
390
416
|
if defaultValueByObjectDataEntryId ~= nil then
|
|
391
417
|
local valueByLevel = defaultValueByObjectDataEntryId[entry.id]
|
|
392
418
|
if valueByLevel ~= nil then
|
|
393
|
-
local
|
|
394
|
-
if
|
|
395
|
-
|
|
419
|
+
local ____valueByLevel_index_19 = valueByLevel[level + 1]
|
|
420
|
+
if ____valueByLevel_index_19 == nil then
|
|
421
|
+
____valueByLevel_index_19 = self.defaultValue
|
|
396
422
|
end
|
|
397
|
-
return
|
|
423
|
+
return ____valueByLevel_index_19
|
|
398
424
|
end
|
|
399
425
|
end
|
|
400
426
|
return self.defaultValue
|
|
401
427
|
end
|
|
402
|
-
local
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
local ____temp_16 = ____opt_14 and ____opt_14[level + 1]
|
|
408
|
-
if ____temp_16 == nil then
|
|
409
|
-
____temp_16 = (defaultValueByLevel or emptyArray())[level + 1]
|
|
410
|
-
end
|
|
411
|
-
local ____temp_16_17 = ____temp_16
|
|
412
|
-
if ____temp_16_17 == nil then
|
|
413
|
-
____temp_16_17 = self.defaultValue
|
|
414
|
-
end
|
|
415
|
-
return ____temp_16_17
|
|
416
|
-
end
|
|
417
|
-
end
|
|
418
|
-
local ____temp_18 = self:getNativeFieldValue(entry, level)
|
|
419
|
-
if ____temp_18 == nil then
|
|
420
|
-
____temp_18 = self.defaultValue
|
|
428
|
+
local ____opt_22 = self.originalValueByLevelByInstance
|
|
429
|
+
local ____opt_20 = ____opt_22 and ____opt_22[entry]
|
|
430
|
+
local originalValue = ____opt_20 and ____opt_20[level]
|
|
431
|
+
if originalValue ~= nil then
|
|
432
|
+
return originalValue
|
|
421
433
|
end
|
|
422
|
-
return
|
|
434
|
+
return self:getActualValue(entry, level)
|
|
423
435
|
end
|
|
424
436
|
function ObjectLevelField.prototype.setValue(self, entry, levelOrValue, value)
|
|
425
437
|
if value == nil then
|
|
@@ -459,55 +471,93 @@ function ObjectLevelField.prototype.setValue(self, entry, levelOrValue, value)
|
|
|
459
471
|
valueByLevel[level + 1] = value
|
|
460
472
|
return true
|
|
461
473
|
end
|
|
462
|
-
local
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
local ____valueByLevel_index_19 = valueByLevel[level + 1]
|
|
472
|
-
if ____valueByLevel_index_19 == nil then
|
|
473
|
-
____valueByLevel_index_19 = (defaultValueByLevel or emptyArray())[level + 1]
|
|
474
|
+
local previousOriginalValue
|
|
475
|
+
local modifiersByInstance = self.modifiersByInstance
|
|
476
|
+
if modifiersByInstance ~= nil then
|
|
477
|
+
local modifiers = modifiersByInstance[entry]
|
|
478
|
+
if modifiers ~= nil and modifiers.size ~= 0 then
|
|
479
|
+
local originalValueByLevelByInstance = self.originalValueByLevelByInstance
|
|
480
|
+
if originalValueByLevelByInstance == nil then
|
|
481
|
+
originalValueByLevelByInstance = mutableWeakLuaMap()
|
|
482
|
+
self.originalValueByLevelByInstance = originalValueByLevelByInstance
|
|
474
483
|
end
|
|
475
|
-
local
|
|
476
|
-
|
|
477
|
-
|
|
484
|
+
local originalValueByLevel = getOrPut(originalValueByLevelByInstance, entry, mutableLuaMap)
|
|
485
|
+
previousOriginalValue = originalValueByLevel[level]
|
|
486
|
+
if value == previousOriginalValue then
|
|
487
|
+
return true
|
|
478
488
|
end
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
valueByLevel[level + 1] = value
|
|
482
|
-
self:invokeValueChangeEvent(
|
|
483
|
-
entry,
|
|
484
|
-
self,
|
|
485
|
-
level,
|
|
486
|
-
previousValue,
|
|
487
|
-
value
|
|
488
|
-
)
|
|
489
|
-
end
|
|
490
|
-
return true
|
|
489
|
+
originalValueByLevel[level] = value
|
|
490
|
+
value = self:calculateActualValue(entry, level)
|
|
491
491
|
end
|
|
492
492
|
end
|
|
493
|
-
|
|
493
|
+
local previousValue = self:setActualValue(entry, level, value)
|
|
494
|
+
if previousValue == nil then
|
|
494
495
|
return false
|
|
495
496
|
end
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
497
|
+
if previousOriginalValue ~= nil or value ~= previousValue then
|
|
498
|
+
local ____self_invokeValueChangeEvent_26 = self.invokeValueChangeEvent
|
|
499
|
+
local ____entry_25 = entry
|
|
500
|
+
local ____previousOriginalValue_24 = previousOriginalValue
|
|
501
|
+
if ____previousOriginalValue_24 == nil then
|
|
502
|
+
____previousOriginalValue_24 = previousValue
|
|
500
503
|
end
|
|
501
|
-
|
|
502
|
-
|
|
504
|
+
____self_invokeValueChangeEvent_26(
|
|
505
|
+
self,
|
|
506
|
+
____entry_25,
|
|
503
507
|
self,
|
|
504
508
|
level,
|
|
505
|
-
|
|
509
|
+
____previousOriginalValue_24,
|
|
506
510
|
value
|
|
507
511
|
)
|
|
508
512
|
end
|
|
509
513
|
return true
|
|
510
514
|
end
|
|
515
|
+
function ObjectLevelField.prototype.applyModifier(self, instance, modifier)
|
|
516
|
+
local modifiersByInstance = self.modifiersByInstance
|
|
517
|
+
if modifiersByInstance == nil then
|
|
518
|
+
modifiersByInstance = mutableWeakLuaMap()
|
|
519
|
+
self.modifiersByInstance = modifiersByInstance
|
|
520
|
+
end
|
|
521
|
+
if getOrPut(modifiersByInstance, instance, mutableLinkedSet):add(modifier) then
|
|
522
|
+
local originalValueByLevelByInstance = self.originalValueByLevelByInstance
|
|
523
|
+
if originalValueByLevelByInstance == nil then
|
|
524
|
+
originalValueByLevelByInstance = mutableWeakLuaMap()
|
|
525
|
+
self.originalValueByLevelByInstance = originalValueByLevelByInstance
|
|
526
|
+
end
|
|
527
|
+
local originalValueByLevel = getOrPut(originalValueByLevelByInstance, instance, mutableLuaMap)
|
|
528
|
+
local levelCount = self:getLevelCount(instance)
|
|
529
|
+
for level = 0, levelCount - 1 do
|
|
530
|
+
local ____originalValueByLevel_level_27 = originalValueByLevel[level]
|
|
531
|
+
if ____originalValueByLevel_level_27 == nil then
|
|
532
|
+
____originalValueByLevel_level_27 = self:getActualValue(instance, level)
|
|
533
|
+
end
|
|
534
|
+
originalValueByLevel[level] = ____originalValueByLevel_level_27
|
|
535
|
+
self:setActualValue(
|
|
536
|
+
instance,
|
|
537
|
+
level,
|
|
538
|
+
self:calculateActualValue(instance, level)
|
|
539
|
+
)
|
|
540
|
+
end
|
|
541
|
+
end
|
|
542
|
+
end
|
|
543
|
+
function ObjectLevelField.prototype.removeModifier(self, instance, modifier)
|
|
544
|
+
local modifiersByInstance = self.modifiersByInstance
|
|
545
|
+
if modifiersByInstance ~= nil then
|
|
546
|
+
local modifiers = modifiersByInstance[instance]
|
|
547
|
+
if modifiers ~= nil and modifiers:remove(modifier) then
|
|
548
|
+
local levelCount = self:getLevelCount(instance)
|
|
549
|
+
for level = 0, levelCount - 1 do
|
|
550
|
+
self:setActualValue(
|
|
551
|
+
instance,
|
|
552
|
+
level,
|
|
553
|
+
self:calculateActualValue(instance, level)
|
|
554
|
+
)
|
|
555
|
+
end
|
|
556
|
+
return true
|
|
557
|
+
end
|
|
558
|
+
end
|
|
559
|
+
return false
|
|
560
|
+
end
|
|
511
561
|
function ObjectLevelField.prototype.trySetValue(self, entry, levelOrValue, value)
|
|
512
562
|
if value ~= nil then
|
|
513
563
|
if __TS__TypeOf(value) ~= __TS__TypeOf(self.defaultValue) then
|
|
@@ -523,6 +573,79 @@ function ObjectLevelField.prototype.trySetValue(self, entry, levelOrValue, value
|
|
|
523
573
|
end
|
|
524
574
|
return self:setValue(entry, levelOrValue)
|
|
525
575
|
end
|
|
576
|
+
function ObjectLevelField.prototype.getActualValue(self, instance, level)
|
|
577
|
+
local defaultValueByObjectDataEntryId = defaultValueByObjectDataEntryIdByObjectFieldId[self.id]
|
|
578
|
+
if defaultValueByObjectDataEntryId ~= nil or self.isGlobal then
|
|
579
|
+
local defaultValueByLevel = (defaultValueByObjectDataEntryId or emptyLuaMap())[self:getObjectDataEntryId(instance)]
|
|
580
|
+
if defaultValueByLevel ~= nil or self.isGlobal then
|
|
581
|
+
local ____opt_28 = self.valueByInstance[instance]
|
|
582
|
+
local ____temp_30 = ____opt_28 and ____opt_28[level + 1]
|
|
583
|
+
if ____temp_30 == nil then
|
|
584
|
+
____temp_30 = (defaultValueByLevel or emptyArray())[level + 1]
|
|
585
|
+
end
|
|
586
|
+
local ____temp_30_31 = ____temp_30
|
|
587
|
+
if ____temp_30_31 == nil then
|
|
588
|
+
____temp_30_31 = self.defaultValue
|
|
589
|
+
end
|
|
590
|
+
return ____temp_30_31
|
|
591
|
+
end
|
|
592
|
+
end
|
|
593
|
+
local ____temp_32 = self:getNativeFieldValue(instance, level)
|
|
594
|
+
if ____temp_32 == nil then
|
|
595
|
+
____temp_32 = self.defaultValue
|
|
596
|
+
end
|
|
597
|
+
return ____temp_32
|
|
598
|
+
end
|
|
599
|
+
function ObjectLevelField.prototype.setActualValue(self, instance, level, value)
|
|
600
|
+
local defaultValueByObjectDataEntryId = defaultValueByObjectDataEntryIdByObjectFieldId[self.id]
|
|
601
|
+
local objectDataEntryId = self:getObjectDataEntryId(instance)
|
|
602
|
+
if defaultValueByObjectDataEntryId ~= nil or self.isGlobal then
|
|
603
|
+
local defaultValueByLevel = (defaultValueByObjectDataEntryId or emptyLuaMap())[objectDataEntryId]
|
|
604
|
+
if defaultValueByLevel ~= nil or self.isGlobal then
|
|
605
|
+
local valueByLevel = self.valueByInstance[instance]
|
|
606
|
+
if valueByLevel == nil then
|
|
607
|
+
valueByLevel = {}
|
|
608
|
+
self.valueByInstance[instance] = valueByLevel
|
|
609
|
+
end
|
|
610
|
+
local ____valueByLevel_index_33 = valueByLevel[level + 1]
|
|
611
|
+
if ____valueByLevel_index_33 == nil then
|
|
612
|
+
____valueByLevel_index_33 = (defaultValueByLevel or emptyArray())[level + 1]
|
|
613
|
+
end
|
|
614
|
+
local ____valueByLevel_index_33_34 = ____valueByLevel_index_33
|
|
615
|
+
if ____valueByLevel_index_33_34 == nil then
|
|
616
|
+
____valueByLevel_index_33_34 = self.defaultValue
|
|
617
|
+
end
|
|
618
|
+
local previousValue = ____valueByLevel_index_33_34
|
|
619
|
+
valueByLevel[level + 1] = value
|
|
620
|
+
return previousValue
|
|
621
|
+
end
|
|
622
|
+
end
|
|
623
|
+
if not self:hasNativeFieldValue(objectDataEntryId) then
|
|
624
|
+
return nil
|
|
625
|
+
end
|
|
626
|
+
local previousValue = self:getNativeFieldValue(instance, level)
|
|
627
|
+
if value ~= previousValue and not self:setNativeFieldValue(instance, level, value) then
|
|
628
|
+
return nil
|
|
629
|
+
end
|
|
630
|
+
return previousValue
|
|
631
|
+
end
|
|
632
|
+
function ObjectLevelField.prototype.calculateActualValue(self, instance, level)
|
|
633
|
+
local ____opt_37 = self.originalValueByLevelByInstance
|
|
634
|
+
local ____opt_35 = ____opt_37 and ____opt_37[instance]
|
|
635
|
+
local originalValue = ____opt_35 and ____opt_35[level]
|
|
636
|
+
local ____opt_39 = self.modifiersByInstance
|
|
637
|
+
local modifiers = ____opt_39 and ____opt_39[instance]
|
|
638
|
+
if originalValue ~= nil then
|
|
639
|
+
local value = originalValue
|
|
640
|
+
if modifiers ~= nil then
|
|
641
|
+
for modifier in pairs(modifiers) do
|
|
642
|
+
value = modifier(instance, level, value, originalValue)
|
|
643
|
+
end
|
|
644
|
+
end
|
|
645
|
+
return value
|
|
646
|
+
end
|
|
647
|
+
return self.defaultValue
|
|
648
|
+
end
|
|
526
649
|
function ObjectLevelField.prototype.invokeValueChangeEvent(self, ...)
|
|
527
650
|
self:invokeValueChangeEventRecursive(
|
|
528
651
|
getClass(self),
|
package/engine/random.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/** @noSelfInFile */
|
|
2
|
+
import { ReadonlyNonEmptyArray } from "../utility/types";
|
|
2
3
|
export declare const randomAngle: () => number;
|
|
3
4
|
export declare const randomInteger: {
|
|
4
5
|
(upperBound?: number): number;
|
|
@@ -9,3 +10,11 @@ export declare const randomFloat: {
|
|
|
9
10
|
(lowerBound: number, upperBound: number): number;
|
|
10
11
|
};
|
|
11
12
|
export declare const randomXY: (centerX: number, centerY: number, range: number) => LuaMultiReturn<[x: number, y: number]>;
|
|
13
|
+
export declare const randomElement: {
|
|
14
|
+
<T>(array: ReadonlyNonEmptyArray<T>): T;
|
|
15
|
+
<T>(array: ReadonlyArray<T>): T | undefined;
|
|
16
|
+
};
|
|
17
|
+
export declare const random: {
|
|
18
|
+
<T>(element: T, ...elements: T[]): T;
|
|
19
|
+
<T>(...elements: T[]): T | undefined;
|
|
20
|
+
};
|
package/engine/random.lua
CHANGED
|
@@ -4,6 +4,7 @@ local MAXIMUM_INTEGER = ____math.MAXIMUM_INTEGER
|
|
|
4
4
|
local PI = ____math.PI
|
|
5
5
|
local getRandomInt = GetRandomInt
|
|
6
6
|
local getRandomReal = GetRandomReal
|
|
7
|
+
local select = _G.select
|
|
7
8
|
local cos = math.cos
|
|
8
9
|
local sin = math.sin
|
|
9
10
|
local sqrt = math.sqrt
|
|
@@ -15,4 +16,16 @@ ____exports.randomXY = function(centerX, centerY, range)
|
|
|
15
16
|
local t = getRandomReal(0, 1) * 2 * PI
|
|
16
17
|
return centerX + r * cos(t), centerY + r * sin(t)
|
|
17
18
|
end
|
|
19
|
+
____exports.randomElement = function(array)
|
|
20
|
+
return array[getRandomInt(1, #array)]
|
|
21
|
+
end
|
|
22
|
+
____exports.random = function(...)
|
|
23
|
+
return (select(
|
|
24
|
+
getRandomInt(
|
|
25
|
+
1,
|
|
26
|
+
select("#", ...)
|
|
27
|
+
),
|
|
28
|
+
...
|
|
29
|
+
))
|
|
30
|
+
end
|
|
18
31
|
return ____exports
|
|
@@ -376,8 +376,8 @@ export declare const INVISIBILITY_TRANSITION_TIME_ABILITY_FLOAT_LEVEL_FIELD: Abi
|
|
|
376
376
|
export declare const ACTIVATION_RADIUS_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
377
377
|
export declare const AMOUNT_REGENERATED_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
378
378
|
export declare const DAMAGE_PER_SECOND_POI1_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
379
|
-
export declare const
|
|
380
|
-
export declare const
|
|
379
|
+
export declare const MOVEMENT_SPEED_FACTOR_POI2_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
380
|
+
export declare const ATTACK_SPEED_FACTOR_POI3_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
381
381
|
export declare const EXTRA_DAMAGE_POA1_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
382
382
|
export declare const DAMAGE_PER_SECOND_POA2_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
383
383
|
export declare const ATTACK_SPEED_FACTOR_POA3_ABILITY_FLOAT_LEVEL_FIELD: AbilityFloatLevelField & symbol;
|
|
@@ -387,8 +387,8 @@ ____exports.INVISIBILITY_TRANSITION_TIME_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloa
|
|
|
387
387
|
____exports.ACTIVATION_RADIUS_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Neu1"))
|
|
388
388
|
____exports.AMOUNT_REGENERATED_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Arm1"))
|
|
389
389
|
____exports.DAMAGE_PER_SECOND_POI1_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poi1"))
|
|
390
|
-
____exports.
|
|
391
|
-
____exports.
|
|
390
|
+
____exports.MOVEMENT_SPEED_FACTOR_POI2_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poi2"))
|
|
391
|
+
____exports.ATTACK_SPEED_FACTOR_POI3_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poi3"))
|
|
392
392
|
____exports.EXTRA_DAMAGE_POA1_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poa1"))
|
|
393
393
|
____exports.DAMAGE_PER_SECOND_POA2_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poa2"))
|
|
394
394
|
____exports.ATTACK_SPEED_FACTOR_POA3_ABILITY_FLOAT_LEVEL_FIELD = AbilityFloatLevelField:create(fourCC("Poa3"))
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
/** @noSelfInFile */
|
|
2
|
-
import { UnitClassificationsField, UnitPropulsionWindowField } from "../../object-field/unit";
|
|
2
|
+
import { UnitClassificationsField, UnitFlyHeightField, UnitHealthRegenerationTypeField, UnitPropulsionWindowField, UnitScalingValueField } from "../../object-field/unit";
|
|
3
3
|
export declare const PROPULSION_WINDOW_UNIT_FLOAT_FIELD: UnitPropulsionWindowField & symbol;
|
|
4
4
|
export declare const UNIT_CLASSIFICATIONS_FIELD: UnitClassificationsField & symbol;
|
|
5
|
+
export declare const FLY_HEIGHT_UNIT_FLOAT_FIELD: UnitFlyHeightField & symbol;
|
|
6
|
+
export declare const SCALING_VALUE_UNIT_FLOAT_FIELD: UnitScalingValueField & symbol;
|
|
7
|
+
export declare const UNIT_HEALTH_REGENERATION_TYPE_FIELD: UnitHealthRegenerationTypeField & symbol;
|
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
local ____exports = {}
|
|
2
2
|
local ____unit = require("engine.object-field.unit")
|
|
3
3
|
local UnitClassificationsField = ____unit.UnitClassificationsField
|
|
4
|
+
local UnitFlyHeightField = ____unit.UnitFlyHeightField
|
|
5
|
+
local UnitHealthRegenerationTypeField = ____unit.UnitHealthRegenerationTypeField
|
|
4
6
|
local UnitPropulsionWindowField = ____unit.UnitPropulsionWindowField
|
|
7
|
+
local UnitScalingValueField = ____unit.UnitScalingValueField
|
|
5
8
|
____exports.PROPULSION_WINDOW_UNIT_FLOAT_FIELD = UnitPropulsionWindowField:create(fourCC("urpw"))
|
|
6
9
|
____exports.UNIT_CLASSIFICATIONS_FIELD = UnitClassificationsField:create(fourCC("utyp"))
|
|
10
|
+
____exports.FLY_HEIGHT_UNIT_FLOAT_FIELD = UnitFlyHeightField:create(fourCC("ufyh"))
|
|
11
|
+
____exports.SCALING_VALUE_UNIT_FLOAT_FIELD = UnitScalingValueField:create(fourCC("usca"))
|
|
12
|
+
____exports.UNIT_HEALTH_REGENERATION_TYPE_FIELD = UnitHealthRegenerationTypeField:create(fourCC("uhrt"))
|
|
7
13
|
return ____exports
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/** @noSelfInFile */
|
|
2
|
+
import { Player } from "../core/types/player";
|
|
3
|
+
import { Event } from "../event";
|
|
4
|
+
export declare const synchronizer: <T, K extends number>(getSyncId: (object: T) => K, getObject: (syncId: K) => T | undefined) => ((player: Player, object: T | undefined) => Promise<T | undefined>);
|
|
5
|
+
export declare class ObjectBus<T, K extends number> {
|
|
6
|
+
private readonly getSyncId;
|
|
7
|
+
readonly event: Event<[Player, T | undefined]>;
|
|
8
|
+
private readonly syncSlider;
|
|
9
|
+
constructor(getSyncId: (object: T) => K, getObject: (syncId: K) => T | undefined);
|
|
10
|
+
send(object: T | undefined): void;
|
|
11
|
+
}
|