@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.
@@ -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
- /** Gets the number of 32-bit words which make the LongInt. */
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): this;
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): this;
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): this;
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(): this;
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): this;
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): this;
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): this;
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;