Skip to content

Commit

Permalink
fix(controller-utils): use overload signatures where appropriate
Browse files Browse the repository at this point in the history
  • Loading branch information
legobeat committed Oct 24, 2024
1 parent bbfeddc commit adaf327
Showing 1 changed file with 18 additions and 4 deletions.
22 changes: 18 additions & 4 deletions packages/controller-utils/src/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,10 +70,12 @@ export function isSafeChainId(chainId: Hex): boolean {
*/
// TODO: Either fix this lint violation or explain why it's necessary to ignore.
// eslint-disable-next-line @typescript-eslint/naming-convention
export function BNToHex(inputBn: BN | BN4 | BigNumber) {
export function BNToHex(inputBn: BN | BN4 | BigNumber): string {
return add0x(inputBn.toString(16));
}

function getBNImplementation(targetBN: BN4): typeof BN4;
function getBNImplementation(targetBN: BN): typeof BN;
/**
* Return the bn.js library responsible for the BN in question
* @param targetBN - A BN instance
Expand All @@ -83,6 +85,16 @@ function getBNImplementation(targetBN: BN | BN4): typeof BN4 | typeof BN {
return Object.keys(targetBN).includes('_strip') ? BN4 : BN;
}

export function fractionBN(
targetBN: BN,
numerator: number | string,
denominator: number | string,
): BN;
export function fractionBN(
targetBN: BN4,
numerator: number | string,
denominator: number | string,
): BN4;
/**
* Used to multiply a BN by a fraction.
*
Expand All @@ -95,13 +107,13 @@ export function fractionBN(
targetBN: BN | BN4,
numerator: number | string,
denominator: number | string,
) {
): BN | BN4 {
// @ts-expect-error - Signature overload confusion
const BNImplementation = getBNImplementation(targetBN);

// @ts-expect-error - Incompatible constructor signatures are actually compatible here
const numBN = new BNImplementation(numerator);
// @ts-expect-error - Incompatible constructor signatures are actually compatible here
const denomBN = new BNImplementation(denominator);
// @ts-expect-error - BNImplementation gets unexpected typed
return targetBN.mul(numBN).div(denomBN);
}

Expand Down Expand Up @@ -206,6 +218,8 @@ export function hexToText(hex: string) {
}
}

export function fromHex(value: string | BN): BN;
export function fromHex(value: BN4): BN4;
/**
* Parses a hex string and converts it into a number that can be operated on in a bignum-safe,
* base-10 way.
Expand Down

0 comments on commit adaf327

Please sign in to comment.