@pezkuwi/types-codec 16.5.5
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/README.md +3 -0
- package/build/abstract/Array.d.ts +89 -0
- package/build/abstract/Base.d.ts +75 -0
- package/build/abstract/Int.d.ts +80 -0
- package/build/abstract/Object.d.ts +67 -0
- package/build/abstract/index.d.ts +3 -0
- package/build/base/Compact.d.ts +88 -0
- package/build/base/DoNotConstruct.d.ts +63 -0
- package/build/base/Enum.d.ts +118 -0
- package/build/base/Int.d.ts +16 -0
- package/build/base/Null.d.ts +56 -0
- package/build/base/Option.d.ts +94 -0
- package/build/base/Result.d.ts +38 -0
- package/build/base/Tuple.d.ts +42 -0
- package/build/base/UInt.d.ts +15 -0
- package/build/base/Vec.d.ts +28 -0
- package/build/base/VecAny.d.ts +15 -0
- package/build/base/VecFixed.d.ts +30 -0
- package/build/base/index.d.ts +12 -0
- package/build/bundle.d.ts +7 -0
- package/build/extended/BTreeMap.d.ts +5 -0
- package/build/extended/BTreeSet.d.ts +64 -0
- package/build/extended/BitVec.d.ts +37 -0
- package/build/extended/Bytes.d.ts +29 -0
- package/build/extended/HashMap.d.ts +5 -0
- package/build/extended/Linkage.d.ts +37 -0
- package/build/extended/Map.d.ts +59 -0
- package/build/extended/OptionBool.d.ts +36 -0
- package/build/extended/Range.d.ts +29 -0
- package/build/extended/RangeInclusive.d.ts +6 -0
- package/build/extended/Type.d.ts +16 -0
- package/build/extended/U8aFixed.d.ts +16 -0
- package/build/extended/WrapperKeepOpaque.d.ts +40 -0
- package/build/extended/WrapperOpaque.d.ts +10 -0
- package/build/extended/index.d.ts +14 -0
- package/build/index.d.ts +2 -0
- package/build/native/Bool.d.ts +71 -0
- package/build/native/Date.d.ts +84 -0
- package/build/native/Float.d.ts +68 -0
- package/build/native/Json.d.ts +69 -0
- package/build/native/Raw.d.ts +87 -0
- package/build/native/Set.d.ts +84 -0
- package/build/native/Struct.d.ts +106 -0
- package/build/native/Text.d.ts +77 -0
- package/build/native/index.d.ts +8 -0
- package/build/packageDetect.d.ts +1 -0
- package/build/packageInfo.d.ts +6 -0
- package/build/primitive/F32.d.ts +11 -0
- package/build/primitive/F64.d.ts +11 -0
- package/build/primitive/I128.d.ts +11 -0
- package/build/primitive/I16.d.ts +11 -0
- package/build/primitive/I256.d.ts +11 -0
- package/build/primitive/I32.d.ts +11 -0
- package/build/primitive/I64.d.ts +11 -0
- package/build/primitive/I8.d.ts +11 -0
- package/build/primitive/ISize.d.ts +12 -0
- package/build/primitive/U128.d.ts +11 -0
- package/build/primitive/U16.d.ts +11 -0
- package/build/primitive/U256.d.ts +11 -0
- package/build/primitive/U32.d.ts +11 -0
- package/build/primitive/U64.d.ts +11 -0
- package/build/primitive/U8.d.ts +11 -0
- package/build/primitive/USize.d.ts +12 -0
- package/build/primitive/index.d.ts +16 -0
- package/build/types/codec.d.ts +113 -0
- package/build/types/helpers.d.ts +27 -0
- package/build/types/index.d.ts +4 -0
- package/build/types/interfaces.d.ts +74 -0
- package/build/types/registry.d.ts +67 -0
- package/build/utils/compareArray.d.ts +1 -0
- package/build/utils/compareMap.d.ts +1 -0
- package/build/utils/compareSet.d.ts +1 -0
- package/build/utils/decodeU8a.d.ts +26 -0
- package/build/utils/index.d.ts +8 -0
- package/build/utils/sanitize.d.ts +15 -0
- package/build/utils/sortValues.d.ts +12 -0
- package/build/utils/toConstructors.d.ts +16 -0
- package/build/utils/typesToMap.d.ts +2 -0
- package/build/utils/util.d.ts +3 -0
- package/package.json +34 -0
- package/src/abstract/Array.ts +213 -0
- package/src/abstract/Base.ts +129 -0
- package/src/abstract/Int.ts +271 -0
- package/src/abstract/Object.ts +99 -0
- package/src/abstract/index.ts +6 -0
- package/src/base/Compact.spec.ts +99 -0
- package/src/base/Compact.ts +198 -0
- package/src/base/DoNotConstruct.spec.ts +23 -0
- package/src/base/DoNotConstruct.ts +118 -0
- package/src/base/Enum.spec.ts +487 -0
- package/src/base/Enum.ts +460 -0
- package/src/base/Int.spec.ts +225 -0
- package/src/base/Int.ts +34 -0
- package/src/base/Null.spec.ts +41 -0
- package/src/base/Null.ts +96 -0
- package/src/base/Option.spec.ts +216 -0
- package/src/base/Option.ts +275 -0
- package/src/base/Result.spec.ts +64 -0
- package/src/base/Result.ts +79 -0
- package/src/base/Tuple.spec.ts +161 -0
- package/src/base/Tuple.ts +149 -0
- package/src/base/UInt.spec.ts +192 -0
- package/src/base/UInt.ts +30 -0
- package/src/base/Vec.spec.ts +224 -0
- package/src/base/Vec.ts +133 -0
- package/src/base/VecAny.ts +23 -0
- package/src/base/VecFixed.spec.ts +78 -0
- package/src/base/VecFixed.ts +92 -0
- package/src/base/index.ts +15 -0
- package/src/bundle.ts +13 -0
- package/src/checkTypes.manual.ts +12 -0
- package/src/extended/BTreeMap.spec.ts +245 -0
- package/src/extended/BTreeMap.ts +16 -0
- package/src/extended/BTreeSet.spec.ts +260 -0
- package/src/extended/BTreeSet.ts +233 -0
- package/src/extended/BitVec.spec.ts +97 -0
- package/src/extended/BitVec.ts +137 -0
- package/src/extended/Bytes.spec.ts +75 -0
- package/src/extended/Bytes.ts +88 -0
- package/src/extended/HashMap.spec.ts +36 -0
- package/src/extended/HashMap.ts +16 -0
- package/src/extended/Linkage.spec.ts +43 -0
- package/src/extended/Linkage.ts +81 -0
- package/src/extended/Map.spec.ts +123 -0
- package/src/extended/Map.ts +255 -0
- package/src/extended/OptionBool.spec.ts +49 -0
- package/src/extended/OptionBool.ts +93 -0
- package/src/extended/Range.spec.ts +37 -0
- package/src/extended/Range.ts +56 -0
- package/src/extended/RangeInclusive.ts +20 -0
- package/src/extended/Type.spec.ts +118 -0
- package/src/extended/Type.ts +29 -0
- package/src/extended/U8aFixed.spec.ts +117 -0
- package/src/extended/U8aFixed.ts +57 -0
- package/src/extended/WrapperKeepOpaque.spec.ts +101 -0
- package/src/extended/WrapperKeepOpaque.ts +128 -0
- package/src/extended/WrapperOpaque.spec.ts +58 -0
- package/src/extended/WrapperOpaque.ts +27 -0
- package/src/extended/index.ts +17 -0
- package/src/index.ts +6 -0
- package/src/mod.ts +4 -0
- package/src/native/Bool.spec.ts +74 -0
- package/src/native/Bool.ts +137 -0
- package/src/native/Date.spec.ts +85 -0
- package/src/native/Date.ts +169 -0
- package/src/native/Float.spec.ts +51 -0
- package/src/native/Float.ts +136 -0
- package/src/native/Json.ts +147 -0
- package/src/native/Raw.spec.ts +113 -0
- package/src/native/Raw.ts +171 -0
- package/src/native/Set.spec.ts +116 -0
- package/src/native/Set.ts +269 -0
- package/src/native/Struct.data.ts +4 -0
- package/src/native/Struct.spec.ts +411 -0
- package/src/native/Struct.ts +338 -0
- package/src/native/Text.spec.ts +85 -0
- package/src/native/Text.ts +184 -0
- package/src/native/index.ts +11 -0
- package/src/packageDetect.ts +11 -0
- package/src/packageInfo.ts +6 -0
- package/src/primitive/F32.ts +14 -0
- package/src/primitive/F64.ts +14 -0
- package/src/primitive/I128.ts +14 -0
- package/src/primitive/I16.ts +14 -0
- package/src/primitive/I256.ts +14 -0
- package/src/primitive/I32.ts +14 -0
- package/src/primitive/I64.ts +14 -0
- package/src/primitive/I8.ts +14 -0
- package/src/primitive/ISize.ts +21 -0
- package/src/primitive/U128.ts +14 -0
- package/src/primitive/U16.ts +14 -0
- package/src/primitive/U256.ts +14 -0
- package/src/primitive/U32.ts +14 -0
- package/src/primitive/U64.ts +14 -0
- package/src/primitive/U8.ts +14 -0
- package/src/primitive/USize.ts +21 -0
- package/src/primitive/index.ts +19 -0
- package/src/test/performance.ts +61 -0
- package/src/types/codec.ts +140 -0
- package/src/types/helpers.ts +50 -0
- package/src/types/index.ts +7 -0
- package/src/types/interfaces.ts +98 -0
- package/src/types/registry.ts +86 -0
- package/src/utils/compareArray.ts +22 -0
- package/src/utils/compareMap.ts +40 -0
- package/src/utils/compareSet.ts +23 -0
- package/src/utils/decodeU8a.ts +123 -0
- package/src/utils/index.ts +11 -0
- package/src/utils/sanitize.spec.ts +89 -0
- package/src/utils/sanitize.ts +290 -0
- package/src/utils/sortValues.ts +103 -0
- package/src/utils/toConstructors.ts +46 -0
- package/src/utils/typesToMap.ts +14 -0
- package/src/utils/util.ts +8 -0
- package/tsconfig.build.json +16 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.spec.json +21 -0
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
// Copyright 2017-2025 @polkadot/types-codec authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HexString } from '@pezkuwi/util/types';
|
|
5
|
+
import type { AnyFloat, CodecClass, IFloat, Inspect, IU8a, Registry } from '../types/index.js';
|
|
6
|
+
|
|
7
|
+
import { floatToU8a, isHex, isU8a, u8aToFloat, u8aToHex, u8aToU8a } from '@pezkuwi/util';
|
|
8
|
+
|
|
9
|
+
interface Options {
|
|
10
|
+
bitLength?: 32 | 64;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* @name Float
|
|
15
|
+
* @description
|
|
16
|
+
* A Codec wrapper for F32 & F64 values. You generally don't want to be using
|
|
17
|
+
* f32/f64 in your runtime, operations on fixed points numbers are preferable. This class
|
|
18
|
+
* was explicitly added since scale-codec has a flag that enables this and it is available
|
|
19
|
+
* in some eth_* RPCs
|
|
20
|
+
*/
|
|
21
|
+
export class Float extends Number implements IFloat {
|
|
22
|
+
readonly encodedLength: number;
|
|
23
|
+
readonly registry: Registry;
|
|
24
|
+
|
|
25
|
+
public createdAtHash?: IU8a;
|
|
26
|
+
public initialU8aLength?: number;
|
|
27
|
+
public isStorageFallback?: boolean;
|
|
28
|
+
|
|
29
|
+
readonly #bitLength: 32 | 64;
|
|
30
|
+
|
|
31
|
+
constructor (registry: Registry, value?: AnyFloat, { bitLength = 32 }: Options = {}) {
|
|
32
|
+
super(
|
|
33
|
+
isU8a(value) || isHex(value)
|
|
34
|
+
? value.length === 0
|
|
35
|
+
? 0
|
|
36
|
+
: u8aToFloat(u8aToU8a(value), { bitLength })
|
|
37
|
+
: (value || 0)
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
this.#bitLength = bitLength;
|
|
41
|
+
this.encodedLength = bitLength / 8;
|
|
42
|
+
this.initialU8aLength = this.encodedLength;
|
|
43
|
+
this.registry = registry;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
public static with (bitLength: 32 | 64): CodecClass<Float> {
|
|
47
|
+
return class extends Float {
|
|
48
|
+
constructor (registry: Registry, value?: AnyFloat) {
|
|
49
|
+
super(registry, value, { bitLength });
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* @description returns a hash of the contents
|
|
56
|
+
*/
|
|
57
|
+
public get hash (): IU8a {
|
|
58
|
+
return this.registry.hash(this.toU8a());
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* @description Returns true if the type wraps an empty/default all-0 value
|
|
63
|
+
*/
|
|
64
|
+
get isEmpty (): boolean {
|
|
65
|
+
return this.valueOf() === 0;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @description Compares the value of the input to see if there is a match
|
|
70
|
+
*/
|
|
71
|
+
public eq (other?: unknown): boolean {
|
|
72
|
+
return this.valueOf() === Number(other);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
77
|
+
*/
|
|
78
|
+
public inspect (): Inspect {
|
|
79
|
+
return {
|
|
80
|
+
outer: [this.toU8a()]
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* @description Returns a hex string representation of the value
|
|
86
|
+
*/
|
|
87
|
+
public toHex (): HexString {
|
|
88
|
+
return u8aToHex(this.toU8a());
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
93
|
+
*/
|
|
94
|
+
public toHuman (): string {
|
|
95
|
+
return this.toString();
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
100
|
+
*/
|
|
101
|
+
public toJSON (): string {
|
|
102
|
+
// Not sure if this is actually a hex or a string value
|
|
103
|
+
// (would need to check against RPCs to see the result here)
|
|
104
|
+
return this.toHex();
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* @description Returns the number representation (Same as valueOf)
|
|
109
|
+
*/
|
|
110
|
+
public toNumber (): number {
|
|
111
|
+
return this.valueOf();
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* @description Converts the value in a best-fit primitive form
|
|
116
|
+
*/
|
|
117
|
+
public toPrimitive (): number {
|
|
118
|
+
return this.toNumber();
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* @description Returns the base runtime type name for this instance
|
|
123
|
+
*/
|
|
124
|
+
public toRawType (): string {
|
|
125
|
+
return `f${this.#bitLength}`;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
130
|
+
*/
|
|
131
|
+
public toU8a (_isBare?: boolean): Uint8Array {
|
|
132
|
+
return floatToU8a(this, {
|
|
133
|
+
bitLength: this.#bitLength
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
// Copyright 2017-2025 @polkadot/types-codec authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HexString } from '@pezkuwi/util/types';
|
|
5
|
+
import type { AnyJson, Codec, Inspect, IU8a, Registry } from '../types/index.js';
|
|
6
|
+
|
|
7
|
+
import { isFunction, objectProperties, stringify } from '@pezkuwi/util';
|
|
8
|
+
|
|
9
|
+
import { compareMap } from '../utils/index.js';
|
|
10
|
+
|
|
11
|
+
/** @internal */
|
|
12
|
+
function decodeJson (value?: Record<string, unknown> | null): [string, any][] {
|
|
13
|
+
return Object.entries(value || {});
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @name Json
|
|
18
|
+
* @description
|
|
19
|
+
* Wraps the a JSON structure retrieve via RPC. It extends the standard JS Map with. While it
|
|
20
|
+
* implements a Codec, it is limited in that it can only be used with input objects via RPC,
|
|
21
|
+
* i.e. no hex decoding. Unlike a struct, this waps a JSON object with unknown keys
|
|
22
|
+
* @noInheritDoc
|
|
23
|
+
*/
|
|
24
|
+
export class Json extends Map<string, any> implements Codec {
|
|
25
|
+
readonly registry: Registry;
|
|
26
|
+
|
|
27
|
+
public createdAtHash?: IU8a;
|
|
28
|
+
public initialU8aLength?: number;
|
|
29
|
+
public isStorageFallback?: boolean;
|
|
30
|
+
|
|
31
|
+
constructor (registry: Registry, value?: Record<string, unknown> | null) {
|
|
32
|
+
const decoded = decodeJson(value);
|
|
33
|
+
|
|
34
|
+
super(decoded);
|
|
35
|
+
|
|
36
|
+
this.registry = registry;
|
|
37
|
+
|
|
38
|
+
objectProperties(this, decoded.map(([k]) => k), (k) => this.get(k));
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* @description Always 0, never encodes as a Uint8Array
|
|
43
|
+
*/
|
|
44
|
+
public get encodedLength (): number {
|
|
45
|
+
return 0 | 0;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* @description returns a hash of the contents
|
|
50
|
+
*/
|
|
51
|
+
public get hash (): IU8a {
|
|
52
|
+
return this.registry.hash(this.toU8a());
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* @description Checks if the value is an empty value
|
|
57
|
+
*/
|
|
58
|
+
public get isEmpty (): boolean {
|
|
59
|
+
return [...this.keys()].length === 0;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* @description Compares the value of the input to see if there is a match
|
|
64
|
+
*/
|
|
65
|
+
public eq (other?: unknown): boolean {
|
|
66
|
+
return compareMap(this, other);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* @description Returns a typed value from the internal map
|
|
71
|
+
*/
|
|
72
|
+
public getT <T> (key: string): T {
|
|
73
|
+
return this.get(key) as unknown as T;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* @description Unimplemented, will throw
|
|
78
|
+
*/
|
|
79
|
+
public inspect (): Inspect {
|
|
80
|
+
throw new Error('Unimplemented');
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
* @description Unimplemented, will throw
|
|
85
|
+
*/
|
|
86
|
+
public toHex (): HexString {
|
|
87
|
+
throw new Error('Unimplemented');
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* @description Converts the Object to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
92
|
+
*/
|
|
93
|
+
public toHuman (): Record<string, AnyJson> {
|
|
94
|
+
return [...this.entries()].reduce<Record<string, AnyJson>>((json, [key, value]): Record<string, AnyJson> => {
|
|
95
|
+
json[key] = isFunction((value as Codec)?.toHuman)
|
|
96
|
+
? (value as Codec).toHuman()
|
|
97
|
+
: value as AnyJson;
|
|
98
|
+
|
|
99
|
+
return json;
|
|
100
|
+
}, {});
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
105
|
+
*/
|
|
106
|
+
public toJSON (): Record<string, AnyJson> {
|
|
107
|
+
return [...this.entries()].reduce<Record<string, AnyJson>>((json, [key, value]): Record<string, AnyJson> => {
|
|
108
|
+
json[key] = value as AnyJson;
|
|
109
|
+
|
|
110
|
+
return json;
|
|
111
|
+
}, {});
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* @description Converts the value in a best-fit primitive form
|
|
116
|
+
*/
|
|
117
|
+
public toPrimitive (disableAscii?: boolean): Record<string, AnyJson> {
|
|
118
|
+
return [...this.entries()].reduce<Record<string, AnyJson>>((json, [key, value]): Record<string, AnyJson> => {
|
|
119
|
+
json[key] = isFunction((value as Codec).toPrimitive)
|
|
120
|
+
? (value as Codec).toPrimitive(disableAscii)
|
|
121
|
+
: value as AnyJson;
|
|
122
|
+
|
|
123
|
+
return json;
|
|
124
|
+
}, {});
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* @description Returns the base runtime type name for this instance
|
|
129
|
+
*/
|
|
130
|
+
public toRawType (): string {
|
|
131
|
+
return 'Json';
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* @description Returns the string representation of the value
|
|
136
|
+
*/
|
|
137
|
+
public override toString (): string {
|
|
138
|
+
return stringify(this.toJSON());
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* @description Unimplemented, will throw
|
|
143
|
+
*/
|
|
144
|
+
public toU8a (_isBare?: boolean): Uint8Array {
|
|
145
|
+
throw new Error('Unimplemented');
|
|
146
|
+
}
|
|
147
|
+
}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
// Copyright 2017-2025 @polkadot/types-codec authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
import type { AnyU8a, CodecTo } from '@pezkuwi/types-codec/types';
|
|
7
|
+
|
|
8
|
+
import { TypeRegistry } from '@pezkuwi/types';
|
|
9
|
+
import { Raw } from '@pezkuwi/types-codec';
|
|
10
|
+
|
|
11
|
+
const registry = new TypeRegistry();
|
|
12
|
+
|
|
13
|
+
const testDecode = (type: string, input: AnyU8a, expected: string): void =>
|
|
14
|
+
it(`can decode from ${type}`, (): void => {
|
|
15
|
+
const e = new Raw(registry, input);
|
|
16
|
+
|
|
17
|
+
expect(e.toString()).toBe(expected);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
const testEncode = (to: CodecTo, expected: AnyU8a): void =>
|
|
21
|
+
it(`can encode ${to}`, (): void => {
|
|
22
|
+
const e = new Raw(registry, [1, 2, 3, 4, 5]);
|
|
23
|
+
|
|
24
|
+
expect(e[to]()).toEqual(expected);
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
describe('Raw', (): void => {
|
|
28
|
+
let u8a: Raw;
|
|
29
|
+
|
|
30
|
+
beforeEach((): void => {
|
|
31
|
+
u8a = new Raw(registry, [1, 2, 3, 4, 5]);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
testDecode('Array', [1, 2, 3, 4, 5], '0x0102030405');
|
|
35
|
+
testDecode('hex', '0x0102030405', '0x0102030405');
|
|
36
|
+
testDecode('U8a', new Uint8Array([1, 2, 3, 4, 5]), '0x0102030405');
|
|
37
|
+
testDecode('Uint8Array', Uint8Array.from([1, 2, 3, 4, 5]), '0x0102030405');
|
|
38
|
+
|
|
39
|
+
testEncode('toJSON', '0x0102030405');
|
|
40
|
+
testEncode('toHex', '0x0102030405');
|
|
41
|
+
testEncode('toPrimitive', '0x0102030405');
|
|
42
|
+
testEncode('toString', '0x0102030405');
|
|
43
|
+
testEncode('toU8a', Uint8Array.from([1, 2, 3, 4, 5]));
|
|
44
|
+
|
|
45
|
+
it('contains the length of the elements', (): void => {
|
|
46
|
+
expect(u8a.length).toEqual(5);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it('correctly encodes length', (): void => {
|
|
50
|
+
expect(u8a.encodedLength).toEqual(5);
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
it('allows wrapping of a pre-existing instance', (): void => {
|
|
54
|
+
expect(
|
|
55
|
+
new Raw(registry, u8a).length
|
|
56
|
+
).toEqual(5);
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it('implements subarray correctly', (): void => {
|
|
60
|
+
expect(u8a.subarray(1, 3)).toEqual(Uint8Array.from([2, 3]));
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
describe('utils', (): void => {
|
|
64
|
+
it('compares against other U8a', (): void => {
|
|
65
|
+
expect(u8a.eq(new Uint8Array([1, 2, 3, 4, 5]))).toBe(true);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('compares against other U8a (non-length)', (): void => {
|
|
69
|
+
expect(u8a.eq(new Uint8Array([1, 2, 3, 4]))).toBe(false);
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
it('compares against other U8a (mismatch)', (): void => {
|
|
73
|
+
expect(u8a.eq(new Uint8Array([1, 2, 3, 4, 6]))).toBe(false);
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
it('compares against hex inputs', (): void => {
|
|
77
|
+
expect(u8a.eq('0x0102030405')).toBe(true);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('has valid isAscii', (): void => {
|
|
81
|
+
expect(u8a.isAscii).toBe(false);
|
|
82
|
+
expect(new Raw(registry, '0x2021222324').isAscii).toBe(true);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
it('has valid toHuman with disableAscii option set as true', (): void => {
|
|
86
|
+
expect(new Raw(registry, new Uint8Array([85, 85, 85, 85, 85, 85, 85, 85])).toHuman(undefined, true)).toEqual('0x5555555555555555');
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
it('has valid toPrimitive', (): void => {
|
|
90
|
+
expect(new Raw(registry, 'testing').toPrimitive()).toEqual('testing');
|
|
91
|
+
expect(new Raw(registry, '0xe4bda0e5a5bd').toPrimitive()).toEqual('0xe4bda0e5a5bd');
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('has valid toUtf8', (): void => {
|
|
95
|
+
expect(new Raw(registry, 'Приветствую, ми').toUtf8()).toEqual('Приветствую, ми');
|
|
96
|
+
expect(new Raw(registry, '0xe4bda0e5a5bd').toUtf8()).toEqual('你好');
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('throws on invalid utf8', (): void => {
|
|
100
|
+
expect(
|
|
101
|
+
() => new Raw(registry, '0x7f07b1f87709608bee603bbc79a0dfc29cd315c1351a83aa31adf7458d7d3003').toUtf8()
|
|
102
|
+
).toThrow(/The character sequence is not a valid Utf8 string/);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('has a sane inspect', (): void => {
|
|
106
|
+
expect(
|
|
107
|
+
new Raw(registry, [1, 2, 3, 4, 5]).inspect()
|
|
108
|
+
).toEqual({
|
|
109
|
+
outer: [new Uint8Array([1, 2, 3, 4, 5])]
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
});
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
// Copyright 2017-2025 @polkadot/types-codec authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import type { HexString } from '@pezkuwi/util/types';
|
|
5
|
+
import type { AnyJson, AnyU8a, Inspect, IU8a, Registry } from '../types/index.js';
|
|
6
|
+
|
|
7
|
+
import { isAscii, isUndefined, isUtf8, u8aToHex, u8aToString, u8aToU8a } from '@pezkuwi/util';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* @name Raw
|
|
11
|
+
* @description
|
|
12
|
+
* A basic wrapper around Uint8Array, with no frills and no fuss. It does differ
|
|
13
|
+
* from other implementations where it will consume the full Uint8Array as passed to it.
|
|
14
|
+
* As such it is meant to be subclassed where the wrapper takes care of the
|
|
15
|
+
* actual lengths instead of used directly.
|
|
16
|
+
* @noInheritDoc
|
|
17
|
+
*/
|
|
18
|
+
export class Raw extends Uint8Array implements IU8a {
|
|
19
|
+
readonly registry: Registry;
|
|
20
|
+
|
|
21
|
+
public createdAtHash?: IU8a | undefined;
|
|
22
|
+
public initialU8aLength?: number | undefined;
|
|
23
|
+
public isStorageFallback?: boolean;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* @description This ensures that operators such as clice, filter, map, etc. return
|
|
27
|
+
* new Array instances (without this we need to apply overrides)
|
|
28
|
+
*/
|
|
29
|
+
static get [Symbol.species] (): typeof Uint8Array {
|
|
30
|
+
return Uint8Array;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
constructor (registry: Registry, value?: AnyU8a, initialU8aLength?: number) {
|
|
34
|
+
super(u8aToU8a(value));
|
|
35
|
+
|
|
36
|
+
this.registry = registry;
|
|
37
|
+
this.initialU8aLength = initialU8aLength;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* @description The length of the value when encoded as a Uint8Array
|
|
42
|
+
*/
|
|
43
|
+
public get encodedLength (): number {
|
|
44
|
+
return this.length;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* @description returns a hash of the contents
|
|
49
|
+
*/
|
|
50
|
+
public get hash (): IU8a {
|
|
51
|
+
return this.registry.hash(this.toU8a());
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* @description Returns true if the wrapped value contains only ASCII printable characters
|
|
56
|
+
*/
|
|
57
|
+
public get isAscii (): boolean {
|
|
58
|
+
return isAscii(this);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* @description Returns true if the type wraps an empty/default all-0 value
|
|
63
|
+
*/
|
|
64
|
+
public get isEmpty (): boolean {
|
|
65
|
+
return !this.length || isUndefined(this.find((b) => !!b));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @description Returns true if the wrapped value contains only utf8 characters
|
|
70
|
+
*/
|
|
71
|
+
public get isUtf8 (): boolean {
|
|
72
|
+
return isUtf8(this);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* @description Returns the number of bits in the value
|
|
77
|
+
*/
|
|
78
|
+
public bitLength (): number {
|
|
79
|
+
return this.length * 8;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* @description Compares the value of the input to see if there is a match
|
|
84
|
+
*/
|
|
85
|
+
public eq (other?: unknown): boolean {
|
|
86
|
+
if (other instanceof Uint8Array) {
|
|
87
|
+
return (this.length === other.length) &&
|
|
88
|
+
!this.some((b, index) => b !== other[index]);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return this.eq(u8aToU8a(other as string));
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* @description Returns a breakdown of the hex encoding for this Codec
|
|
96
|
+
*/
|
|
97
|
+
public inspect (): Inspect {
|
|
98
|
+
return {
|
|
99
|
+
outer: [this.toU8a()]
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* @description Returns a hex string representation of the value
|
|
105
|
+
*/
|
|
106
|
+
public toHex (): HexString {
|
|
107
|
+
return u8aToHex(this);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
|
|
112
|
+
*/
|
|
113
|
+
public toHuman (_isExtended?: boolean, disableAscii?: boolean): AnyJson {
|
|
114
|
+
return this.toPrimitive(disableAscii);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* @description Converts the Object to JSON, typically used for RPC transfers
|
|
119
|
+
*/
|
|
120
|
+
public toJSON (): string {
|
|
121
|
+
return this.toHex();
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* @description Converts the value in a best-fit primitive form
|
|
126
|
+
*/
|
|
127
|
+
public toPrimitive (disableAscii?: boolean): AnyJson {
|
|
128
|
+
if (!disableAscii && this.isAscii) {
|
|
129
|
+
const text = this.toUtf8();
|
|
130
|
+
|
|
131
|
+
// ensure we didn't end up with multibyte codepoints
|
|
132
|
+
if (isAscii(text)) {
|
|
133
|
+
return text;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
return this.toJSON();
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
/**
|
|
141
|
+
* @description Returns the base runtime type name for this instance
|
|
142
|
+
*/
|
|
143
|
+
public toRawType (): string {
|
|
144
|
+
return 'Raw';
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
/**
|
|
148
|
+
* @description Returns the string representation of the value
|
|
149
|
+
*/
|
|
150
|
+
public override toString (): string {
|
|
151
|
+
return this.toHex();
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* @description Encodes the value as a Uint8Array as per the SCALE specifications
|
|
156
|
+
*/
|
|
157
|
+
public toU8a (_isBare?: boolean): Uint8Array {
|
|
158
|
+
return Uint8Array.from(this);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* @description Returns the wrapped data as a UTF-8 string
|
|
163
|
+
*/
|
|
164
|
+
public toUtf8 (): string {
|
|
165
|
+
if (!this.isUtf8) {
|
|
166
|
+
throw new Error('The character sequence is not a valid Utf8 string');
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
return u8aToString(this);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
// Copyright 2017-2025 @polkadot/types-codec authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
/// <reference types="@pezkuwi/dev-test/globals.d.ts" />
|
|
5
|
+
|
|
6
|
+
/* eslint-disable sort-keys */
|
|
7
|
+
|
|
8
|
+
import { TypeRegistry } from '@pezkuwi/types';
|
|
9
|
+
import { CodecSet } from '@pezkuwi/types-codec';
|
|
10
|
+
import { stringify } from '@pezkuwi/util';
|
|
11
|
+
|
|
12
|
+
// TODO actually import these from definitions, don't re-define here
|
|
13
|
+
const SET_FIELDS = {
|
|
14
|
+
header: 0b00000001,
|
|
15
|
+
body: 0b00000010,
|
|
16
|
+
receipt: 0b00000100,
|
|
17
|
+
messageQueue: 0b00001000,
|
|
18
|
+
justification: 0b00010000
|
|
19
|
+
};
|
|
20
|
+
const SET_ROLES = {
|
|
21
|
+
none: 0b00000000,
|
|
22
|
+
full: 0b00000001,
|
|
23
|
+
light: 0b00000010,
|
|
24
|
+
authority: 0b00000100
|
|
25
|
+
};
|
|
26
|
+
const SET_WITHDRAW = {
|
|
27
|
+
TransactionPayment: 0b00000001,
|
|
28
|
+
Transfer: 0b00000010,
|
|
29
|
+
Reserve: 0b00000100,
|
|
30
|
+
Fee: 0b00001000
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
describe('Set', (): void => {
|
|
34
|
+
const registry = new TypeRegistry();
|
|
35
|
+
|
|
36
|
+
it('constructs via an string[]', (): void => {
|
|
37
|
+
const set = new CodecSet(registry, SET_ROLES, ['full', 'authority']);
|
|
38
|
+
|
|
39
|
+
expect(set.isEmpty).toEqual(false);
|
|
40
|
+
expect(set.toString()).toEqual(
|
|
41
|
+
'[full, authority]'
|
|
42
|
+
);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it('throws with invalid values', (): void => {
|
|
46
|
+
expect(
|
|
47
|
+
() => new CodecSet(registry, SET_ROLES, ['full', 'authority', 'invalid'])
|
|
48
|
+
).toThrow(/Invalid key 'invalid'/);
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it('throws with add on invalid', (): void => {
|
|
52
|
+
expect(
|
|
53
|
+
() => (new CodecSet(registry, SET_ROLES, [])).add('invalid')
|
|
54
|
+
).toThrow(/Invalid key 'invalid'/);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it('allows construction via number', (): void => {
|
|
58
|
+
expect(
|
|
59
|
+
(new CodecSet(registry, SET_WITHDRAW, 15)).eq(['TransactionPayment', 'Transfer', 'Reserve', 'Fee'])
|
|
60
|
+
).toBe(true);
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('does not allow invalid number', (): void => {
|
|
64
|
+
expect(
|
|
65
|
+
() => new CodecSet(registry, SET_WITHDRAW, 31)
|
|
66
|
+
).toThrow(/Mismatch decoding '31', computed as '15'/);
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it('hash a valid encoding', (): void => {
|
|
70
|
+
const set = new CodecSet(registry, SET_FIELDS, ['header', 'body', 'justification']);
|
|
71
|
+
|
|
72
|
+
expect(set.toU8a()).toEqual(new Uint8Array([19]));
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
describe('utils', (): void => {
|
|
76
|
+
const set = new CodecSet(registry, SET_ROLES, ['full', 'authority']);
|
|
77
|
+
|
|
78
|
+
it('compares against string array', (): void => {
|
|
79
|
+
expect(
|
|
80
|
+
set.eq(['authority', 'full'])
|
|
81
|
+
).toBe(true);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('compares against number (encoded)', (): void => {
|
|
85
|
+
expect(
|
|
86
|
+
set.eq(SET_ROLES.full | SET_ROLES.authority)
|
|
87
|
+
).toBe(true);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it('compares against other sets', (): void => {
|
|
91
|
+
expect(
|
|
92
|
+
set.eq(new CodecSet(registry, SET_ROLES, ['authority', 'full']))
|
|
93
|
+
).toBe(true);
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it('returns false on other values', (): void => {
|
|
97
|
+
expect(
|
|
98
|
+
set.eq('full')
|
|
99
|
+
).toBe(false);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
it('has a sane inspect', (): void => {
|
|
103
|
+
expect(set.inspect()).toEqual({
|
|
104
|
+
outer: [new Uint8Array([SET_ROLES.full | SET_ROLES.authority])]
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
it('has a sane toRawType representation', (): void => {
|
|
110
|
+
expect(
|
|
111
|
+
new CodecSet(registry, { a: 1, b: 2, c: 345 }).toRawType()
|
|
112
|
+
).toEqual(stringify({
|
|
113
|
+
_set: { a: 1, b: 2, c: 345 }
|
|
114
|
+
}));
|
|
115
|
+
});
|
|
116
|
+
});
|