@bsv/sdk 1.6.7 → 1.6.8
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/dist/cjs/package.json +1 -1
- package/dist/cjs/src/primitives/utils.js +18 -2
- package/dist/cjs/src/primitives/utils.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/primitives/utils.js +18 -2
- package/dist/esm/src/primitives/utils.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/types/src/primitives/utils.d.ts +2 -1
- package/dist/types/src/primitives/utils.d.ts.map +1 -1
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/dist/umd/bundle.js +1 -1
- package/docs/primitives.md +2 -1
- package/package.json +1 -1
- package/src/primitives/utils.ts +20 -2
package/docs/primitives.md
CHANGED
|
@@ -3229,7 +3229,8 @@ export class Reader {
|
|
|
3229
3229
|
public readInt32LE(): number
|
|
3230
3230
|
public readUInt64BEBn(): BigNumber
|
|
3231
3231
|
public readUInt64LEBn(): BigNumber
|
|
3232
|
-
public
|
|
3232
|
+
public readInt64LEBn(): BigNumber
|
|
3233
|
+
public readVarIntNum(signed: boolean = true): number
|
|
3233
3234
|
public readVarInt(): number[]
|
|
3234
3235
|
public readVarIntBn(): BigNumber
|
|
3235
3236
|
}
|
package/package.json
CHANGED
package/src/primitives/utils.ts
CHANGED
|
@@ -525,6 +525,9 @@ export class Writer {
|
|
|
525
525
|
|
|
526
526
|
static varIntNum (n: number): number[] {
|
|
527
527
|
let buf: number[]
|
|
528
|
+
if (n < 0) {
|
|
529
|
+
return this.varIntBn(new BigNumber(n))
|
|
530
|
+
}
|
|
528
531
|
if (n < 253) {
|
|
529
532
|
buf = [n] // 1 byte
|
|
530
533
|
} else if (n < 0x10000) {
|
|
@@ -565,6 +568,9 @@ export class Writer {
|
|
|
565
568
|
|
|
566
569
|
static varIntBn (bn: BigNumber): number[] {
|
|
567
570
|
let buf: number[]
|
|
571
|
+
if (bn.isNeg()) {
|
|
572
|
+
bn = bn.add(OverflowUint64) // Adjust for negative numbers
|
|
573
|
+
}
|
|
568
574
|
if (bn.ltn(253)) {
|
|
569
575
|
const n = bn.toNumber()
|
|
570
576
|
// No need for bitwise operation as the value is within a byte's range
|
|
@@ -708,7 +714,16 @@ export class Reader {
|
|
|
708
714
|
return bn
|
|
709
715
|
}
|
|
710
716
|
|
|
711
|
-
public
|
|
717
|
+
public readInt64LEBn (): BigNumber {
|
|
718
|
+
const bin = this.readReverse(8)
|
|
719
|
+
let bn = new BigNumber(bin)
|
|
720
|
+
if (bn.gte(OverflowInt64)) {
|
|
721
|
+
bn = bn.sub(OverflowUint64) // Adjust for negative numbers
|
|
722
|
+
}
|
|
723
|
+
return bn
|
|
724
|
+
}
|
|
725
|
+
|
|
726
|
+
public readVarIntNum (signed: boolean = true): number {
|
|
712
727
|
const first = this.readUInt8()
|
|
713
728
|
let bn: BigNumber
|
|
714
729
|
switch (first) {
|
|
@@ -717,7 +732,7 @@ export class Reader {
|
|
|
717
732
|
case 0xfe:
|
|
718
733
|
return this.readUInt32LE()
|
|
719
734
|
case 0xff:
|
|
720
|
-
bn = this.readUInt64LEBn()
|
|
735
|
+
bn = signed ? this.readInt64LEBn() : this.readUInt64LEBn()
|
|
721
736
|
if (bn.lte(new BigNumber(2).pow(new BigNumber(53)))) {
|
|
722
737
|
return bn.toNumber()
|
|
723
738
|
} else {
|
|
@@ -801,3 +816,6 @@ export const minimallyEncode = (buf: number[]): number[] => {
|
|
|
801
816
|
// If we found the whole thing is zeros, then we have a zero.
|
|
802
817
|
return []
|
|
803
818
|
}
|
|
819
|
+
|
|
820
|
+
const OverflowInt64 = new BigNumber(2).pow(new BigNumber(63))
|
|
821
|
+
const OverflowUint64 = new BigNumber(2).pow(new BigNumber(64))
|