15 lines
599 B
JavaScript
15 lines
599 B
JavaScript
import { toHex, fromHex } from '@exodus/bytes/hex.js'
|
|
import { assert } from './fallback/_utils.js'
|
|
|
|
const _0n = BigInt(0)
|
|
|
|
export function fromBigInt(x, { length, format } = {}) {
|
|
assert(Number.isSafeInteger(length) && length > 0, 'Expected length arg to be a positive integer')
|
|
assert(typeof x === 'bigint' && x >= _0n, 'Expected a non-negative bigint')
|
|
const hex = x.toString(16)
|
|
assert(length * 2 >= hex.length, `Can not fit supplied number into ${length} bytes`)
|
|
return fromHex(hex.padStart(length * 2, '0'), format)
|
|
}
|
|
|
|
export const toBigInt = (a) => BigInt('0x' + (toHex(a) || '0'))
|