2017-11-17 03:07:17 +01:00
|
|
|
// Copyright (C) 2017 Caio Lima. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
|
|
|
|
/*---
|
|
|
|
description: String should be parsed to BigInt according StringToBigInt
|
|
|
|
esid: sec-string-to-bigint
|
|
|
|
info: |
|
2018-04-18 22:56:06 +02:00
|
|
|
ToBigInt ( argument )
|
2017-11-17 03:07:17 +01:00
|
|
|
|
2018-04-18 22:56:06 +02:00
|
|
|
String:
|
|
|
|
|
|
|
|
Let n be StringToBigInt(prim).
|
|
|
|
If n is NaN, throw a SyntaxError exception.
|
|
|
|
Return n.
|
|
|
|
|
|
|
|
StringToBigInt ( argument )
|
|
|
|
|
|
|
|
Replace the StrUnsignedDecimalLiteral production with DecimalDigits to not allow Infinity, decimal points, or exponents.
|
2017-11-17 03:07:17 +01:00
|
|
|
|
|
|
|
features: [BigInt]
|
|
|
|
---*/
|
|
|
|
|
|
|
|
assert.sameValue(BigInt("10"), 10n);
|
|
|
|
assert.sameValue(BigInt("18446744073709551616"), 18446744073709551616n);
|
|
|
|
assert.sameValue(BigInt("7"), 7n);
|
|
|
|
assert.sameValue(BigInt("88"), 88n);
|
|
|
|
assert.sameValue(BigInt("900"), 900n);
|
|
|
|
|
|
|
|
assert.sameValue(BigInt("-10"), -10n);
|
|
|
|
assert.sameValue(BigInt("-18446744073709551616"), -18446744073709551616n);
|
|
|
|
assert.sameValue(BigInt("-7"), -7n);
|
|
|
|
assert.sameValue(BigInt("-88"), -88n);
|
|
|
|
assert.sameValue(BigInt("-900"), -900n);
|