|
1 |
| -type t = Js.Types.bigint_val |
| 1 | +@val external asIntN: (~width: int, bigint) => bigint = "BigInt.asIntN" |
| 2 | +@val external asUintN: (~width: int, bigint) => bigint = "BigInt.asUintN" |
2 | 3 |
|
3 |
| -@val external asIntN: (~width: int, t) => t = "BigInt.asIntN" |
4 |
| -@val external asUintN: (~width: int, t) => t = "BigInt.asUintN" |
| 4 | +@val external fromString: string => bigint = "BigInt" |
5 | 5 |
|
6 |
| -@val external fromString: string => t = "BigInt" |
7 |
| -@val external fromInt: int => t = "BigInt" |
8 |
| -@val external fromFloat: float => t = "BigInt" |
| 6 | +@val |
| 7 | +/** |
| 8 | +Parses the given `string` into a `bigint` using JavaScript semantics. Return the |
| 9 | +number as a `bigint` if successfully parsed. Uncaught syntax exception otherwise. |
9 | 10 |
|
10 |
| -@send external toString: t => string = "toString" |
11 |
| -@send external toStringWithRadix: (t, ~radix: int) => string = "toString" |
12 |
| -@send external toLocaleString: t => string = "toLocaleString" |
| 11 | +## Examples |
13 | 12 |
|
14 |
| -@val external toFloat: t => float = "Number" |
| 13 | +```rescript |
| 14 | +/* returns 123n */ |
| 15 | +BigInt.fromStringExn("123") |
| 16 | +
|
| 17 | +/* returns 0n */ |
| 18 | +BigInt.fromStringExn("") |
| 19 | +
|
| 20 | +/* returns 17n */ |
| 21 | +BigInt.fromStringExn("0x11") |
| 22 | +
|
| 23 | +/* returns 3n */ |
| 24 | +BigInt.fromStringExn("0b11") |
| 25 | +
|
| 26 | +/* returns 9n */ |
| 27 | +BigInt.fromStringExn("0o11") |
| 28 | +
|
| 29 | +/* catch exception */ |
| 30 | +try { |
| 31 | + BigInt.fromStringExn("a") |
| 32 | +} catch { |
| 33 | +| Exn.Error(_error) => 0n |
| 34 | +} |
| 35 | +``` |
| 36 | +*/ |
| 37 | +external fromStringExn: string => bigint = "BigInt" |
| 38 | +@val external fromInt: int => bigint = "BigInt" |
| 39 | +@val external fromFloat: float => bigint = "BigInt" |
| 40 | + |
| 41 | +@send |
| 42 | +/** |
| 43 | +Formats a `bigint` as a string. Return a `string` representing the given value. |
| 44 | +See [`toString`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toString) on MDN. |
| 45 | +
|
| 46 | +## Examples |
| 47 | +
|
| 48 | +```rescript |
| 49 | +/* prints "123" */ |
| 50 | +Js.BigInt.toString(123n)->Js.log |
| 51 | +``` |
| 52 | +*/ |
| 53 | +external toString: bigint => string = "toString" |
| 54 | +@send external toStringWithRadix: (bigint, ~radix: int) => string = "toString" |
| 55 | + |
| 56 | +@send |
| 57 | +/** |
| 58 | +Returns a string with a language-sensitive representation of this BigInt value. |
| 59 | +
|
| 60 | +## Examples |
| 61 | +
|
| 62 | +```rescript |
| 63 | +/* prints "123" */ |
| 64 | +Js.BigInt.toString(123n)->Js.log |
| 65 | +``` |
| 66 | +*/ |
| 67 | +external toLocaleString: bigint => string = "toLocaleString" |
| 68 | + |
| 69 | +@val external toFloat: bigint => float = "Number" |
15 | 70 |
|
16 | 71 | let toInt = t => t->toFloat->Core__Int.fromFloat
|
17 | 72 |
|
18 |
| -external \"+": (t, t) => t = "%addfloat" |
19 |
| -external \"-": (t, t) => t = "%subfloat" |
20 |
| -external \"*": (t, t) => t = "%mulfloat" |
21 |
| -external \"/": (t, t) => t = "%divfloat" |
| 73 | +external \"+": (bigint, bigint) => bigint = "%addbigint" |
| 74 | +external \"-": (bigint, bigint) => bigint = "%subbigint" |
| 75 | +external \"*": (bigint, bigint) => bigint = "%mulbigint" |
| 76 | +external \"/": (bigint, bigint) => bigint = "%divbigint" |
| 77 | +external \"~-": bigint => bigint = "%negbigint" |
| 78 | +external \"~+": bigint => bigint = "%identity" |
| 79 | +external \"**": (bigint, bigint) => bigint = "%powbigint" |
22 | 80 |
|
23 |
| -external add: (t, t) => t = "%addfloat" |
24 |
| -external sub: (t, t) => t = "%subfloat" |
25 |
| -external mul: (t, t) => t = "%mulfloat" |
26 |
| -external div: (t, t) => t = "%divfloat" |
| 81 | +external add: (bigint, bigint) => bigint = "%addfloat" |
| 82 | +external sub: (bigint, bigint) => bigint = "%subfloat" |
| 83 | +external mul: (bigint, bigint) => bigint = "%mulfloat" |
| 84 | +external div: (bigint, bigint) => bigint = "%divfloat" |
27 | 85 |
|
28 |
| -@noalloc external mod: (t, t) => t = "?fmod_float" |
| 86 | +external mod: (bigint, bigint) => bigint = "%modbigint" |
29 | 87 |
|
30 |
| -external land: (t, t) => t = "%andint" |
31 |
| -external lor: (t, t) => t = "%orint" |
32 |
| -external lxor: (t, t) => t = "%xorint" |
| 88 | +external land: (bigint, bigint) => bigint = "%andbigint" |
| 89 | +external lor: (bigint, bigint) => bigint = "%orbigint" |
| 90 | +external lxor: (bigint, bigint) => bigint = "%xorbigint" |
33 | 91 |
|
34 |
| -external lsl: (t, t) => t = "%lslint" |
35 |
| -external asr: (t, t) => t = "%asrint" |
| 92 | +external lsl: (bigint, bigint) => bigint = "%lslbigint" |
| 93 | +external asr: (bigint, bigint) => bigint = "%asrbigint" |
36 | 94 |
|
37 |
| -let exp = (x: t, y: t) => { |
38 |
| - let _ = x |
39 |
| - let _ = y |
40 |
| - %raw(`x ** y`) |
41 |
| -} |
| 95 | +let lnot = x => lxor(x, -1n) |
0 commit comments