@pezkuwi/types-codec 16.5.5 → 16.5.6
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/LICENSE +201 -0
- package/abstract/Array.js +166 -0
- package/abstract/Base.js +101 -0
- package/abstract/Int.js +226 -0
- package/abstract/Object.js +40 -0
- package/{src/abstract/index.ts → abstract/index.js} +0 -3
- package/base/Compact.js +159 -0
- package/base/DoNotConstruct.js +95 -0
- package/base/Enum.js +369 -0
- package/{build/base → base}/Int.d.ts +1 -1
- package/base/Int.js +26 -0
- package/base/Null.js +77 -0
- package/base/Option.js +232 -0
- package/base/Result.js +63 -0
- package/base/Tuple.js +110 -0
- package/{build/base → base}/UInt.d.ts +1 -1
- package/base/UInt.js +23 -0
- package/base/Vec.js +102 -0
- package/base/VecAny.js +17 -0
- package/base/VecFixed.js +67 -0
- package/{src/base/index.ts → base/index.js} +0 -3
- package/{src/bundle.ts → bundle.js} +0 -6
- package/cjs/abstract/Array.d.ts +89 -0
- package/cjs/abstract/Array.js +170 -0
- package/cjs/abstract/Base.d.ts +75 -0
- package/cjs/abstract/Base.js +105 -0
- package/cjs/abstract/Int.d.ts +80 -0
- package/cjs/abstract/Int.js +230 -0
- package/cjs/abstract/Object.d.ts +67 -0
- package/cjs/abstract/Object.js +44 -0
- package/cjs/abstract/index.d.ts +3 -0
- package/cjs/abstract/index.js +9 -0
- package/cjs/base/Compact.d.ts +88 -0
- package/cjs/base/Compact.js +163 -0
- package/cjs/base/DoNotConstruct.d.ts +63 -0
- package/cjs/base/DoNotConstruct.js +99 -0
- package/cjs/base/Enum.d.ts +118 -0
- package/cjs/base/Enum.js +373 -0
- package/cjs/base/Int.d.ts +16 -0
- package/cjs/base/Int.js +30 -0
- package/cjs/base/Null.d.ts +56 -0
- package/cjs/base/Null.js +81 -0
- package/cjs/base/Option.d.ts +94 -0
- package/cjs/base/Option.js +236 -0
- package/cjs/base/Result.d.ts +38 -0
- package/cjs/base/Result.js +67 -0
- package/cjs/base/Tuple.d.ts +42 -0
- package/cjs/base/Tuple.js +114 -0
- package/cjs/base/UInt.d.ts +15 -0
- package/cjs/base/UInt.js +27 -0
- package/cjs/base/Vec.d.ts +28 -0
- package/cjs/base/Vec.js +107 -0
- package/cjs/base/VecAny.d.ts +15 -0
- package/cjs/base/VecAny.js +21 -0
- package/cjs/base/VecFixed.d.ts +30 -0
- package/cjs/base/VecFixed.js +71 -0
- package/cjs/base/index.d.ts +12 -0
- package/cjs/base/index.js +27 -0
- package/cjs/bundle.d.ts +7 -0
- package/cjs/bundle.js +12 -0
- package/cjs/extended/BTreeMap.js +14 -0
- package/cjs/extended/BTreeSet.js +189 -0
- package/cjs/extended/BitVec.js +112 -0
- package/cjs/extended/Bytes.js +74 -0
- package/cjs/extended/HashMap.js +14 -0
- package/cjs/extended/Linkage.js +70 -0
- package/cjs/extended/Map.js +204 -0
- package/cjs/extended/OptionBool.js +76 -0
- package/cjs/extended/Range.js +42 -0
- package/cjs/extended/RangeInclusive.js +17 -0
- package/cjs/extended/Type.js +25 -0
- package/cjs/extended/U8aFixed.js +46 -0
- package/cjs/extended/WrapperKeepOpaque.js +103 -0
- package/cjs/extended/WrapperOpaque.js +23 -0
- package/cjs/extended/index.js +32 -0
- package/cjs/index.js +5 -0
- package/cjs/native/Bool.js +113 -0
- package/cjs/native/Date.js +144 -0
- package/cjs/native/Float.js +111 -0
- package/cjs/native/Json.js +121 -0
- package/cjs/native/Raw.js +144 -0
- package/cjs/native/Set.js +219 -0
- package/cjs/native/Struct.data.js +4 -0
- package/cjs/native/Struct.js +264 -0
- package/cjs/native/Text.js +154 -0
- package/cjs/native/index.js +22 -0
- package/cjs/package.json +3 -0
- package/cjs/packageDetect.js +5 -0
- package/cjs/packageInfo.js +4 -0
- package/cjs/primitive/F32.js +14 -0
- package/cjs/primitive/F64.js +14 -0
- package/cjs/primitive/I128.js +14 -0
- package/cjs/primitive/I16.js +14 -0
- package/cjs/primitive/I256.js +14 -0
- package/cjs/primitive/I32.js +14 -0
- package/cjs/primitive/I64.js +14 -0
- package/cjs/primitive/I8.js +14 -0
- package/cjs/primitive/ISize.js +18 -0
- package/cjs/primitive/U128.js +14 -0
- package/cjs/primitive/U16.js +14 -0
- package/cjs/primitive/U256.js +14 -0
- package/cjs/primitive/U32.js +14 -0
- package/cjs/primitive/U64.js +14 -0
- package/cjs/primitive/U8.js +14 -0
- package/cjs/primitive/USize.js +18 -0
- package/cjs/primitive/index.js +51 -0
- package/{build → cjs}/types/codec.d.ts +1 -1
- package/cjs/types/codec.js +2 -0
- package/cjs/types/helpers.js +2 -0
- package/cjs/types/index.js +7 -0
- package/cjs/types/interfaces.js +2 -0
- package/cjs/types/registry.js +2 -0
- package/cjs/utils/compareArray.js +13 -0
- package/cjs/utils/compareMap.js +30 -0
- package/cjs/utils/compareSet.js +20 -0
- package/cjs/utils/decodeU8a.js +105 -0
- package/cjs/utils/index.js +25 -0
- package/cjs/utils/sanitize.js +233 -0
- package/cjs/utils/sortValues.js +84 -0
- package/cjs/utils/toConstructors.js +40 -0
- package/cjs/utils/typesToMap.js +10 -0
- package/cjs/utils/util.js +7 -0
- package/extended/BTreeMap.d.ts +5 -0
- package/extended/BTreeMap.js +10 -0
- package/extended/BTreeSet.d.ts +64 -0
- package/extended/BTreeSet.js +185 -0
- package/extended/BitVec.d.ts +37 -0
- package/extended/BitVec.js +108 -0
- package/extended/Bytes.d.ts +29 -0
- package/extended/Bytes.js +70 -0
- package/extended/HashMap.d.ts +5 -0
- package/extended/HashMap.js +10 -0
- package/extended/Linkage.d.ts +37 -0
- package/extended/Linkage.js +65 -0
- package/extended/Map.d.ts +59 -0
- package/extended/Map.js +200 -0
- package/extended/OptionBool.d.ts +36 -0
- package/extended/OptionBool.js +72 -0
- package/extended/Range.d.ts +29 -0
- package/extended/Range.js +38 -0
- package/extended/RangeInclusive.d.ts +6 -0
- package/extended/RangeInclusive.js +13 -0
- package/extended/Type.d.ts +16 -0
- package/extended/Type.js +21 -0
- package/extended/U8aFixed.d.ts +16 -0
- package/extended/U8aFixed.js +42 -0
- package/extended/WrapperKeepOpaque.d.ts +40 -0
- package/extended/WrapperKeepOpaque.js +99 -0
- package/extended/WrapperOpaque.d.ts +10 -0
- package/extended/WrapperOpaque.js +19 -0
- package/{src/extended/index.ts → extended/index.d.ts} +0 -3
- package/extended/index.js +14 -0
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/native/Bool.d.ts +71 -0
- package/native/Bool.js +109 -0
- package/native/Date.d.ts +84 -0
- package/native/Date.js +140 -0
- package/native/Float.d.ts +68 -0
- package/native/Float.js +107 -0
- package/native/Json.d.ts +69 -0
- package/native/Json.js +117 -0
- package/native/Raw.d.ts +87 -0
- package/native/Raw.js +140 -0
- package/native/Set.d.ts +84 -0
- package/native/Set.js +215 -0
- package/native/Struct.d.ts +106 -0
- package/{src/native/Struct.data.ts → native/Struct.data.js} +0 -3
- package/native/Struct.js +260 -0
- package/native/Text.d.ts +77 -0
- package/native/Text.js +150 -0
- package/{src/native/index.ts → native/index.d.ts} +0 -3
- package/native/index.js +8 -0
- package/package.json +1126 -11
- package/packageDetect.d.ts +1 -0
- package/packageDetect.js +3 -0
- package/packageInfo.d.ts +6 -0
- package/packageInfo.js +1 -0
- package/primitive/F32.d.ts +11 -0
- package/primitive/F32.js +10 -0
- package/primitive/F64.d.ts +11 -0
- package/primitive/F64.js +10 -0
- package/primitive/I128.d.ts +11 -0
- package/primitive/I128.js +10 -0
- package/primitive/I16.d.ts +11 -0
- package/primitive/I16.js +10 -0
- package/primitive/I256.d.ts +11 -0
- package/primitive/I256.js +10 -0
- package/primitive/I32.d.ts +11 -0
- package/primitive/I32.js +10 -0
- package/primitive/I64.d.ts +11 -0
- package/primitive/I64.js +10 -0
- package/primitive/I8.d.ts +11 -0
- package/primitive/I8.js +10 -0
- package/primitive/ISize.d.ts +12 -0
- package/primitive/ISize.js +14 -0
- package/primitive/U128.d.ts +11 -0
- package/primitive/U128.js +10 -0
- package/primitive/U16.d.ts +11 -0
- package/primitive/U16.js +10 -0
- package/primitive/U256.d.ts +11 -0
- package/primitive/U256.js +10 -0
- package/primitive/U32.d.ts +11 -0
- package/primitive/U32.js +10 -0
- package/primitive/U64.d.ts +11 -0
- package/primitive/U64.js +10 -0
- package/primitive/U8.d.ts +11 -0
- package/primitive/U8.js +10 -0
- package/primitive/USize.d.ts +12 -0
- package/primitive/USize.js +14 -0
- package/{src/primitive/index.ts → primitive/index.d.ts} +0 -3
- package/primitive/index.js +16 -0
- package/types/codec.d.ts +113 -0
- package/types/codec.js +1 -0
- package/{src/types/helpers.ts → types/helpers.d.ts} +8 -31
- package/types/helpers.js +1 -0
- package/{src/types/index.ts → types/index.d.ts} +0 -3
- package/types/index.js +4 -0
- package/types/interfaces.d.ts +74 -0
- package/types/interfaces.js +1 -0
- package/types/registry.d.ts +67 -0
- package/types/registry.js +1 -0
- package/utils/compareArray.d.ts +1 -0
- package/utils/compareArray.js +10 -0
- package/utils/compareMap.d.ts +1 -0
- package/utils/compareMap.js +27 -0
- package/utils/compareSet.d.ts +1 -0
- package/utils/compareSet.js +17 -0
- package/utils/decodeU8a.d.ts +26 -0
- package/utils/decodeU8a.js +100 -0
- package/{src/utils/index.ts → utils/index.d.ts} +0 -3
- package/utils/index.js +8 -0
- package/utils/sanitize.d.ts +15 -0
- package/utils/sanitize.js +219 -0
- package/utils/sortValues.d.ts +12 -0
- package/utils/sortValues.js +79 -0
- package/utils/toConstructors.d.ts +16 -0
- package/utils/toConstructors.js +35 -0
- package/utils/typesToMap.d.ts +2 -0
- package/utils/typesToMap.js +7 -0
- package/utils/util.d.ts +3 -0
- package/utils/util.js +4 -0
- package/src/abstract/Array.ts +0 -213
- package/src/abstract/Base.ts +0 -129
- package/src/abstract/Int.ts +0 -271
- package/src/abstract/Object.ts +0 -99
- package/src/base/Compact.spec.ts +0 -99
- package/src/base/Compact.ts +0 -198
- package/src/base/DoNotConstruct.spec.ts +0 -23
- package/src/base/DoNotConstruct.ts +0 -118
- package/src/base/Enum.spec.ts +0 -487
- package/src/base/Enum.ts +0 -460
- package/src/base/Int.spec.ts +0 -225
- package/src/base/Int.ts +0 -34
- package/src/base/Null.spec.ts +0 -41
- package/src/base/Null.ts +0 -96
- package/src/base/Option.spec.ts +0 -216
- package/src/base/Option.ts +0 -275
- package/src/base/Result.spec.ts +0 -64
- package/src/base/Result.ts +0 -79
- package/src/base/Tuple.spec.ts +0 -161
- package/src/base/Tuple.ts +0 -149
- package/src/base/UInt.spec.ts +0 -192
- package/src/base/UInt.ts +0 -30
- package/src/base/Vec.spec.ts +0 -224
- package/src/base/Vec.ts +0 -133
- package/src/base/VecAny.ts +0 -23
- package/src/base/VecFixed.spec.ts +0 -78
- package/src/base/VecFixed.ts +0 -92
- package/src/checkTypes.manual.ts +0 -12
- package/src/extended/BTreeMap.spec.ts +0 -245
- package/src/extended/BTreeMap.ts +0 -16
- package/src/extended/BTreeSet.spec.ts +0 -260
- package/src/extended/BTreeSet.ts +0 -233
- package/src/extended/BitVec.spec.ts +0 -97
- package/src/extended/BitVec.ts +0 -137
- package/src/extended/Bytes.spec.ts +0 -75
- package/src/extended/Bytes.ts +0 -88
- package/src/extended/HashMap.spec.ts +0 -36
- package/src/extended/HashMap.ts +0 -16
- package/src/extended/Linkage.spec.ts +0 -43
- package/src/extended/Linkage.ts +0 -81
- package/src/extended/Map.spec.ts +0 -123
- package/src/extended/Map.ts +0 -255
- package/src/extended/OptionBool.spec.ts +0 -49
- package/src/extended/OptionBool.ts +0 -93
- package/src/extended/Range.spec.ts +0 -37
- package/src/extended/Range.ts +0 -56
- package/src/extended/RangeInclusive.ts +0 -20
- package/src/extended/Type.spec.ts +0 -118
- package/src/extended/Type.ts +0 -29
- package/src/extended/U8aFixed.spec.ts +0 -117
- package/src/extended/U8aFixed.ts +0 -57
- package/src/extended/WrapperKeepOpaque.spec.ts +0 -101
- package/src/extended/WrapperKeepOpaque.ts +0 -128
- package/src/extended/WrapperOpaque.spec.ts +0 -58
- package/src/extended/WrapperOpaque.ts +0 -27
- package/src/index.ts +0 -6
- package/src/mod.ts +0 -4
- package/src/native/Bool.spec.ts +0 -74
- package/src/native/Bool.ts +0 -137
- package/src/native/Date.spec.ts +0 -85
- package/src/native/Date.ts +0 -169
- package/src/native/Float.spec.ts +0 -51
- package/src/native/Float.ts +0 -136
- package/src/native/Json.ts +0 -147
- package/src/native/Raw.spec.ts +0 -113
- package/src/native/Raw.ts +0 -171
- package/src/native/Set.spec.ts +0 -116
- package/src/native/Set.ts +0 -269
- package/src/native/Struct.spec.ts +0 -411
- package/src/native/Struct.ts +0 -338
- package/src/native/Text.spec.ts +0 -85
- package/src/native/Text.ts +0 -184
- package/src/packageDetect.ts +0 -11
- package/src/packageInfo.ts +0 -6
- package/src/primitive/F32.ts +0 -14
- package/src/primitive/F64.ts +0 -14
- package/src/primitive/I128.ts +0 -14
- package/src/primitive/I16.ts +0 -14
- package/src/primitive/I256.ts +0 -14
- package/src/primitive/I32.ts +0 -14
- package/src/primitive/I64.ts +0 -14
- package/src/primitive/I8.ts +0 -14
- package/src/primitive/ISize.ts +0 -21
- package/src/primitive/U128.ts +0 -14
- package/src/primitive/U16.ts +0 -14
- package/src/primitive/U256.ts +0 -14
- package/src/primitive/U32.ts +0 -14
- package/src/primitive/U64.ts +0 -14
- package/src/primitive/U8.ts +0 -14
- package/src/primitive/USize.ts +0 -21
- package/src/test/performance.ts +0 -61
- package/src/types/codec.ts +0 -140
- package/src/types/interfaces.ts +0 -98
- package/src/types/registry.ts +0 -86
- package/src/utils/compareArray.ts +0 -22
- package/src/utils/compareMap.ts +0 -40
- package/src/utils/compareSet.ts +0 -23
- package/src/utils/decodeU8a.ts +0 -123
- package/src/utils/sanitize.spec.ts +0 -89
- package/src/utils/sanitize.ts +0 -290
- package/src/utils/sortValues.ts +0 -103
- package/src/utils/toConstructors.ts +0 -46
- package/src/utils/typesToMap.ts +0 -14
- package/src/utils/util.ts +0 -8
- package/tsconfig.build.json +0 -16
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.spec.json +0 -21
- /package/{build/abstract → abstract}/Array.d.ts +0 -0
- /package/{build/abstract → abstract}/Base.d.ts +0 -0
- /package/{build/abstract → abstract}/Int.d.ts +0 -0
- /package/{build/abstract → abstract}/Object.d.ts +0 -0
- /package/{build/abstract → abstract}/index.d.ts +0 -0
- /package/{build/base → base}/Compact.d.ts +0 -0
- /package/{build/base → base}/DoNotConstruct.d.ts +0 -0
- /package/{build/base → base}/Enum.d.ts +0 -0
- /package/{build/base → base}/Null.d.ts +0 -0
- /package/{build/base → base}/Option.d.ts +0 -0
- /package/{build/base → base}/Result.d.ts +0 -0
- /package/{build/base → base}/Tuple.d.ts +0 -0
- /package/{build/base → base}/Vec.d.ts +0 -0
- /package/{build/base → base}/VecAny.d.ts +0 -0
- /package/{build/base → base}/VecFixed.d.ts +0 -0
- /package/{build/base → base}/index.d.ts +0 -0
- /package/{build/bundle.d.ts → bundle.d.ts} +0 -0
- /package/{build → cjs}/extended/BTreeMap.d.ts +0 -0
- /package/{build → cjs}/extended/BTreeSet.d.ts +0 -0
- /package/{build → cjs}/extended/BitVec.d.ts +0 -0
- /package/{build → cjs}/extended/Bytes.d.ts +0 -0
- /package/{build → cjs}/extended/HashMap.d.ts +0 -0
- /package/{build → cjs}/extended/Linkage.d.ts +0 -0
- /package/{build → cjs}/extended/Map.d.ts +0 -0
- /package/{build → cjs}/extended/OptionBool.d.ts +0 -0
- /package/{build → cjs}/extended/Range.d.ts +0 -0
- /package/{build → cjs}/extended/RangeInclusive.d.ts +0 -0
- /package/{build → cjs}/extended/Type.d.ts +0 -0
- /package/{build → cjs}/extended/U8aFixed.d.ts +0 -0
- /package/{build → cjs}/extended/WrapperKeepOpaque.d.ts +0 -0
- /package/{build → cjs}/extended/WrapperOpaque.d.ts +0 -0
- /package/{build → cjs}/extended/index.d.ts +0 -0
- /package/{build → cjs}/index.d.ts +0 -0
- /package/{build → cjs}/native/Bool.d.ts +0 -0
- /package/{build → cjs}/native/Date.d.ts +0 -0
- /package/{build → cjs}/native/Float.d.ts +0 -0
- /package/{build → cjs}/native/Json.d.ts +0 -0
- /package/{build → cjs}/native/Raw.d.ts +0 -0
- /package/{build → cjs}/native/Set.d.ts +0 -0
- /package/{build → cjs}/native/Struct.d.ts +0 -0
- /package/{build → cjs}/native/Text.d.ts +0 -0
- /package/{build → cjs}/native/index.d.ts +0 -0
- /package/{build → cjs}/packageDetect.d.ts +0 -0
- /package/{build → cjs}/packageInfo.d.ts +0 -0
- /package/{build → cjs}/primitive/F32.d.ts +0 -0
- /package/{build → cjs}/primitive/F64.d.ts +0 -0
- /package/{build → cjs}/primitive/I128.d.ts +0 -0
- /package/{build → cjs}/primitive/I16.d.ts +0 -0
- /package/{build → cjs}/primitive/I256.d.ts +0 -0
- /package/{build → cjs}/primitive/I32.d.ts +0 -0
- /package/{build → cjs}/primitive/I64.d.ts +0 -0
- /package/{build → cjs}/primitive/I8.d.ts +0 -0
- /package/{build → cjs}/primitive/ISize.d.ts +0 -0
- /package/{build → cjs}/primitive/U128.d.ts +0 -0
- /package/{build → cjs}/primitive/U16.d.ts +0 -0
- /package/{build → cjs}/primitive/U256.d.ts +0 -0
- /package/{build → cjs}/primitive/U32.d.ts +0 -0
- /package/{build → cjs}/primitive/U64.d.ts +0 -0
- /package/{build → cjs}/primitive/U8.d.ts +0 -0
- /package/{build → cjs}/primitive/USize.d.ts +0 -0
- /package/{build → cjs}/primitive/index.d.ts +0 -0
- /package/{build → cjs}/types/helpers.d.ts +0 -0
- /package/{build → cjs}/types/index.d.ts +0 -0
- /package/{build → cjs}/types/interfaces.d.ts +0 -0
- /package/{build → cjs}/types/registry.d.ts +0 -0
- /package/{build → cjs}/utils/compareArray.d.ts +0 -0
- /package/{build → cjs}/utils/compareMap.d.ts +0 -0
- /package/{build → cjs}/utils/compareSet.d.ts +0 -0
- /package/{build → cjs}/utils/decodeU8a.d.ts +0 -0
- /package/{build → cjs}/utils/index.d.ts +0 -0
- /package/{build → cjs}/utils/sanitize.d.ts +0 -0
- /package/{build → cjs}/utils/sortValues.d.ts +0 -0
- /package/{build → cjs}/utils/toConstructors.d.ts +0 -0
- /package/{build → cjs}/utils/typesToMap.d.ts +0 -0
- /package/{build → cjs}/utils/util.d.ts +0 -0
package/cjs/base/Null.js
ADDED
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Null = void 0;
|
|
4
|
+
const util_1 = require("@pezkuwi/util");
|
|
5
|
+
/**
|
|
6
|
+
* @name Null
|
|
7
|
+
* @description
|
|
8
|
+
* Implements a type that does not contain anything (apart from `null`)
|
|
9
|
+
*/
|
|
10
|
+
class Null {
|
|
11
|
+
encodedLength = 0;
|
|
12
|
+
isEmpty = true;
|
|
13
|
+
registry;
|
|
14
|
+
createdAtHash;
|
|
15
|
+
initialU8aLength = 0;
|
|
16
|
+
isStorageFallback;
|
|
17
|
+
constructor(registry) {
|
|
18
|
+
this.registry = registry;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* @description returns a hash of the contents
|
|
22
|
+
*/
|
|
23
|
+
get hash() {
|
|
24
|
+
throw new Error('.hash is not implemented on Null');
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* @description Compares the value of the input to see if there is a match
|
|
28
|
+
*/
|
|
29
|
+
eq(other) {
|
|
30
|
+
return other instanceof Null || (0, util_1.isNull)(other);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
34
|
+
*/
|
|
35
|
+
inspect() {
|
|
36
|
+
return {};
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* @description Returns a hex string representation of the value
|
|
40
|
+
*/
|
|
41
|
+
toHex() {
|
|
42
|
+
return '0x';
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
46
|
+
*/
|
|
47
|
+
toHuman() {
|
|
48
|
+
return this.toJSON();
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
52
|
+
*/
|
|
53
|
+
toJSON() {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* @description Converts the value in a best-fit primitive form
|
|
58
|
+
*/
|
|
59
|
+
toPrimitive() {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* @description Returns the base runtime type name for this instance
|
|
64
|
+
*/
|
|
65
|
+
toRawType() {
|
|
66
|
+
return 'Null';
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* @description Returns the string representation of the value
|
|
70
|
+
*/
|
|
71
|
+
toString() {
|
|
72
|
+
return '';
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
76
|
+
*/
|
|
77
|
+
toU8a(_isBare) {
|
|
78
|
+
return new Uint8Array();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
exports.Null = Null;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import type { HexString } from '@pezkuwi/util/types';
|
|
2
|
+
import type { AnyJson, Codec, CodecClass, DefinitionSetter, Inspect, IOption, IU8a, Registry } from '../types/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name Option
|
|
5
|
+
* @description
|
|
6
|
+
* An Option is an optional field. Basically the first byte indicates that there is
|
|
7
|
+
* is value to follow. If the byte is `1` there is an actual value. So the Option
|
|
8
|
+
* implements that - decodes, checks for optionality and wraps the required structure
|
|
9
|
+
* with a value if/as required/found.
|
|
10
|
+
*/
|
|
11
|
+
export declare class Option<T extends Codec> implements IOption<T> {
|
|
12
|
+
#private;
|
|
13
|
+
readonly registry: Registry;
|
|
14
|
+
createdAtHash?: IU8a;
|
|
15
|
+
initialU8aLength?: number;
|
|
16
|
+
isStorageFallback?: boolean;
|
|
17
|
+
constructor(registry: Registry, typeName: CodecClass<T> | string, value?: unknown, { definition, setDefinition }?: DefinitionSetter<CodecClass<T>>);
|
|
18
|
+
static with<O extends Codec>(Type: CodecClass<O> | string): CodecClass<Option<O>>;
|
|
19
|
+
/**
|
|
20
|
+
* @description The length of the value when encoded as a Uint8Array
|
|
21
|
+
*/
|
|
22
|
+
get encodedLength(): number;
|
|
23
|
+
/**
|
|
24
|
+
* @description returns a hash of the contents
|
|
25
|
+
*/
|
|
26
|
+
get hash(): IU8a;
|
|
27
|
+
/**
|
|
28
|
+
* @description Checks if the Option has no value
|
|
29
|
+
*/
|
|
30
|
+
get isEmpty(): boolean;
|
|
31
|
+
/**
|
|
32
|
+
* @description Checks if the Option has no value
|
|
33
|
+
*/
|
|
34
|
+
get isNone(): boolean;
|
|
35
|
+
/**
|
|
36
|
+
* @description Checks if the Option has a value
|
|
37
|
+
*/
|
|
38
|
+
get isSome(): boolean;
|
|
39
|
+
/**
|
|
40
|
+
* @description The actual value for the Option
|
|
41
|
+
*/
|
|
42
|
+
get value(): T;
|
|
43
|
+
/**
|
|
44
|
+
* @description Compares the value of the input to see if there is a match
|
|
45
|
+
*/
|
|
46
|
+
eq(other?: unknown): boolean;
|
|
47
|
+
/**
|
|
48
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
49
|
+
*/
|
|
50
|
+
inspect(): Inspect;
|
|
51
|
+
/**
|
|
52
|
+
* @description Returns a hex string representation of the value
|
|
53
|
+
*/
|
|
54
|
+
toHex(): HexString;
|
|
55
|
+
/**
|
|
56
|
+
* @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
57
|
+
*/
|
|
58
|
+
toHuman(isExtended?: boolean, disableAscii?: boolean): AnyJson;
|
|
59
|
+
/**
|
|
60
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
61
|
+
*/
|
|
62
|
+
toJSON(): AnyJson;
|
|
63
|
+
/**
|
|
64
|
+
* @description Converts the value in a best-fit primitive form
|
|
65
|
+
*/
|
|
66
|
+
toPrimitive(disableAscii?: boolean): AnyJson;
|
|
67
|
+
/**
|
|
68
|
+
* @description Returns the base runtime type name for this instance
|
|
69
|
+
*/
|
|
70
|
+
toRawType(isBare?: boolean): string;
|
|
71
|
+
/**
|
|
72
|
+
* @description Returns the string representation of the value
|
|
73
|
+
*/
|
|
74
|
+
toString(): string;
|
|
75
|
+
/**
|
|
76
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
77
|
+
* @param isBare true when the value has none of the type-specific prefixes (internal)
|
|
78
|
+
*/
|
|
79
|
+
toU8a(isBare?: boolean): Uint8Array;
|
|
80
|
+
/**
|
|
81
|
+
* @description Returns the value that the Option represents (if available), throws if null
|
|
82
|
+
*/
|
|
83
|
+
unwrap(): T;
|
|
84
|
+
/**
|
|
85
|
+
* @description Returns the value that the Option represents (if available) or defaultValue if none
|
|
86
|
+
* @param defaultValue The value to return if the option isNone
|
|
87
|
+
*/
|
|
88
|
+
unwrapOr<O>(defaultValue: O): T | O;
|
|
89
|
+
/**
|
|
90
|
+
* @description Returns the value that the Option represents (if available) or defaultValue if none
|
|
91
|
+
* @param defaultValue The value to return if the option isNone
|
|
92
|
+
*/
|
|
93
|
+
unwrapOrDefault(): T;
|
|
94
|
+
}
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Option = void 0;
|
|
4
|
+
const util_1 = require("@pezkuwi/util");
|
|
5
|
+
const index_js_1 = require("../utils/index.js");
|
|
6
|
+
const Null_js_1 = require("./Null.js");
|
|
7
|
+
class None extends Null_js_1.Null {
|
|
8
|
+
/**
|
|
9
|
+
* @description Returns the base runtime type name for this instance
|
|
10
|
+
*/
|
|
11
|
+
toRawType() {
|
|
12
|
+
return 'None';
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
/** @internal */
|
|
16
|
+
function decodeOption(registry, Type, value) {
|
|
17
|
+
if (value instanceof Type) {
|
|
18
|
+
// don't re-create, use as it (which also caters for derived types)
|
|
19
|
+
return value;
|
|
20
|
+
}
|
|
21
|
+
else if (value instanceof Option) {
|
|
22
|
+
if (value.value instanceof Type) {
|
|
23
|
+
// same instance, return it
|
|
24
|
+
return value.value;
|
|
25
|
+
}
|
|
26
|
+
else if (value.isNone) {
|
|
27
|
+
// internal is None, we are also none
|
|
28
|
+
return new None(registry);
|
|
29
|
+
}
|
|
30
|
+
// convert the actual value into known
|
|
31
|
+
return new Type(registry, value.value);
|
|
32
|
+
}
|
|
33
|
+
else if ((0, util_1.isNull)(value) || (0, util_1.isUndefined)(value) || value === '0x' || value instanceof None) {
|
|
34
|
+
// anything empty we pass as-is
|
|
35
|
+
return new None(registry);
|
|
36
|
+
}
|
|
37
|
+
else if ((0, util_1.isU8a)(value)) {
|
|
38
|
+
// the isU8a check happens last in the if-tree - since the wrapped value
|
|
39
|
+
// may be an instance of it, so Type and Option checks go in first
|
|
40
|
+
return !value.length || value[0] === 0
|
|
41
|
+
? new None(registry)
|
|
42
|
+
: new Type(registry, value.subarray(1));
|
|
43
|
+
}
|
|
44
|
+
return new Type(registry, value);
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* @name Option
|
|
48
|
+
* @description
|
|
49
|
+
* An Option is an optional field. Basically the first byte indicates that there is
|
|
50
|
+
* is value to follow. If the byte is `1` there is an actual value. So the Option
|
|
51
|
+
* implements that - decodes, checks for optionality and wraps the required structure
|
|
52
|
+
* with a value if/as required/found.
|
|
53
|
+
*/
|
|
54
|
+
class Option {
|
|
55
|
+
registry;
|
|
56
|
+
createdAtHash;
|
|
57
|
+
initialU8aLength;
|
|
58
|
+
isStorageFallback;
|
|
59
|
+
#Type;
|
|
60
|
+
#raw;
|
|
61
|
+
constructor(registry, typeName, value, { definition, setDefinition = util_1.identity } = {}) {
|
|
62
|
+
const Type = definition || setDefinition((0, index_js_1.typeToConstructor)(registry, typeName));
|
|
63
|
+
const decoded = (0, util_1.isU8a)(value) && value.length && !(0, util_1.isCodec)(value)
|
|
64
|
+
? value[0] === 0
|
|
65
|
+
? new None(registry)
|
|
66
|
+
: new Type(registry, value.subarray(1))
|
|
67
|
+
: decodeOption(registry, Type, value);
|
|
68
|
+
this.registry = registry;
|
|
69
|
+
this.#Type = Type;
|
|
70
|
+
this.#raw = decoded;
|
|
71
|
+
if (decoded?.initialU8aLength) {
|
|
72
|
+
this.initialU8aLength = 1 + decoded.initialU8aLength;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
static with(Type) {
|
|
76
|
+
let definition;
|
|
77
|
+
const setDefinition = (d) => {
|
|
78
|
+
definition = d;
|
|
79
|
+
return d;
|
|
80
|
+
};
|
|
81
|
+
return class extends Option {
|
|
82
|
+
constructor(registry, value) {
|
|
83
|
+
super(registry, Type, value, { definition, setDefinition });
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* @description The length of the value when encoded as a Uint8Array
|
|
89
|
+
*/
|
|
90
|
+
get encodedLength() {
|
|
91
|
+
// boolean byte (has value, doesn't have) along with wrapped length
|
|
92
|
+
return 1 + this.#raw.encodedLength;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* @description returns a hash of the contents
|
|
96
|
+
*/
|
|
97
|
+
get hash() {
|
|
98
|
+
return this.registry.hash(this.toU8a());
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* @description Checks if the Option has no value
|
|
102
|
+
*/
|
|
103
|
+
get isEmpty() {
|
|
104
|
+
return this.isNone;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* @description Checks if the Option has no value
|
|
108
|
+
*/
|
|
109
|
+
get isNone() {
|
|
110
|
+
return this.#raw instanceof None;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* @description Checks if the Option has a value
|
|
114
|
+
*/
|
|
115
|
+
get isSome() {
|
|
116
|
+
return !this.isNone;
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* @description The actual value for the Option
|
|
120
|
+
*/
|
|
121
|
+
get value() {
|
|
122
|
+
return this.#raw;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* @description Compares the value of the input to see if there is a match
|
|
126
|
+
*/
|
|
127
|
+
eq(other) {
|
|
128
|
+
if (other instanceof Option) {
|
|
129
|
+
return (this.isSome === other.isSome) && this.value.eq(other.value);
|
|
130
|
+
}
|
|
131
|
+
return this.value.eq(other);
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
135
|
+
*/
|
|
136
|
+
inspect() {
|
|
137
|
+
if (this.isNone) {
|
|
138
|
+
return { outer: [new Uint8Array([0])] };
|
|
139
|
+
}
|
|
140
|
+
const { inner, outer = [] } = this.#raw.inspect();
|
|
141
|
+
return {
|
|
142
|
+
inner,
|
|
143
|
+
outer: [new Uint8Array([1]), ...outer]
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* @description Returns a hex string representation of the value
|
|
148
|
+
*/
|
|
149
|
+
toHex() {
|
|
150
|
+
// This attempts to align with the JSON encoding - actually in this case
|
|
151
|
+
// the isSome value is correct, however the `isNone` may be problematic
|
|
152
|
+
return this.isNone
|
|
153
|
+
? '0x'
|
|
154
|
+
: (0, util_1.u8aToHex)(this.toU8a().subarray(1));
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
158
|
+
*/
|
|
159
|
+
toHuman(isExtended, disableAscii) {
|
|
160
|
+
return this.#raw.toHuman(isExtended, disableAscii);
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
164
|
+
*/
|
|
165
|
+
toJSON() {
|
|
166
|
+
return this.isNone
|
|
167
|
+
? null
|
|
168
|
+
: this.#raw.toJSON();
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* @description Converts the value in a best-fit primitive form
|
|
172
|
+
*/
|
|
173
|
+
toPrimitive(disableAscii) {
|
|
174
|
+
return this.isNone
|
|
175
|
+
? null
|
|
176
|
+
: this.#raw.toPrimitive(disableAscii);
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* @description Returns the base runtime type name for this instance
|
|
180
|
+
*/
|
|
181
|
+
toRawType(isBare) {
|
|
182
|
+
const wrapped = this.registry.getClassName(this.#Type) || new this.#Type(this.registry).toRawType();
|
|
183
|
+
return isBare
|
|
184
|
+
? wrapped
|
|
185
|
+
: `Option<${wrapped}>`;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* @description Returns the string representation of the value
|
|
189
|
+
*/
|
|
190
|
+
toString() {
|
|
191
|
+
return this.#raw.toString();
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
195
|
+
* @param isBare true when the value has none of the type-specific prefixes (internal)
|
|
196
|
+
*/
|
|
197
|
+
toU8a(isBare) {
|
|
198
|
+
if (isBare) {
|
|
199
|
+
return this.#raw.toU8a(true);
|
|
200
|
+
}
|
|
201
|
+
const u8a = new Uint8Array(this.encodedLength);
|
|
202
|
+
if (this.isSome) {
|
|
203
|
+
u8a.set([1]);
|
|
204
|
+
u8a.set(this.#raw.toU8a(), 1);
|
|
205
|
+
}
|
|
206
|
+
return u8a;
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* @description Returns the value that the Option represents (if available), throws if null
|
|
210
|
+
*/
|
|
211
|
+
unwrap() {
|
|
212
|
+
if (this.isNone) {
|
|
213
|
+
throw new Error('Option: unwrapping a None value');
|
|
214
|
+
}
|
|
215
|
+
return this.#raw;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* @description Returns the value that the Option represents (if available) or defaultValue if none
|
|
219
|
+
* @param defaultValue The value to return if the option isNone
|
|
220
|
+
*/
|
|
221
|
+
unwrapOr(defaultValue) {
|
|
222
|
+
return this.isSome
|
|
223
|
+
? this.unwrap()
|
|
224
|
+
: defaultValue;
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* @description Returns the value that the Option represents (if available) or defaultValue if none
|
|
228
|
+
* @param defaultValue The value to return if the option isNone
|
|
229
|
+
*/
|
|
230
|
+
unwrapOrDefault() {
|
|
231
|
+
return this.isSome
|
|
232
|
+
? this.unwrap()
|
|
233
|
+
: new this.#Type(this.registry);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
exports.Option = Option;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { Codec, CodecClass, IResult, Registry } from '../types/index.js';
|
|
2
|
+
import { Enum } from './Enum.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name Result
|
|
5
|
+
* @description
|
|
6
|
+
* A Result maps to the Rust Result type, that can either wrap a success or error value
|
|
7
|
+
*/
|
|
8
|
+
export declare class Result<O extends Codec, E extends Codec> extends Enum implements IResult<O, E> {
|
|
9
|
+
constructor(registry: Registry, Ok: CodecClass<O> | string, Err: CodecClass<E> | string, value?: unknown);
|
|
10
|
+
static with<O extends Codec, E extends Codec>(Types: {
|
|
11
|
+
Ok: CodecClass<O> | string;
|
|
12
|
+
Err: CodecClass<E> | string;
|
|
13
|
+
}): CodecClass<Result<O, E>>;
|
|
14
|
+
/**
|
|
15
|
+
* @description Returns the wrapper Err value (if isErr)
|
|
16
|
+
*/
|
|
17
|
+
get asErr(): E;
|
|
18
|
+
/**
|
|
19
|
+
* @description Returns the wrapper Ok value (if isOk)
|
|
20
|
+
*/
|
|
21
|
+
get asOk(): O;
|
|
22
|
+
/**
|
|
23
|
+
* @description Checks if the Result has no value
|
|
24
|
+
*/
|
|
25
|
+
get isEmpty(): boolean;
|
|
26
|
+
/**
|
|
27
|
+
* @description Checks if the Result wraps an Err value
|
|
28
|
+
*/
|
|
29
|
+
get isErr(): boolean;
|
|
30
|
+
/**
|
|
31
|
+
* @description Checks if the Result wraps an Ok value
|
|
32
|
+
*/
|
|
33
|
+
get isOk(): boolean;
|
|
34
|
+
/**
|
|
35
|
+
* @description Returns the base runtime type name for this instance
|
|
36
|
+
*/
|
|
37
|
+
toRawType(): string;
|
|
38
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Result = void 0;
|
|
4
|
+
const Enum_js_1 = require("./Enum.js");
|
|
5
|
+
/**
|
|
6
|
+
* @name Result
|
|
7
|
+
* @description
|
|
8
|
+
* A Result maps to the Rust Result type, that can either wrap a success or error value
|
|
9
|
+
*/
|
|
10
|
+
class Result extends Enum_js_1.Enum {
|
|
11
|
+
constructor(registry, Ok, Err, value) {
|
|
12
|
+
// NOTE This is order-dependent, Ok (with index 0) needs to be first
|
|
13
|
+
// eslint-disable-next-line sort-keys
|
|
14
|
+
super(registry, { Ok, Err }, value);
|
|
15
|
+
}
|
|
16
|
+
static with(Types) {
|
|
17
|
+
return class extends Result {
|
|
18
|
+
constructor(registry, value) {
|
|
19
|
+
super(registry, Types.Ok, Types.Err, value);
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* @description Returns the wrapper Err value (if isErr)
|
|
25
|
+
*/
|
|
26
|
+
get asErr() {
|
|
27
|
+
if (!this.isErr) {
|
|
28
|
+
throw new Error('Cannot extract Err value from Ok result, check isErr first');
|
|
29
|
+
}
|
|
30
|
+
return this.value;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* @description Returns the wrapper Ok value (if isOk)
|
|
34
|
+
*/
|
|
35
|
+
get asOk() {
|
|
36
|
+
if (!this.isOk) {
|
|
37
|
+
throw new Error('Cannot extract Ok value from Err result, check isOk first');
|
|
38
|
+
}
|
|
39
|
+
return this.value;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* @description Checks if the Result has no value
|
|
43
|
+
*/
|
|
44
|
+
get isEmpty() {
|
|
45
|
+
return this.isOk && this.value.isEmpty;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* @description Checks if the Result wraps an Err value
|
|
49
|
+
*/
|
|
50
|
+
get isErr() {
|
|
51
|
+
return !this.isOk;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* @description Checks if the Result wraps an Ok value
|
|
55
|
+
*/
|
|
56
|
+
get isOk() {
|
|
57
|
+
return this.index === 0;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* @description Returns the base runtime type name for this instance
|
|
61
|
+
*/
|
|
62
|
+
toRawType() {
|
|
63
|
+
const Types = this._toRawStruct();
|
|
64
|
+
return `Result<${Types.Ok},${Types.Err}>`;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.Result = Result;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { AnyTupleValue, Codec, CodecClass, DefinitionSetter, Inspect, ITuple, Registry } from '../types/index.js';
|
|
2
|
+
import { AbstractArray } from '../abstract/Array.js';
|
|
3
|
+
type TupleType = (CodecClass | string);
|
|
4
|
+
type TupleTypes = TupleType[] | Record<string, CodecClass | string>;
|
|
5
|
+
type Definition = [CodecClass[], string[]];
|
|
6
|
+
/**
|
|
7
|
+
* @name Tuple
|
|
8
|
+
* @description
|
|
9
|
+
* A Tuple defines an anonymous fixed-length array, where each element has its
|
|
10
|
+
* own type. It extends the base JS `Array` object.
|
|
11
|
+
*/
|
|
12
|
+
export declare class Tuple extends AbstractArray<Codec> implements ITuple<Codec[]> {
|
|
13
|
+
#private;
|
|
14
|
+
constructor(registry: Registry, Types: TupleTypes | TupleType, value?: AnyTupleValue, { definition, setDefinition }?: DefinitionSetter<Definition>);
|
|
15
|
+
static with(Types: TupleTypes | TupleType): CodecClass<Tuple>;
|
|
16
|
+
/**
|
|
17
|
+
* @description The length of the value when encoded as a Uint8Array
|
|
18
|
+
*/
|
|
19
|
+
get encodedLength(): number;
|
|
20
|
+
/**
|
|
21
|
+
* @description The types definition of the tuple
|
|
22
|
+
*/
|
|
23
|
+
get Types(): string[];
|
|
24
|
+
/**
|
|
25
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
26
|
+
*/
|
|
27
|
+
inspect(): Inspect;
|
|
28
|
+
/**
|
|
29
|
+
* @description Returns the base runtime type name for this instance
|
|
30
|
+
*/
|
|
31
|
+
toRawType(): string;
|
|
32
|
+
/**
|
|
33
|
+
* @description Returns the string representation of the value
|
|
34
|
+
*/
|
|
35
|
+
toString(): string;
|
|
36
|
+
/**
|
|
37
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
38
|
+
* @param isBare true when the value has none of the type-specific prefixes (internal)
|
|
39
|
+
*/
|
|
40
|
+
toU8a(isBare?: boolean): Uint8Array;
|
|
41
|
+
}
|
|
42
|
+
export {};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Tuple = void 0;
|
|
4
|
+
const util_1 = require("@pezkuwi/util");
|
|
5
|
+
const Array_js_1 = require("../abstract/Array.js");
|
|
6
|
+
const index_js_1 = require("../utils/index.js");
|
|
7
|
+
/** @internal */
|
|
8
|
+
function decodeTuple(registry, result, value, Classes) {
|
|
9
|
+
if (Array.isArray(value)) {
|
|
10
|
+
const Types = Classes[0];
|
|
11
|
+
for (let i = 0, count = Types.length; i < count; i++) {
|
|
12
|
+
try {
|
|
13
|
+
const entry = value?.[i];
|
|
14
|
+
result[i] = entry instanceof Types[i]
|
|
15
|
+
? entry
|
|
16
|
+
: new Types[i](registry, entry);
|
|
17
|
+
}
|
|
18
|
+
catch (error) {
|
|
19
|
+
throw new Error(`Tuple: failed on ${i}:: ${error.message}`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return [result, 0];
|
|
23
|
+
}
|
|
24
|
+
else if ((0, util_1.isHex)(value)) {
|
|
25
|
+
return (0, index_js_1.decodeU8a)(registry, result, (0, util_1.u8aToU8a)(value), Classes);
|
|
26
|
+
}
|
|
27
|
+
else if (!value || !result.length) {
|
|
28
|
+
const Types = Classes[0];
|
|
29
|
+
for (let i = 0, count = Types.length; i < count; i++) {
|
|
30
|
+
result[i] = new Types[i](registry);
|
|
31
|
+
}
|
|
32
|
+
return [result, 0];
|
|
33
|
+
}
|
|
34
|
+
throw new Error(`Expected array input to Tuple decoding, found ${typeof value}: ${(0, util_1.stringify)(value)}`);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* @name Tuple
|
|
38
|
+
* @description
|
|
39
|
+
* A Tuple defines an anonymous fixed-length array, where each element has its
|
|
40
|
+
* own type. It extends the base JS `Array` object.
|
|
41
|
+
*/
|
|
42
|
+
class Tuple extends Array_js_1.AbstractArray {
|
|
43
|
+
#Types;
|
|
44
|
+
constructor(registry, Types, value, { definition, setDefinition = util_1.identity } = {}) {
|
|
45
|
+
const Classes = definition || setDefinition(Array.isArray(Types)
|
|
46
|
+
? [(0, index_js_1.typesToConstructors)(registry, Types), []]
|
|
47
|
+
: (0, util_1.isFunction)(Types) || (0, util_1.isString)(Types)
|
|
48
|
+
? [[(0, index_js_1.typeToConstructor)(registry, Types)], []]
|
|
49
|
+
: (0, index_js_1.mapToTypeMap)(registry, Types));
|
|
50
|
+
super(registry, Classes[0].length);
|
|
51
|
+
this.initialU8aLength = ((0, util_1.isU8a)(value)
|
|
52
|
+
? (0, index_js_1.decodeU8a)(registry, this, value, Classes)
|
|
53
|
+
: decodeTuple(registry, this, value, Classes))[1];
|
|
54
|
+
this.#Types = Classes;
|
|
55
|
+
}
|
|
56
|
+
static with(Types) {
|
|
57
|
+
let definition;
|
|
58
|
+
// eslint-disable-next-line no-return-assign
|
|
59
|
+
const setDefinition = (d) => definition = d;
|
|
60
|
+
return class extends Tuple {
|
|
61
|
+
constructor(registry, value) {
|
|
62
|
+
super(registry, Types, value, { definition, setDefinition });
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* @description The length of the value when encoded as a Uint8Array
|
|
68
|
+
*/
|
|
69
|
+
get encodedLength() {
|
|
70
|
+
let total = 0;
|
|
71
|
+
for (let i = 0, count = this.length; i < count; i++) {
|
|
72
|
+
total += this[i].encodedLength;
|
|
73
|
+
}
|
|
74
|
+
return total;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* @description The types definition of the tuple
|
|
78
|
+
*/
|
|
79
|
+
get Types() {
|
|
80
|
+
return this.#Types[1].length
|
|
81
|
+
? this.#Types[1]
|
|
82
|
+
: this.#Types[0].map((T) => new T(this.registry).toRawType());
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
86
|
+
*/
|
|
87
|
+
inspect() {
|
|
88
|
+
return {
|
|
89
|
+
inner: this.inspectInner()
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* @description Returns the base runtime type name for this instance
|
|
94
|
+
*/
|
|
95
|
+
toRawType() {
|
|
96
|
+
const types = this.#Types[0].map((T) => this.registry.getClassName(T) || new T(this.registry).toRawType());
|
|
97
|
+
return `(${types.join(',')})`;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* @description Returns the string representation of the value
|
|
101
|
+
*/
|
|
102
|
+
toString() {
|
|
103
|
+
// Overwrite the default toString representation of Array.
|
|
104
|
+
return (0, util_1.stringify)(this.toJSON());
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
108
|
+
* @param isBare true when the value has none of the type-specific prefixes (internal)
|
|
109
|
+
*/
|
|
110
|
+
toU8a(isBare) {
|
|
111
|
+
return (0, util_1.u8aConcatStrict)(this.toU8aInner(isBare));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
exports.Tuple = Tuple;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { CodecClass, UIntBitLength } from '../types/index.js';
|
|
2
|
+
import { AbstractInt } from '../abstract/Int.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name UInt
|
|
5
|
+
* @description
|
|
6
|
+
* A generic unsigned integer codec. For Bizinikiwi all numbers are Little Endian encoded,
|
|
7
|
+
* this handles the encoding and decoding of those numbers. Upon construction
|
|
8
|
+
* the bitLength is provided and any additional use keeps the number to this
|
|
9
|
+
* length. This extends `BN`, so all methods available on a normal `BN` object
|
|
10
|
+
* is available here.
|
|
11
|
+
* @noInheritDoc
|
|
12
|
+
*/
|
|
13
|
+
export declare class UInt extends AbstractInt {
|
|
14
|
+
static with(bitLength: UIntBitLength, typeName?: string): CodecClass<UInt>;
|
|
15
|
+
}
|