aboutsummaryrefslogtreecommitdiff
path: root/src/tools/integer-base-converter/integer-base-converter.model.ts
diff options
context:
space:
mode:
authorGravatar sharevb <sharevb@gmail.com> 2024-04-22 08:45:51 +0200
committerGravatar GitHub <noreply@github.com> 2024-04-22 08:45:51 +0200
commit9eac9cb2a9d23619b0d3c044f1bc1385aab427e4 (patch)
tree683fb9d70adea3d82ce384b40264d5972ebbc33c /src/tools/integer-base-converter/integer-base-converter.model.ts
parent23f82d956a8af21e176f7268c9414244168bd4eb (diff)
downloadit-tools-9eac9cb2a9d23619b0d3c044f1bc1385aab427e4.tar.gz
it-tools-9eac9cb2a9d23619b0d3c044f1bc1385aab427e4.tar.zst
it-tools-9eac9cb2a9d23619b0d3c044f1bc1385aab427e4.zip
fix(integer base converter): support bigint (#872)
Diffstat (limited to 'src/tools/integer-base-converter/integer-base-converter.model.ts')
-rw-r--r--src/tools/integer-base-converter/integer-base-converter.model.ts10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/tools/integer-base-converter/integer-base-converter.model.ts b/src/tools/integer-base-converter/integer-base-converter.model.ts
index b4470e5..da0fe77 100644
--- a/src/tools/integer-base-converter/integer-base-converter.model.ts
+++ b/src/tools/integer-base-converter/integer-base-converter.model.ts
@@ -5,16 +5,16 @@ export function convertBase({ value, fromBase, toBase }: { value: string; fromBa
let decValue = value
.split('')
.reverse()
- .reduce((carry: number, digit: string, index: number) => {
+ .reduce((carry: bigint, digit: string, index: number) => {
if (!fromRange.includes(digit)) {
throw new Error(`Invalid digit "${digit}" for base ${fromBase}.`);
}
- return (carry += fromRange.indexOf(digit) * fromBase ** index);
- }, 0);
+ return (carry += BigInt(fromRange.indexOf(digit)) * BigInt(fromBase) ** BigInt(index));
+ }, 0n);
let newValue = '';
while (decValue > 0) {
- newValue = toRange[decValue % toBase] + newValue;
- decValue = (decValue - (decValue % toBase)) / toBase;
+ newValue = toRange[Number(decValue % BigInt(toBase))] + newValue;
+ decValue = (decValue - (decValue % BigInt(toBase))) / BigInt(toBase);
}
return newValue || '0';
}