@oathompsonjones/mini-games 1.0.6 → 1.0.9
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/TODO.md +6 -0
- package/build/base/board.d.ts +53 -45
- package/build/base/board.js +84 -72
- package/build/base/controller.d.ts +48 -37
- package/build/base/controller.js +32 -26
- package/build/bitBoard/bitBoard.d.ts +37 -34
- package/build/bitBoard/bitBoard.js +15 -12
- package/build/bitBoard/intBitBoard.d.ts +22 -22
- package/build/bitBoard/intBitBoard.js +16 -16
- package/build/bitBoard/longInt.d.ts +47 -40
- package/build/bitBoard/longInt.js +40 -37
- package/build/bitBoard/longIntBitBoard.d.ts +26 -26
- package/build/bitBoard/longIntBitBoard.js +16 -16
- package/build/console.d.ts +2 -3
- package/build/console.js +3 -4
- package/build/games/connect4/board.d.ts +12 -5
- package/build/games/connect4/board.js +12 -6
- package/build/games/connect4/controller.d.ts +18 -11
- package/build/games/connect4/controller.js +20 -12
- package/build/games/tictactoe/board.d.ts +5 -2
- package/build/games/tictactoe/board.js +5 -2
- package/build/games/tictactoe/controller.d.ts +17 -12
- package/build/games/tictactoe/controller.js +19 -13
- package/eslint.config.js +1 -1
- package/package.json +6 -7
- package/patches/eventemitter3@5.0.1.patch +0 -68
|
@@ -8,7 +8,7 @@ export default class LongInt {
|
|
|
8
8
|
data;
|
|
9
9
|
/**
|
|
10
10
|
* Creates an instance of LongInt.
|
|
11
|
-
* @param args The arguments to construct the `LongInt` out of.
|
|
11
|
+
* @param args - The arguments to construct the `LongInt` out of.
|
|
12
12
|
*/
|
|
13
13
|
constructor(args) {
|
|
14
14
|
if (args instanceof Array || args instanceof Uint32Array)
|
|
@@ -18,14 +18,17 @@ export default class LongInt {
|
|
|
18
18
|
else
|
|
19
19
|
this.data = new Uint32Array(args).fill(0);
|
|
20
20
|
}
|
|
21
|
-
/**
|
|
21
|
+
/**
|
|
22
|
+
* Gets the number of 32-bit words which make the LongInt.
|
|
23
|
+
* @returns The number of words.
|
|
24
|
+
*/
|
|
22
25
|
get wordCount() {
|
|
23
26
|
return this.data.length;
|
|
24
27
|
}
|
|
25
28
|
/**
|
|
26
29
|
* Carries out a bitwise and (&) operation on the two numbers.
|
|
27
|
-
* @param left The left number.
|
|
28
|
-
* @param right The right number.
|
|
30
|
+
* @param left - The left number.
|
|
31
|
+
* @param right - The right number.
|
|
29
32
|
* @returns The result of left & right.
|
|
30
33
|
*/
|
|
31
34
|
static and(left, right) {
|
|
@@ -33,8 +36,8 @@ export default class LongInt {
|
|
|
33
36
|
}
|
|
34
37
|
/**
|
|
35
38
|
* Carries out a bitwise or (|) operation on the two numbers.
|
|
36
|
-
* @param left The left number.
|
|
37
|
-
* @param right The right number.
|
|
39
|
+
* @param left - The left number.
|
|
40
|
+
* @param right - The right number.
|
|
38
41
|
* @returns The result of left | right.
|
|
39
42
|
*/
|
|
40
43
|
static or(left, right) {
|
|
@@ -42,8 +45,8 @@ export default class LongInt {
|
|
|
42
45
|
}
|
|
43
46
|
/**
|
|
44
47
|
* Carries out a bitwise xor (^) operation on the two numbers.
|
|
45
|
-
* @param left The left number.
|
|
46
|
-
* @param right The right number.
|
|
48
|
+
* @param left - The left number.
|
|
49
|
+
* @param right - The right number.
|
|
47
50
|
* @returns The result of left ^ right.
|
|
48
51
|
*/
|
|
49
52
|
static xor(left, right) {
|
|
@@ -51,7 +54,7 @@ export default class LongInt {
|
|
|
51
54
|
}
|
|
52
55
|
/**
|
|
53
56
|
* Carries out a bitwise not (~) operation on the number.
|
|
54
|
-
* @param number The number to negate.
|
|
57
|
+
* @param number - The number to negate.
|
|
55
58
|
* @returns The result of ~number.
|
|
56
59
|
*/
|
|
57
60
|
static not(number) {
|
|
@@ -59,8 +62,8 @@ export default class LongInt {
|
|
|
59
62
|
}
|
|
60
63
|
/**
|
|
61
64
|
* Carries out a bitwise left shift (<<) operation on the number.
|
|
62
|
-
* @param number The number to shift.
|
|
63
|
-
* @param shiftAmount The number of places to shift.
|
|
65
|
+
* @param number - The number to shift.
|
|
66
|
+
* @param shiftAmount - The number of places to shift.
|
|
64
67
|
* @returns The result of number << shiftAmount.
|
|
65
68
|
*/
|
|
66
69
|
static leftShift(number, shiftAmount) {
|
|
@@ -68,8 +71,8 @@ export default class LongInt {
|
|
|
68
71
|
}
|
|
69
72
|
/**
|
|
70
73
|
* Carries out a bitwise unsigned right shift (>>>) operation on the number.
|
|
71
|
-
* @param number The number to shift.
|
|
72
|
-
* @param shiftAmount The number of places to shift.
|
|
74
|
+
* @param number - The number to shift.
|
|
75
|
+
* @param shiftAmount - The number of places to shift.
|
|
73
76
|
* @returns The result of number >>> shiftAmount.
|
|
74
77
|
*/
|
|
75
78
|
static rightShift(number, shiftAmount) {
|
|
@@ -77,8 +80,8 @@ export default class LongInt {
|
|
|
77
80
|
}
|
|
78
81
|
/**
|
|
79
82
|
* Carries out a bitwise arithmetic right shift (>>) operation on the number.
|
|
80
|
-
* @param number The number to shift.
|
|
81
|
-
* @param shiftAmount The number of places to shift.
|
|
83
|
+
* @param number - The number to shift.
|
|
84
|
+
* @param shiftAmount - The number of places to shift.
|
|
82
85
|
* @returns The result of number >> shiftAmount.
|
|
83
86
|
*/
|
|
84
87
|
static arithmeticRightShift(number, shiftAmount) {
|
|
@@ -86,8 +89,8 @@ export default class LongInt {
|
|
|
86
89
|
}
|
|
87
90
|
/**
|
|
88
91
|
* Determines whether or not 2 LongInts have equal values.
|
|
89
|
-
* @param longInt1 The first LongInt.
|
|
90
|
-
* @param longInt2 The second LongInt (can also be a number).
|
|
92
|
+
* @param longInt1 - The first LongInt.
|
|
93
|
+
* @param longInt2 - The second LongInt (can also be a number).
|
|
91
94
|
* @returns Whether or not they are equal.
|
|
92
95
|
*/
|
|
93
96
|
static equals(longInt1, longInt2) {
|
|
@@ -95,8 +98,8 @@ export default class LongInt {
|
|
|
95
98
|
}
|
|
96
99
|
/**
|
|
97
100
|
* Creates a LongInt with the same dimensions as this one, using the given input.
|
|
98
|
-
* @param longInt The LongInt to match the dimensions of.
|
|
99
|
-
* @param value The value of the LongInt.
|
|
101
|
+
* @param longInt - The LongInt to match the dimensions of.
|
|
102
|
+
* @param value - The value of the LongInt to create.
|
|
100
103
|
* @returns The new LongInt.
|
|
101
104
|
*/
|
|
102
105
|
static getMatchingLongInt(longInt, value = 0) {
|
|
@@ -104,7 +107,7 @@ export default class LongInt {
|
|
|
104
107
|
}
|
|
105
108
|
/**
|
|
106
109
|
* Carries out an in-place bitwise and (&) operation on this number and the one provided.
|
|
107
|
-
* @param right The right number.
|
|
110
|
+
* @param right - The right number.
|
|
108
111
|
* @returns The new value of this & right.
|
|
109
112
|
*/
|
|
110
113
|
and(right) {
|
|
@@ -115,7 +118,7 @@ export default class LongInt {
|
|
|
115
118
|
}
|
|
116
119
|
/**
|
|
117
120
|
* Carries out an in-place bitwise or (|) operation on this number and the one provided.
|
|
118
|
-
* @param right The right number.
|
|
121
|
+
* @param right - The right number.
|
|
119
122
|
* @returns The new value of this | right.
|
|
120
123
|
*/
|
|
121
124
|
or(right) {
|
|
@@ -126,7 +129,7 @@ export default class LongInt {
|
|
|
126
129
|
}
|
|
127
130
|
/**
|
|
128
131
|
* Carries out an in-place bitwise xor (^) operation on this number and the one provided.
|
|
129
|
-
* @param right The right number.
|
|
132
|
+
* @param right - The right number.
|
|
130
133
|
* @returns The new value of this ^ right.
|
|
131
134
|
*/
|
|
132
135
|
xor(right) {
|
|
@@ -146,7 +149,7 @@ export default class LongInt {
|
|
|
146
149
|
}
|
|
147
150
|
/**
|
|
148
151
|
* Carries out an in-place bitwise left shift (<<) operation on this number.
|
|
149
|
-
* @param shiftAmount The number of places to shift.
|
|
152
|
+
* @param shiftAmount - The number of places to shift.
|
|
150
153
|
* @returns The result of this << shiftAmount.
|
|
151
154
|
*/
|
|
152
155
|
leftShift(shiftAmount) {
|
|
@@ -163,9 +166,9 @@ export default class LongInt {
|
|
|
163
166
|
}
|
|
164
167
|
/**
|
|
165
168
|
* Carries out an in-place bitwise unsigned right shift (>>>) operation on this number.
|
|
166
|
-
* @param shiftAmount The number of places to shift.
|
|
169
|
+
* @param shiftAmount - The number of places to shift.
|
|
167
170
|
* @returns The result of this >>> shiftAmount.
|
|
168
|
-
|
|
171
|
+
*/
|
|
169
172
|
rightShift(shiftAmount) {
|
|
170
173
|
if (shiftAmount === 0)
|
|
171
174
|
return this;
|
|
@@ -180,7 +183,7 @@ export default class LongInt {
|
|
|
180
183
|
}
|
|
181
184
|
/**
|
|
182
185
|
* Carries out an in-place bitwise arithmetic right shift (>>) operation on this number.
|
|
183
|
-
* @param shiftAmount The number of places to shift.
|
|
186
|
+
* @param shiftAmount - The number of places to shift.
|
|
184
187
|
* @returns The result of this >> shiftAmount.
|
|
185
188
|
*/
|
|
186
189
|
arithmeticRightShift(shiftAmount) {
|
|
@@ -197,7 +200,7 @@ export default class LongInt {
|
|
|
197
200
|
}
|
|
198
201
|
/**
|
|
199
202
|
* Determines whether or not this LongInt has equal value to another.
|
|
200
|
-
* @param value The LongInt or number to compare to.
|
|
203
|
+
* @param value - The LongInt or number to compare to.
|
|
201
204
|
* @returns Whether or not they are equal.
|
|
202
205
|
*/
|
|
203
206
|
equals(value) {
|
|
@@ -213,19 +216,19 @@ export default class LongInt {
|
|
|
213
216
|
}
|
|
214
217
|
/**
|
|
215
218
|
* Returns a string representation of the LongInt.
|
|
216
|
-
* @param type The base of the string to print.
|
|
219
|
+
* @param type - The base of the string to print.
|
|
217
220
|
* @returns The string representation.
|
|
218
221
|
*/
|
|
219
222
|
toString(type) {
|
|
220
223
|
let padLength = 0;
|
|
221
224
|
switch (type) {
|
|
222
|
-
case 2
|
|
225
|
+
case 2 /* StringType.BINARY */:
|
|
223
226
|
padLength = 32;
|
|
224
227
|
break;
|
|
225
|
-
case 10
|
|
228
|
+
case 10 /* StringType.DECIMAL */:
|
|
226
229
|
padLength = 10;
|
|
227
230
|
break;
|
|
228
|
-
case 16
|
|
231
|
+
case 16 /* StringType.HEXADECIMAL */:
|
|
229
232
|
padLength = 8;
|
|
230
233
|
break;
|
|
231
234
|
}
|
|
@@ -236,7 +239,7 @@ export default class LongInt {
|
|
|
236
239
|
}
|
|
237
240
|
/**
|
|
238
241
|
* Creates a LongInt with the same dimensions as this one, using the given input.
|
|
239
|
-
* @param value The value of the LongInt.
|
|
242
|
+
* @param value - The value of the LongInt to create.
|
|
240
243
|
* @returns The new LongInt.
|
|
241
244
|
*/
|
|
242
245
|
getMatchingLongInt(value = 0) {
|
|
@@ -274,8 +277,8 @@ export default class LongInt {
|
|
|
274
277
|
}
|
|
275
278
|
/**
|
|
276
279
|
* Shifts the 32-bit number array to the right.
|
|
277
|
-
* @param count How many places to shift the array.
|
|
278
|
-
* @param fillValue The value to fill empty spaces with.
|
|
280
|
+
* @param count - How many places to shift the array.
|
|
281
|
+
* @param fillValue - The value to fill empty spaces with.
|
|
279
282
|
* @returns The new value of this.
|
|
280
283
|
*/
|
|
281
284
|
shiftArrayRight(count, fillValue = 0) {
|
|
@@ -287,8 +290,8 @@ export default class LongInt {
|
|
|
287
290
|
}
|
|
288
291
|
/**
|
|
289
292
|
* Shifts the 32-bit number array to the left.
|
|
290
|
-
* @param count How many places to shift the array.
|
|
291
|
-
* @param fillValue The value to fill empty spaces with.
|
|
293
|
+
* @param count - How many places to shift the array.
|
|
294
|
+
* @param fillValue - The value to fill empty spaces with.
|
|
292
295
|
* @returns The new value of this.
|
|
293
296
|
*/
|
|
294
297
|
shiftArrayLeft(count, fillValue = 0) {
|
|
@@ -299,4 +302,4 @@ export default class LongInt {
|
|
|
299
302
|
return this;
|
|
300
303
|
}
|
|
301
304
|
}
|
|
302
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"longInt.js","sourceRoot":"","sources":["../../src/bitBoard/longInt.ts"],"names":[],"mappings":"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","sourcesContent":["export type StringType = 2 | 10 | 16;\n\n/**\n * Represents a long integer using an array of 32-bit numbers.\n * Provides static methods for bitwise operations which do not modify the original values.\n * Provides non-static equivalents to the above operations, which are carried out in place.\n */\nexport default class LongInt {\n    /** Holds the array of 32-bit numbers. */\n    public readonly data: Uint32Array;\n\n    /**\n     * Creates an instance of LongInt.\n     * @param values A little-endian array of 32-bit numbers to fill the `LongInt`.\n     */\n    public constructor(values: number[] | Uint32Array);\n    /**\n     * Creates an instance of LongInt.\n     * @param length The number of 32-bit numbers to construct the `LongInt` out of.\n     */\n    public constructor(length: number);\n    /**\n     * Creates an instance of LongInt.\n     * @param longInt A `LongInt` object to duplicate.\n     */\n    public constructor(longInt: LongInt);\n    /**\n     * Creates an instance of LongInt.\n     * @param args The arguments to construct the `LongInt` out of.\n     */\n    public constructor(args: LongInt | number[] | Uint32Array | number) {\n        if (args instanceof Array || args instanceof Uint32Array)\n            this.data = new Uint32Array(args);\n        else if (args instanceof LongInt)\n            this.data = new Uint32Array(args.data);\n        else\n            this.data = new Uint32Array(args).fill(0);\n    }\n\n    /** Gets the number of 32-bit words which make the LongInt. */\n    public get wordCount(): number {\n        return this.data.length;\n    }\n\n    /**\n     * Carries out a bitwise and (&) operation on the two numbers.\n     * @param left The left number.\n     * @param right The right number.\n     * @returns The result of left & right.\n     */\n    public static and(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).and(right);\n    }\n\n    /**\n     * Carries out a bitwise or (|) operation on the two numbers.\n     * @param left The left number.\n     * @param right The right number.\n     * @returns The result of left | right.\n     */\n    public static or(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).or(right);\n    }\n\n    /**\n     * Carries out a bitwise xor (^) operation on the two numbers.\n     * @param left The left number.\n     * @param right The right number.\n     * @returns The result of left ^ right.\n     */\n    public static xor(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).xor(right);\n    }\n\n    /**\n     * Carries out a bitwise not (~) operation on the number.\n     * @param number The number to negate.\n     * @returns The result of ~number.\n     */\n    public static not(number: LongInt): LongInt {\n        return new LongInt(number).not();\n    }\n\n    /**\n     * Carries out a bitwise left shift (<<) operation on the number.\n     * @param number The number to shift.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of number << shiftAmount.\n     */\n    public static leftShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).leftShift(shiftAmount);\n    }\n\n    /**\n     * Carries out a bitwise unsigned right shift (>>>) operation on the number.\n     * @param number The number to shift.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of number >>> shiftAmount.\n     */\n    public static rightShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).rightShift(shiftAmount);\n    }\n\n    /**\n     * Carries out a bitwise arithmetic right shift (>>) operation on the number.\n     * @param number The number to shift.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of number >> shiftAmount.\n     */\n    public static arithmeticRightShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).arithmeticRightShift(shiftAmount);\n    }\n\n    /**\n     * Determines whether or not 2 LongInts have equal values.\n     * @param longInt1 The first LongInt.\n     * @param longInt2 The second LongInt (can also be a number).\n     * @returns Whether or not they are equal.\n     */\n    public static equals(longInt1: LongInt, longInt2: LongInt | number): boolean {\n        return longInt1.equals(longInt2);\n    }\n\n    /**\n     * Creates a new LongInt object with the given value, stretched or truncated to the same size as this.\n     * @param longInt The LongInt to match the dimensions of.\n     * @param value The LongInt object to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value: LongInt): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param longInt The LongInt to match the dimensions of.\n     * @param values An array of 32-bit numbers to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, values: number[] | Uint32Array): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param longInt The LongInt to match the dimensions of.\n     * @param value A 32-bit number to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value?: number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param longInt The LongInt to match the dimensions of.\n     * @param value The value of the LongInt.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value: LongInt | number[] | Uint32Array | number = 0): LongInt {\n        return new LongInt(longInt).getMatchingLongInt(value);\n    }\n\n    /**\n     * Carries out an in-place bitwise and (&) operation on this number and the one provided.\n     * @param right The right number.\n     * @returns The new value of this & right.\n     */\n    public and(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] &= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise or (|) operation on this number and the one provided.\n     * @param right The right number.\n     * @returns The new value of this | right.\n     */\n    public or(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] |= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise xor (^) operation on this number and the one provided.\n     * @param right The right number.\n     * @returns The new value of this ^ right.\n     */\n    public xor(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] ^= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise not (~) operation on this nurmbe.\n     * @returns The result of ~this.\n     */\n    public not(): this {\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] = ~this.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise left shift (<<) operation on this number.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of this << shiftAmount.\n     */\n    public leftShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount > 31)\n            this.shiftArrayRight(Math.floor(shiftAmount / 32));\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = this.data.length - 1; i >= 0; i--)\n                this.data[i] = this.data[i]! << singleShiftAmount | this.data[i - 1]! >>> 32 - singleShiftAmount;\n        }\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise unsigned right shift (>>>) operation on this number.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of this >>> shiftAmount.\n    */\n    public rightShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = 0; i < this.data.length; i++)\n                this.data[i] = this.data[i]! >>> singleShiftAmount | this.data[i + 1]! << 32 - singleShiftAmount;\n        }\n\n        if (shiftAmount > 31)\n            this.shiftArrayLeft(Math.floor(shiftAmount / 32));\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise arithmetic right shift (>>) operation on this number.\n     * @param shiftAmount The number of places to shift.\n     * @returns The result of this >> shiftAmount.\n     */\n    public arithmeticRightShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = 0; i < this.data.length; i++)\n                this.data[i] = this.data[i]! >> singleShiftAmount | this.data[i + 1]! << 32 - singleShiftAmount;\n        }\n\n        if (shiftAmount > 31)\n            this.shiftArrayLeft(Math.floor(shiftAmount / 32), ~0 >>> 0);\n\n        return this;\n    }\n\n    /**\n     * Determines whether or not this LongInt has equal value to another.\n     * @param value The LongInt or number to compare to.\n     * @returns Whether or not they are equal.\n     */\n    public equals(value: LongInt | number): boolean {\n        const longInt = value instanceof LongInt ? value : new LongInt([value]);\n        const longestLongInt = this.data.length > longInt.data.length ? this : longInt;\n        const longInt1 = LongInt.getMatchingLongInt(longestLongInt, this);\n        const longInt2 = LongInt.getMatchingLongInt(longestLongInt, longInt);\n\n        for (let i = 0; i < longestLongInt.data.length; i++) {\n            if (longInt1.data[i] !== longInt2.data[i])\n                return false;\n        }\n\n        return true;\n    }\n\n    /**\n     * Returns a string representation of the LongInt.\n     * @param type The base of the string to print.\n     * @returns The string representation.\n     */\n    public toString(type: StringType): string {\n        let padLength = 0;\n\n        switch (type) {\n            case 2:\n                padLength = 32;\n                break;\n            case 10:\n                padLength = 10;\n                break;\n            case 16:\n                padLength = 8;\n                break;\n        }\n\n        return [...this.data]\n            .reverse()\n            .map((num) => num.toString(type).padStart(padLength, \"0\"))\n            .join(\" \");\n    }\n\n    /**\n     * Creates a new LongInt object with the given value, stretched or truncated to the same size as this.\n     * @param longInt The LongInt object to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(longInt: LongInt): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param values An array of 32-bit numbers to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(values: number[] | Uint32Array): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param value A 32-bit number to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value?: number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param value The value of the LongInt.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value: LongInt | number[] | Uint32Array | number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param value The value of the LongInt.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value: LongInt | number[] | Uint32Array | number = 0): LongInt {\n        let integers: number[] | Uint32Array = [];\n\n        switch (true) {\n            case value instanceof Uint32Array:\n                if (value.length < this.data.length)\n                    integers = [...value, ...Array<number>(this.data.length - value.length).fill(0)];\n                else if (value.length > this.data.length)\n                    integers = value.slice(0, this.data.length);\n                else\n                    integers = value;\n\n                break;\n            case value instanceof LongInt:\n                if (value.data.length < this.data.length)\n                    integers = [...value.data, ...Array<number>(this.data.length - value.data.length).fill(0)];\n                else if (value.data.length > this.data.length)\n                    integers = value.data.slice(0, this.data.length);\n                else\n                    integers = value.data;\n\n                break;\n            case value instanceof Array:\n                if (value.length < this.data.length)\n                    integers = [...value, ...Array<number>(this.data.length - value.length).fill(0)];\n                else if (value.length > this.data.length)\n                    integers = value.slice(0, this.data.length);\n                else\n                    integers = value;\n\n                break;\n            default:\n                integers = [value, ...Array<number>(this.data.length - 1).fill(0)];\n                break;\n        }\n\n        return new LongInt(integers);\n    }\n\n    /**\n     * Shifts the 32-bit number array to the right.\n     * @param count How many places to shift the array.\n     * @param fillValue The value to fill empty spaces with.\n     * @returns The new value of this.\n     */\n    private shiftArrayRight(count: number, fillValue: number = 0): this {\n        if (count < 0)\n            return this.shiftArrayLeft(-count, fillValue);\n\n        for (let i = this.data.length - 1; i >= 0; i--)\n            this.data[i] = this.data[i - count] ?? fillValue;\n\n        return this;\n    }\n\n    /**\n     * Shifts the 32-bit number array to the left.\n     * @param count How many places to shift the array.\n     * @param fillValue The value to fill empty spaces with.\n     * @returns The new value of this.\n     */\n    private shiftArrayLeft(count: number, fillValue: number = 0): this {\n        if (count < 0)\n            return this.shiftArrayRight(-count, fillValue);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] = this.data[i + count] ?? fillValue;\n\n        return this;\n    }\n}\n"]}
|
|
305
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"longInt.js","sourceRoot":"","sources":["../../src/bitBoard/longInt.ts"],"names":[],"mappings":"AAMA;;;;GAIG;AACH,MAAM,CAAC,OAAO,OAAO,OAAO;IACxB,yCAAyC;IACzB,IAAI,CAAc;IAiBlC;;;OAGG;IACH,YAAmB,IAA+C;QAC9D,IAAI,IAAI,YAAY,KAAK,IAAI,IAAI,YAAY,WAAW;YACpD,IAAI,CAAC,IAAI,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;aACjC,IAAI,IAAI,YAAY,OAAO;YAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;YAEvC,IAAI,CAAC,IAAI,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC;IAED;;;OAGG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,GAAG,CAAC,IAAa,EAAE,KAAuB;QACpD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,EAAE,CAAC,IAAa,EAAE,KAAuB;QACnD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,GAAG,CAAC,IAAa,EAAE,KAAuB;QACpD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,GAAG,CAAC,MAAe;QAC7B,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC;IACrC,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,SAAS,CAAC,MAAe,EAAE,WAAmB;QACxD,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACtD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,UAAU,CAAC,MAAe,EAAE,WAAmB;QACzD,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IACvD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,oBAAoB,CAAC,MAAe,EAAE,WAAmB;QACnE,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAC;IACjE,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAC,QAAiB,EAAE,QAA0B;QAC9D,OAAO,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAuBD;;;;;OAKG;IACI,MAAM,CAAC,kBAAkB,CAAC,OAAgB,EAAE,QAAmD,CAAC;QACnG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAED;;;;OAIG;IACI,GAAG,CAAC,KAAuB;QAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAE,CAAC;QAE3C,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,EAAE,CAAC,KAAuB;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAE,CAAC;QAE3C,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,GAAG,CAAC,KAAuB;QAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAE,CAAC;QAE3C,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;OAGG;IACI,GAAG;QACN,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,CAAC;QAElC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,WAAmB;QAChC,IAAI,WAAW,KAAK,CAAC;YACjB,OAAO,IAAI,CAAC;QAEhB,IAAI,WAAW,GAAG,EAAE;YAChB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC,CAAC;QAEvD,IAAI,WAAW,KAAK,EAAE,EAAE,CAAC;YACrB,MAAM,iBAAiB,GAAG,WAAW,GAAG,EAAE,CAAC;YAE3C,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;gBAC1C,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,IAAI,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAE,KAAK,EAAE,GAAG,iBAAiB,CAAC;QACzG,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,UAAU,CAAC,WAAmB;QACjC,IAAI,WAAW,KAAK,CAAC;YACjB,OAAO,IAAI,CAAC;QAEhB,IAAI,WAAW,KAAK,EAAE,EAAE,CAAC;YACrB,MAAM,iBAAiB,GAAG,WAAW,GAAG,EAAE,CAAC;YAE3C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;gBACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,KAAK,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAE,IAAI,EAAE,GAAG,iBAAiB,CAAC;QACzG,CAAC;QAED,IAAI,WAAW,GAAG,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC,CAAC;QAEtD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,oBAAoB,CAAC,WAAmB;QAC3C,IAAI,WAAW,KAAK,CAAC;YACjB,OAAO,IAAI,CAAC;QAEhB,IAAI,WAAW,KAAK,EAAE,EAAE,CAAC;YACrB,MAAM,iBAAiB,GAAG,WAAW,GAAG,EAAE,CAAC;YAE3C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;gBACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAE,IAAI,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAE,IAAI,EAAE,GAAG,iBAAiB,CAAC;QACxG,CAAC;QAED,IAAI,WAAW,GAAG,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAEhE,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,KAAuB;QACjC,MAAM,OAAO,GAAG,KAAK,YAAY,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACxE,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;QAC/E,MAAM,QAAQ,GAAG,OAAO,CAAC,kBAAkB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;QAClE,MAAM,QAAQ,GAAG,OAAO,CAAC,kBAAkB,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;QAErE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAClD,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBACrC,OAAO,KAAK,CAAC;QACrB,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,IAAgB;QAC5B,IAAI,SAAS,GAAG,CAAC,CAAC;QAElB,QAAQ,IAAI,EAAE,CAAC;YACX;gBACI,SAAS,GAAG,EAAE,CAAC;gBACf,MAAM;YACV;gBACI,SAAS,GAAG,EAAE,CAAC;gBACf,MAAM;YACV;gBACI,SAAS,GAAG,CAAC,CAAC;gBACd,MAAM;QACd,CAAC;QAED,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;aAChB,OAAO,EAAE;aACT,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;aACzD,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IA0BD;;;;OAIG;IACK,kBAAkB,CAAC,QAAmD,CAAC;QAC3E,IAAI,QAAQ,GAA2B,EAAE,CAAC;QAE1C,QAAQ,IAAI,EAAE,CAAC;YACX,KAAK,KAAK,YAAY,WAAW;gBAC7B,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBAC/B,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,GAAG,KAAK,CAAS,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;qBAChF,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBACpC,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;oBAE5C,QAAQ,GAAG,KAAK,CAAC;gBAErB,MAAM;YACV,KAAK,KAAK,YAAY,OAAO;gBACzB,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBACpC,QAAQ,GAAG,CAAC,GAAG,KAAK,CAAC,IAAI,EAAE,GAAG,KAAK,CAAS,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC1F,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBACzC,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;oBAEjD,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC;gBAE1B,MAAM;YACV,KAAK,KAAK,YAAY,KAAK;gBACvB,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBAC/B,QAAQ,GAAG,CAAC,GAAG,KAAK,EAAE,GAAG,KAAK,CAAS,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;qBAChF,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM;oBACpC,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;oBAE5C,QAAQ,GAAG,KAAK,CAAC;gBAErB,MAAM;YACV;gBACI,QAAQ,GAAG,CAAC,KAAK,EAAE,GAAG,KAAK,CAAS,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnE,MAAM;QACd,CAAC;QAED,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACK,eAAe,CAAC,KAAa,EAAE,YAAoB,CAAC;QACxD,IAAI,KAAK,GAAG,CAAC;YACT,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QAElD,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;YAC1C,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,IAAI,SAAS,CAAC;QAErD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;;OAKG;IACK,cAAc,CAAC,KAAa,EAAE,YAAoB,CAAC;QACvD,IAAI,KAAK,GAAG,CAAC;YACT,OAAO,IAAI,CAAC,eAAe,CAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QAEnD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,IAAI,SAAS,CAAC;QAErD,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ","sourcesContent":["export const enum StringType {\n    BINARY = 2,\n    DECIMAL = 10,\n    HEXADECIMAL = 16,\n}\n\n/**\n * Represents a long integer using an array of 32-bit numbers.\n * Provides static methods for bitwise operations which do not modify the original values.\n * Provides non-static equivalents to the above operations, which are carried out in place.\n */\nexport default class LongInt {\n    /** Holds the array of 32-bit numbers. */\n    public readonly data: Uint32Array;\n\n    /**\n     * Creates an instance of LongInt.\n     * @param values - A little-endian array of 32-bit numbers to fill the `LongInt`.\n     */\n    public constructor(values: number[] | Uint32Array);\n    /**\n     * Creates an instance of LongInt.\n     * @param length - The number of 32-bit numbers to construct the `LongInt` out of.\n     */\n    public constructor(length: number);\n    /**\n     * Creates an instance of LongInt.\n     * @param longInt - A `LongInt` object to duplicate.\n     */\n    public constructor(longInt: LongInt);\n    /**\n     * Creates an instance of LongInt.\n     * @param args - The arguments to construct the `LongInt` out of.\n     */\n    public constructor(args: LongInt | number[] | Uint32Array | number) {\n        if (args instanceof Array || args instanceof Uint32Array)\n            this.data = new Uint32Array(args);\n        else if (args instanceof LongInt)\n            this.data = new Uint32Array(args.data);\n        else\n            this.data = new Uint32Array(args).fill(0);\n    }\n\n    /**\n     * Gets the number of 32-bit words which make the LongInt.\n     * @returns The number of words.\n     */\n    public get wordCount(): number {\n        return this.data.length;\n    }\n\n    /**\n     * Carries out a bitwise and (&) operation on the two numbers.\n     * @param left - The left number.\n     * @param right - The right number.\n     * @returns The result of left & right.\n     */\n    public static and(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).and(right);\n    }\n\n    /**\n     * Carries out a bitwise or (|) operation on the two numbers.\n     * @param left - The left number.\n     * @param right - The right number.\n     * @returns The result of left | right.\n     */\n    public static or(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).or(right);\n    }\n\n    /**\n     * Carries out a bitwise xor (^) operation on the two numbers.\n     * @param left - The left number.\n     * @param right - The right number.\n     * @returns The result of left ^ right.\n     */\n    public static xor(left: LongInt, right: LongInt | number): LongInt {\n        return new LongInt(left).xor(right);\n    }\n\n    /**\n     * Carries out a bitwise not (~) operation on the number.\n     * @param number - The number to negate.\n     * @returns The result of ~number.\n     */\n    public static not(number: LongInt): LongInt {\n        return new LongInt(number).not();\n    }\n\n    /**\n     * Carries out a bitwise left shift (<<) operation on the number.\n     * @param number - The number to shift.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of number << shiftAmount.\n     */\n    public static leftShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).leftShift(shiftAmount);\n    }\n\n    /**\n     * Carries out a bitwise unsigned right shift (>>>) operation on the number.\n     * @param number - The number to shift.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of number >>> shiftAmount.\n     */\n    public static rightShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).rightShift(shiftAmount);\n    }\n\n    /**\n     * Carries out a bitwise arithmetic right shift (>>) operation on the number.\n     * @param number - The number to shift.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of number >> shiftAmount.\n     */\n    public static arithmeticRightShift(number: LongInt, shiftAmount: number): LongInt {\n        return new LongInt(number).arithmeticRightShift(shiftAmount);\n    }\n\n    /**\n     * Determines whether or not 2 LongInts have equal values.\n     * @param longInt1 - The first LongInt.\n     * @param longInt2 - The second LongInt (can also be a number).\n     * @returns Whether or not they are equal.\n     */\n    public static equals(longInt1: LongInt, longInt2: LongInt | number): boolean {\n        return longInt1.equals(longInt2);\n    }\n\n    /**\n     * Creates a new LongInt object with the given value, stretched or truncated to the same size as this.\n     * @param longInt - The LongInt to match the dimensions of.\n     * @param value - The LongInt object to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value: LongInt): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param longInt - The LongInt to match the dimensions of.\n     * @param values - An array of 32-bit numbers to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, values: number[] | Uint32Array): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param longInt - The LongInt to match the dimensions of.\n     * @param value - A 32-bit number to use as the value.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value?: number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param longInt - The LongInt to match the dimensions of.\n     * @param value - The value of the LongInt to create.\n     * @returns The new LongInt.\n     */\n    public static getMatchingLongInt(longInt: LongInt, value: LongInt | number[] | Uint32Array | number = 0): LongInt {\n        return new LongInt(longInt).getMatchingLongInt(value);\n    }\n\n    /**\n     * Carries out an in-place bitwise and (&) operation on this number and the one provided.\n     * @param right - The right number.\n     * @returns The new value of this & right.\n     */\n    public and(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i]! &= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise or (|) operation on this number and the one provided.\n     * @param right - The right number.\n     * @returns The new value of this | right.\n     */\n    public or(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i]! |= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise xor (^) operation on this number and the one provided.\n     * @param right - The right number.\n     * @returns The new value of this ^ right.\n     */\n    public xor(right: LongInt | number): this {\n        const rightLongInt = this.getMatchingLongInt(right);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i]! ^= rightLongInt.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise not (~) operation on this nurmbe.\n     * @returns The result of ~this.\n     */\n    public not(): this {\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] = ~this.data[i]!;\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise left shift (<<) operation on this number.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of this << shiftAmount.\n     */\n    public leftShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount > 31)\n            this.shiftArrayRight(Math.floor(shiftAmount / 32));\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = this.data.length - 1; i >= 0; i--)\n                this.data[i] = this.data[i]! << singleShiftAmount | this.data[i - 1]! >>> 32 - singleShiftAmount;\n        }\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise unsigned right shift (>>>) operation on this number.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of this >>> shiftAmount.\n     */\n    public rightShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = 0; i < this.data.length; i++)\n                this.data[i] = this.data[i]! >>> singleShiftAmount | this.data[i + 1]! << 32 - singleShiftAmount;\n        }\n\n        if (shiftAmount > 31)\n            this.shiftArrayLeft(Math.floor(shiftAmount / 32));\n\n        return this;\n    }\n\n    /**\n     * Carries out an in-place bitwise arithmetic right shift (>>) operation on this number.\n     * @param shiftAmount - The number of places to shift.\n     * @returns The result of this >> shiftAmount.\n     */\n    public arithmeticRightShift(shiftAmount: number): this {\n        if (shiftAmount === 0)\n            return this;\n\n        if (shiftAmount !== 32) {\n            const singleShiftAmount = shiftAmount % 32;\n\n            for (let i = 0; i < this.data.length; i++)\n                this.data[i] = this.data[i]! >> singleShiftAmount | this.data[i + 1]! << 32 - singleShiftAmount;\n        }\n\n        if (shiftAmount > 31)\n            this.shiftArrayLeft(Math.floor(shiftAmount / 32), ~0 >>> 0);\n\n        return this;\n    }\n\n    /**\n     * Determines whether or not this LongInt has equal value to another.\n     * @param value - The LongInt or number to compare to.\n     * @returns Whether or not they are equal.\n     */\n    public equals(value: LongInt | number): boolean {\n        const longInt = value instanceof LongInt ? value : new LongInt([value]);\n        const longestLongInt = this.data.length > longInt.data.length ? this : longInt;\n        const longInt1 = LongInt.getMatchingLongInt(longestLongInt, this);\n        const longInt2 = LongInt.getMatchingLongInt(longestLongInt, longInt);\n\n        for (let i = 0; i < longestLongInt.data.length; i++) {\n            if (longInt1.data[i] !== longInt2.data[i])\n                return false;\n        }\n\n        return true;\n    }\n\n    /**\n     * Returns a string representation of the LongInt.\n     * @param type - The base of the string to print.\n     * @returns The string representation.\n     */\n    public toString(type: StringType): string {\n        let padLength = 0;\n\n        switch (type) {\n            case StringType.BINARY:\n                padLength = 32;\n                break;\n            case StringType.DECIMAL:\n                padLength = 10;\n                break;\n            case StringType.HEXADECIMAL:\n                padLength = 8;\n                break;\n        }\n\n        return [...this.data]\n            .reverse()\n            .map((num) => num.toString(type).padStart(padLength, \"0\"))\n            .join(\" \");\n    }\n\n    /**\n     * Creates a new LongInt object with the given value, stretched or truncated to the same size as this.\n     * @param longInt - The LongInt object to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(longInt: LongInt): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param values - An array of 32-bit numbers to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(values: number[] | Uint32Array): LongInt;\n    /**\n     * Creates a new LongInt object using the given value, stretched or truncated to the same size as this.\n     * @param value - A 32-bit number to use as the value.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value?: number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param value - The value of the LongInt to create.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value: LongInt | number[] | Uint32Array | number): LongInt;\n    /**\n     * Creates a LongInt with the same dimensions as this one, using the given input.\n     * @param value - The value of the LongInt to create.\n     * @returns The new LongInt.\n     */\n    private getMatchingLongInt(value: LongInt | number[] | Uint32Array | number = 0): LongInt {\n        let integers: number[] | Uint32Array = [];\n\n        switch (true) {\n            case value instanceof Uint32Array:\n                if (value.length < this.data.length)\n                    integers = [...value, ...Array<number>(this.data.length - value.length).fill(0)];\n                else if (value.length > this.data.length)\n                    integers = value.slice(0, this.data.length);\n                else\n                    integers = value;\n\n                break;\n            case value instanceof LongInt:\n                if (value.data.length < this.data.length)\n                    integers = [...value.data, ...Array<number>(this.data.length - value.data.length).fill(0)];\n                else if (value.data.length > this.data.length)\n                    integers = value.data.slice(0, this.data.length);\n                else\n                    integers = value.data;\n\n                break;\n            case value instanceof Array:\n                if (value.length < this.data.length)\n                    integers = [...value, ...Array<number>(this.data.length - value.length).fill(0)];\n                else if (value.length > this.data.length)\n                    integers = value.slice(0, this.data.length);\n                else\n                    integers = value;\n\n                break;\n            default:\n                integers = [value, ...Array<number>(this.data.length - 1).fill(0)];\n                break;\n        }\n\n        return new LongInt(integers);\n    }\n\n    /**\n     * Shifts the 32-bit number array to the right.\n     * @param count - How many places to shift the array.\n     * @param fillValue - The value to fill empty spaces with.\n     * @returns The new value of this.\n     */\n    private shiftArrayRight(count: number, fillValue: number = 0): this {\n        if (count < 0)\n            return this.shiftArrayLeft(-count, fillValue);\n\n        for (let i = this.data.length - 1; i >= 0; i--)\n            this.data[i] = this.data[i - count] ?? fillValue;\n\n        return this;\n    }\n\n    /**\n     * Shifts the 32-bit number array to the left.\n     * @param count - How many places to shift the array.\n     * @param fillValue - The value to fill empty spaces with.\n     * @returns The new value of this.\n     */\n    private shiftArrayLeft(count: number, fillValue: number = 0): this {\n        if (count < 0)\n            return this.shiftArrayRight(-count, fillValue);\n\n        for (let i = 0; i < this.data.length; i++)\n            this.data[i] = this.data[i + count] ?? fillValue;\n\n        return this;\n    }\n}\n"]}
|
|
@@ -4,43 +4,43 @@ import LongInt from "./longInt.js";
|
|
|
4
4
|
export default class LongIntBitBoard extends BitBoard<LongInt> {
|
|
5
5
|
/**
|
|
6
6
|
* Creates an instance of LongIntBitBoard.
|
|
7
|
-
* @param longInt The data to fill the BitBoard with.
|
|
8
|
-
|
|
7
|
+
* @param longInt - The data to fill the BitBoard with.
|
|
8
|
+
*/
|
|
9
9
|
constructor(longInt: LongInt);
|
|
10
10
|
/**
|
|
11
11
|
* Creates an instance of LongIntBitBoard.
|
|
12
|
-
* @param uint32Array The data to fill the BitBoard with.
|
|
12
|
+
* @param uint32Array - The data to fill the BitBoard with.
|
|
13
13
|
*/
|
|
14
14
|
constructor(uint32Array: Uint32Array);
|
|
15
15
|
/**
|
|
16
16
|
* Creates an instance of LongIntBitBoard.
|
|
17
|
-
* @param numberArray The data to fill the BitBoard with.
|
|
17
|
+
* @param numberArray - The data to fill the BitBoard with.
|
|
18
18
|
*/
|
|
19
19
|
constructor(numberArray: number[]);
|
|
20
20
|
/**
|
|
21
21
|
* Creates an instance of LongIntBitBoard.
|
|
22
|
-
* @param length The length of the LongInt.
|
|
22
|
+
* @param length - The length of the LongInt array.
|
|
23
23
|
*/
|
|
24
24
|
constructor(length: number);
|
|
25
25
|
/**
|
|
26
26
|
* Gets the value of a given bit.
|
|
27
|
-
* @param bit The bit to get.
|
|
27
|
+
* @param bit - The bit to get.
|
|
28
28
|
* @returns The value of the bit.
|
|
29
29
|
*/
|
|
30
30
|
getBit(bit: number): 0 | 1;
|
|
31
31
|
/**
|
|
32
32
|
* Sets the value for a given bit to 1.
|
|
33
|
-
* @param bit The bit to set.
|
|
33
|
+
* @param bit - The bit to set.
|
|
34
34
|
*/
|
|
35
35
|
setBit(bit: number): void;
|
|
36
36
|
/**
|
|
37
37
|
* Sets the value for a given bit to 0.
|
|
38
|
-
* @param bit The bit to clear.
|
|
38
|
+
* @param bit - The bit to clear.
|
|
39
39
|
*/
|
|
40
40
|
clearBit(bit: number): void;
|
|
41
41
|
/**
|
|
42
42
|
* Toggles the data for a given bit between 0 and 1.
|
|
43
|
-
* @param bit The bit to toggle.
|
|
43
|
+
* @param bit - The bit to toggle.
|
|
44
44
|
*/
|
|
45
45
|
toggleBit(bit: number): void;
|
|
46
46
|
/** Sets all bits to 0. */
|
|
@@ -49,55 +49,55 @@ export default class LongIntBitBoard extends BitBoard<LongInt> {
|
|
|
49
49
|
setAll(): void;
|
|
50
50
|
/**
|
|
51
51
|
* Gets a given number of bits.
|
|
52
|
-
* @param LSB The least significant bit to get.
|
|
53
|
-
* @param numberOfBits The number of bits to get.
|
|
54
|
-
* @returns The bits.
|
|
52
|
+
* @param LSB - The least significant bit to get.
|
|
53
|
+
* @param numberOfBits - The number of bits to get.
|
|
54
|
+
* @returns The bits as a number.
|
|
55
55
|
*/
|
|
56
56
|
getBits(LSB: number, numberOfBits: number): LongInt;
|
|
57
57
|
/**
|
|
58
58
|
* Carries out a bitwise and (&) operation.
|
|
59
|
-
* @param right The right value.
|
|
59
|
+
* @param right - The right value.
|
|
60
60
|
* @returns The result.
|
|
61
61
|
*/
|
|
62
|
-
and(right: LongIntBitBoard | number):
|
|
62
|
+
and(right: LongIntBitBoard | number): LongIntBitBoard;
|
|
63
63
|
/**
|
|
64
64
|
* Carries out a bitwise or (|) operation.
|
|
65
|
-
* @param right The right value.
|
|
65
|
+
* @param right - The right value.
|
|
66
66
|
* @returns The result.
|
|
67
67
|
*/
|
|
68
|
-
or(right: LongIntBitBoard | number):
|
|
68
|
+
or(right: LongIntBitBoard | number): LongIntBitBoard;
|
|
69
69
|
/**
|
|
70
70
|
* Carries out a bitwise xor (^) operation.
|
|
71
|
-
* @param right The right value.
|
|
71
|
+
* @param right - The right value.
|
|
72
72
|
* @returns The result.
|
|
73
73
|
*/
|
|
74
|
-
xor(right: LongIntBitBoard | number):
|
|
74
|
+
xor(right: LongIntBitBoard | number): LongIntBitBoard;
|
|
75
75
|
/**
|
|
76
76
|
* Carries out a bitwise not (~) operation.
|
|
77
77
|
* @returns The result.
|
|
78
78
|
*/
|
|
79
|
-
not():
|
|
79
|
+
not(): LongIntBitBoard;
|
|
80
80
|
/**
|
|
81
81
|
* Carries out a bitwise left shift (<<) operation.
|
|
82
|
-
* @param shiftAmount How much to shift it by.
|
|
82
|
+
* @param shiftAmount - How much to shift it by.
|
|
83
83
|
* @returns The result.
|
|
84
84
|
*/
|
|
85
|
-
leftShift(shiftAmount: number):
|
|
85
|
+
leftShift(shiftAmount: number): LongIntBitBoard;
|
|
86
86
|
/**
|
|
87
87
|
* Carries out a bitwise logical right shift (>>>) operation.
|
|
88
|
-
* @param shiftAmount How much to shift it by.
|
|
88
|
+
* @param shiftAmount - How much to shift it by.
|
|
89
89
|
* @returns The result.
|
|
90
90
|
*/
|
|
91
|
-
rightShift(shiftAmount: number):
|
|
91
|
+
rightShift(shiftAmount: number): LongIntBitBoard;
|
|
92
92
|
/**
|
|
93
93
|
* Carries out a bitwise arithmetic right shift (>>) operation.
|
|
94
|
-
* @param shiftAmount How much to shift it by.
|
|
94
|
+
* @param shiftAmount - How much to shift it by.
|
|
95
95
|
* @returns The result.
|
|
96
96
|
*/
|
|
97
|
-
arithmeticRightShift(shiftAmount: number):
|
|
97
|
+
arithmeticRightShift(shiftAmount: number): LongIntBitBoard;
|
|
98
98
|
/**
|
|
99
99
|
* Checks if two BitBoards have equal data values.
|
|
100
|
-
* @param value The value to compare against.
|
|
100
|
+
* @param value - The value to compare against.
|
|
101
101
|
* @returns Whether or not the two BitBoard have the same data value.
|
|
102
102
|
*/
|
|
103
103
|
equals(value: LongInt | LongIntBitBoard | number): boolean;
|