UNPKG

bitcoin-convert

Version:

Conversion between the bitcoin base unit (BTC) and other units (Satoshi, μBTC, ...)

1,688 lines (1,411 loc) 299 kB
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.btcConvert = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ 'use strict'; require('babel-polyfill'); module.exports = require('./lib/convert'); },{"./lib/convert":2,"babel-polyfill":3}],2:[function(require,module,exports){ 'use strict'; var Big = require('big.js'); var units = { 'BTC': new Big(1), 'mBTC': new Big(0.001), 'μBTC': new Big(0.000001), 'bit': new Big(0.000001), 'Satoshi': new Big(0.00000001), 'sat': new Big(0.00000001) }; function convert(from, fromUnit, toUnit, representation) { var fromFactor = units[fromUnit]; if (fromFactor === undefined) { throw new Error('\'' + fromUnit + '\' is not a bitcoin unit'); } var toFactor = units[toUnit]; if (toFactor === undefined) { throw new Error('\'' + toUnit + '\' is not a bitcoin unit'); } if (Number.isNaN(from)) { if (!representation || representation === 'Number') { return from; } else if (representation === 'Big') { return new Big(from); // throws BigError } else if (representation === 'String') { return from.toString(); } throw new Error('\'' + representation + '\' is not a valid representation'); } var result = new Big(from).times(fromFactor).div(toFactor); if (!representation || representation === 'Number') { return Number(result); } else if (representation === 'Big') { return result; } else if (representation === 'String') { return result.toString(); } throw new Error('\'' + representation + '\' is not a valid representation'); } convert.units = function () { return Object.keys(units); }; convert.addUnit = function addUnit(unit, factor) { factor = new Big(factor); var existing = units[unit]; if (existing && !existing.eq(factor)) { throw new Error('\'' + unit + '\' already exists with a different conversion factor'); } units[unit] = factor; }; var predefinedUnits = convert.units(); convert.removeUnit = function removeUnit(unit) { if (predefinedUnits.indexOf(unit) >= 0) { throw new Error('\'' + unit + '\' is predefined and cannot be removed'); } delete units[unit]; }; module.exports = convert; },{"big.js":4}],3:[function(require,module,exports){ (function (global){ "use strict"; require("core-js/shim"); require("regenerator-runtime/runtime"); require("core-js/fn/regexp/escape"); if (global._babelPolyfill) { throw new Error("only one instance of babel-polyfill is allowed"); } global._babelPolyfill = true; var DEFINE_PROPERTY = "defineProperty"; function define(O, key, value) { O[key] || Object[DEFINE_PROPERTY](O, key, { writable: true, configurable: true, value: value }); } define(String.prototype, "padLeft", "".padStart); define(String.prototype, "padRight", "".padEnd); "pop,reverse,shift,keys,values,entries,indexOf,every,some,forEach,map,filter,find,findIndex,includes,join,slice,concat,push,splice,unshift,sort,lastIndexOf,reduce,reduceRight,copyWithin,fill".split(",").forEach(function (key) { [][key] && define(Array, key, Function.call.bind([][key])); }); }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"core-js/fn/regexp/escape":5,"core-js/shim":298,"regenerator-runtime/runtime":300}],4:[function(require,module,exports){ /* big.js v3.1.3 https://github.com/MikeMcl/big.js/LICENCE */ ;(function (global) { 'use strict'; /* big.js v3.1.3 A small, fast, easy-to-use library for arbitrary-precision decimal arithmetic. https://github.com/MikeMcl/big.js/ Copyright (c) 2014 Michael Mclaughlin <M8ch88l@gmail.com> MIT Expat Licence */ /***************************** EDITABLE DEFAULTS ******************************/ // The default values below must be integers within the stated ranges. /* * The maximum number of decimal places of the results of operations * involving division: div and sqrt, and pow with negative exponents. */ var DP = 20, // 0 to MAX_DP /* * The rounding mode used when rounding to the above decimal places. * * 0 Towards zero (i.e. truncate, no rounding). (ROUND_DOWN) * 1 To nearest neighbour. If equidistant, round up. (ROUND_HALF_UP) * 2 To nearest neighbour. If equidistant, to even. (ROUND_HALF_EVEN) * 3 Away from zero. (ROUND_UP) */ RM = 1, // 0, 1, 2 or 3 // The maximum value of DP and Big.DP. MAX_DP = 1E6, // 0 to 1000000 // The maximum magnitude of the exponent argument to the pow method. MAX_POWER = 1E6, // 1 to 1000000 /* * The exponent value at and beneath which toString returns exponential * notation. * JavaScript's Number type: -7 * -1000000 is the minimum recommended exponent value of a Big. */ E_NEG = -7, // 0 to -1000000 /* * The exponent value at and above which toString returns exponential * notation. * JavaScript's Number type: 21 * 1000000 is the maximum recommended exponent value of a Big. * (This limit is not enforced or checked.) */ E_POS = 21, // 0 to 1000000 /******************************************************************************/ // The shared prototype object. P = {}, isValid = /^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i, Big; /* * Create and return a Big constructor. * */ function bigFactory() { /* * The Big constructor and exported function. * Create and return a new instance of a Big number object. * * n {number|string|Big} A numeric value. */ function Big(n) { var x = this; // Enable constructor usage without new. if (!(x instanceof Big)) { return n === void 0 ? bigFactory() : new Big(n); } // Duplicate. if (n instanceof Big) { x.s = n.s; x.e = n.e; x.c = n.c.slice(); } else { parse(x, n); } /* * Retain a reference to this Big constructor, and shadow * Big.prototype.constructor which points to Object. */ x.constructor = Big; } Big.prototype = P; Big.DP = DP; Big.RM = RM; Big.E_NEG = E_NEG; Big.E_POS = E_POS; return Big; } // Private functions /* * Return a string representing the value of Big x in normal or exponential * notation to dp fixed decimal places or significant digits. * * x {Big} The Big to format. * dp {number} Integer, 0 to MAX_DP inclusive. * toE {number} 1 (toExponential), 2 (toPrecision) or undefined (toFixed). */ function format(x, dp, toE) { var Big = x.constructor, // The index (normal notation) of the digit that may be rounded up. i = dp - (x = new Big(x)).e, c = x.c; // Round? if (c.length > ++dp) { rnd(x, i, Big.RM); } if (!c[0]) { ++i; } else if (toE) { i = dp; // toFixed } else { c = x.c; // Recalculate i as x.e may have changed if value rounded up. i = x.e + i + 1; } // Append zeros? for (; c.length < i; c.push(0)) { } i = x.e; /* * toPrecision returns exponential notation if the number of * significant digits specified is less than the number of digits * necessary to represent the integer part of the value in normal * notation. */ return toE === 1 || toE && (dp <= i || i <= Big.E_NEG) ? // Exponential notation. (x.s < 0 && c[0] ? '-' : '') + (c.length > 1 ? c[0] + '.' + c.join('').slice(1) : c[0]) + (i < 0 ? 'e' : 'e+') + i // Normal notation. : x.toString(); } /* * Parse the number or string value passed to a Big constructor. * * x {Big} A Big number instance. * n {number|string} A numeric value. */ function parse(x, n) { var e, i, nL; // Minus zero? if (n === 0 && 1 / n < 0) { n = '-0'; // Ensure n is string and check validity. } else if (!isValid.test(n += '')) { throwErr(NaN); } // Determine sign. x.s = n.charAt(0) == '-' ? (n = n.slice(1), -1) : 1; // Decimal point? if ((e = n.indexOf('.')) > -1) { n = n.replace('.', ''); } // Exponential form? if ((i = n.search(/e/i)) > 0) { // Determine exponent. if (e < 0) { e = i; } e += +n.slice(i + 1); n = n.substring(0, i); } else if (e < 0) { // Integer. e = n.length; } // Determine leading zeros. for (i = 0; n.charAt(i) == '0'; i++) { } if (i == (nL = n.length)) { // Zero. x.c = [ x.e = 0 ]; } else { // Determine trailing zeros. for (; n.charAt(--nL) == '0';) { } x.e = e - i - 1; x.c = []; // Convert string to array of digits without leading/trailing zeros. for (e = 0; i <= nL; x.c[e++] = +n.charAt(i++)) { } } return x; } /* * Round Big x to a maximum of dp decimal places using rounding mode rm. * Called by div, sqrt and round. * * x {Big} The Big to round. * dp {number} Integer, 0 to MAX_DP inclusive. * rm {number} 0, 1, 2 or 3 (DOWN, HALF_UP, HALF_EVEN, UP) * [more] {boolean} Whether the result of division was truncated. */ function rnd(x, dp, rm, more) { var u, xc = x.c, i = x.e + dp + 1; if (rm === 1) { // xc[i] is the digit after the digit that may be rounded up. more = xc[i] >= 5; } else if (rm === 2) { more = xc[i] > 5 || xc[i] == 5 && (more || i < 0 || xc[i + 1] !== u || xc[i - 1] & 1); } else if (rm === 3) { more = more || xc[i] !== u || i < 0; } else { more = false; if (rm !== 0) { throwErr('!Big.RM!'); } } if (i < 1 || !xc[0]) { if (more) { // 1, 0.1, 0.01, 0.001, 0.0001 etc. x.e = -dp; x.c = [1]; } else { // Zero. x.c = [x.e = 0]; } } else { // Remove any digits after the required decimal places. xc.length = i--; // Round up? if (more) { // Rounding up may mean the previous digit has to be rounded up. for (; ++xc[i] > 9;) { xc[i] = 0; if (!i--) { ++x.e; xc.unshift(1); } } } // Remove trailing zeros. for (i = xc.length; !xc[--i]; xc.pop()) { } } return x; } /* * Throw a BigError. * * message {string} The error message. */ function throwErr(message) { var err = new Error(message); err.name = 'BigError'; throw err; } // Prototype/instance methods /* * Return a new Big whose value is the absolute value of this Big. */ P.abs = function () { var x = new this.constructor(this); x.s = 1; return x; }; /* * Return * 1 if the value of this Big is greater than the value of Big y, * -1 if the value of this Big is less than the value of Big y, or * 0 if they have the same value. */ P.cmp = function (y) { var xNeg, x = this, xc = x.c, yc = (y = new x.constructor(y)).c, i = x.s, j = y.s, k = x.e, l = y.e; // Either zero? if (!xc[0] || !yc[0]) { return !xc[0] ? !yc[0] ? 0 : -j : i; } // Signs differ? if (i != j) { return i; } xNeg = i < 0; // Compare exponents. if (k != l) { return k > l ^ xNeg ? 1 : -1; } i = -1; j = (k = xc.length) < (l = yc.length) ? k : l; // Compare digit by digit. for (; ++i < j;) { if (xc[i] != yc[i]) { return xc[i] > yc[i] ^ xNeg ? 1 : -1; } } // Compare lengths. return k == l ? 0 : k > l ^ xNeg ? 1 : -1; }; /* * Return a new Big whose value is the value of this Big divided by the * value of Big y, rounded, if necessary, to a maximum of Big.DP decimal * places using rounding mode Big.RM. */ P.div = function (y) { var x = this, Big = x.constructor, // dividend dvd = x.c, //divisor dvs = (y = new Big(y)).c, s = x.s == y.s ? 1 : -1, dp = Big.DP; if (dp !== ~~dp || dp < 0 || dp > MAX_DP) { throwErr('!Big.DP!'); } // Either 0? if (!dvd[0] || !dvs[0]) { // If both are 0, throw NaN if (dvd[0] == dvs[0]) { throwErr(NaN); } // If dvs is 0, throw +-Infinity. if (!dvs[0]) { throwErr(s / 0); } // dvd is 0, return +-0. return new Big(s * 0); } var dvsL, dvsT, next, cmp, remI, u, dvsZ = dvs.slice(), dvdI = dvsL = dvs.length, dvdL = dvd.length, // remainder rem = dvd.slice(0, dvsL), remL = rem.length, // quotient q = y, qc = q.c = [], qi = 0, digits = dp + (q.e = x.e - y.e) + 1; q.s = s; s = digits < 0 ? 0 : digits; // Create version of divisor with leading zero. dvsZ.unshift(0); // Add zeros to make remainder as long as divisor. for (; remL++ < dvsL; rem.push(0)) { } do { // 'next' is how many times the divisor goes into current remainder. for (next = 0; next < 10; next++) { // Compare divisor and remainder. if (dvsL != (remL = rem.length)) { cmp = dvsL > remL ? 1 : -1; } else { for (remI = -1, cmp = 0; ++remI < dvsL;) { if (dvs[remI] != rem[remI]) { cmp = dvs[remI] > rem[remI] ? 1 : -1; break; } } } // If divisor < remainder, subtract divisor from remainder. if (cmp < 0) { // Remainder can't be more than 1 digit longer than divisor. // Equalise lengths using divisor with extra leading zero? for (dvsT = remL == dvsL ? dvs : dvsZ; remL;) { if (rem[--remL] < dvsT[remL]) { remI = remL; for (; remI && !rem[--remI]; rem[remI] = 9) { } --rem[remI]; rem[remL] += 10; } rem[remL] -= dvsT[remL]; } for (; !rem[0]; rem.shift()) { } } else { break; } } // Add the 'next' digit to the result array. qc[qi++] = cmp ? next : ++next; // Update the remainder. if (rem[0] && cmp) { rem[remL] = dvd[dvdI] || 0; } else { rem = [ dvd[dvdI] ]; } } while ((dvdI++ < dvdL || rem[0] !== u) && s--); // Leading zero? Do not remove if result is simply zero (qi == 1). if (!qc[0] && qi != 1) { // There can't be more than one zero. qc.shift(); q.e--; } // Round? if (qi > digits) { rnd(q, dp, Big.RM, rem[0] !== u); } return q; }; /* * Return true if the value of this Big is equal to the value of Big y, * otherwise returns false. */ P.eq = function (y) { return !this.cmp(y); }; /* * Return true if the value of this Big is greater than the value of Big y, * otherwise returns false. */ P.gt = function (y) { return this.cmp(y) > 0; }; /* * Return true if the value of this Big is greater than or equal to the * value of Big y, otherwise returns false. */ P.gte = function (y) { return this.cmp(y) > -1; }; /* * Return true if the value of this Big is less than the value of Big y, * otherwise returns false. */ P.lt = function (y) { return this.cmp(y) < 0; }; /* * Return true if the value of this Big is less than or equal to the value * of Big y, otherwise returns false. */ P.lte = function (y) { return this.cmp(y) < 1; }; /* * Return a new Big whose value is the value of this Big minus the value * of Big y. */ P.sub = P.minus = function (y) { var i, j, t, xLTy, x = this, Big = x.constructor, a = x.s, b = (y = new Big(y)).s; // Signs differ? if (a != b) { y.s = -b; return x.plus(y); } var xc = x.c.slice(), xe = x.e, yc = y.c, ye = y.e; // Either zero? if (!xc[0] || !yc[0]) { // y is non-zero? x is non-zero? Or both are zero. return yc[0] ? (y.s = -b, y) : new Big(xc[0] ? x : 0); } // Determine which is the bigger number. // Prepend zeros to equalise exponents. if (a = xe - ye) { if (xLTy = a < 0) { a = -a; t = xc; } else { ye = xe; t = yc; } t.reverse(); for (b = a; b--; t.push(0)) { } t.reverse(); } else { // Exponents equal. Check digit by digit. j = ((xLTy = xc.length < yc.length) ? xc : yc).length; for (a = b = 0; b < j; b++) { if (xc[b] != yc[b]) { xLTy = xc[b] < yc[b]; break; } } } // x < y? Point xc to the array of the bigger number. if (xLTy) { t = xc; xc = yc; yc = t; y.s = -y.s; } /* * Append zeros to xc if shorter. No need to add zeros to yc if shorter * as subtraction only needs to start at yc.length. */ if (( b = (j = yc.length) - (i = xc.length) ) > 0) { for (; b--; xc[i++] = 0) { } } // Subtract yc from xc. for (b = i; j > a;){ if (xc[--j] < yc[j]) { for (i = j; i && !xc[--i]; xc[i] = 9) { } --xc[i]; xc[j] += 10; } xc[j] -= yc[j]; } // Remove trailing zeros. for (; xc[--b] === 0; xc.pop()) { } // Remove leading zeros and adjust exponent accordingly. for (; xc[0] === 0;) { xc.shift(); --ye; } if (!xc[0]) { // n - n = +0 y.s = 1; // Result must be zero. xc = [ye = 0]; } y.c = xc; y.e = ye; return y; }; /* * Return a new Big whose value is the value of this Big modulo the * value of Big y. */ P.mod = function (y) { var yGTx, x = this, Big = x.constructor, a = x.s, b = (y = new Big(y)).s; if (!y.c[0]) { throwErr(NaN); } x.s = y.s = 1; yGTx = y.cmp(x) == 1; x.s = a; y.s = b; if (yGTx) { return new Big(x); } a = Big.DP; b = Big.RM; Big.DP = Big.RM = 0; x = x.div(y); Big.DP = a; Big.RM = b; return this.minus( x.times(y) ); }; /* * Return a new Big whose value is the value of this Big plus the value * of Big y. */ P.add = P.plus = function (y) { var t, x = this, Big = x.constructor, a = x.s, b = (y = new Big(y)).s; // Signs differ? if (a != b) { y.s = -b; return x.minus(y); } var xe = x.e, xc = x.c, ye = y.e, yc = y.c; // Either zero? if (!xc[0] || !yc[0]) { // y is non-zero? x is non-zero? Or both are zero. return yc[0] ? y : new Big(xc[0] ? x : a * 0); } xc = xc.slice(); // Prepend zeros to equalise exponents. // Note: Faster to use reverse then do unshifts. if (a = xe - ye) { if (a > 0) { ye = xe; t = yc; } else { a = -a; t = xc; } t.reverse(); for (; a--; t.push(0)) { } t.reverse(); } // Point xc to the longer array. if (xc.length - yc.length < 0) { t = yc; yc = xc; xc = t; } a = yc.length; /* * Only start adding at yc.length - 1 as the further digits of xc can be * left as they are. */ for (b = 0; a;) { b = (xc[--a] = xc[a] + yc[a] + b) / 10 | 0; xc[a] %= 10; } // No need to check for zero, as +x + +y != 0 && -x + -y != 0 if (b) { xc.unshift(b); ++ye; } // Remove trailing zeros. for (a = xc.length; xc[--a] === 0; xc.pop()) { } y.c = xc; y.e = ye; return y; }; /* * Return a Big whose value is the value of this Big raised to the power n. * If n is negative, round, if necessary, to a maximum of Big.DP decimal * places using rounding mode Big.RM. * * n {number} Integer, -MAX_POWER to MAX_POWER inclusive. */ P.pow = function (n) { var x = this, one = new x.constructor(1), y = one, isNeg = n < 0; if (n !== ~~n || n < -MAX_POWER || n > MAX_POWER) { throwErr('!pow!'); } n = isNeg ? -n : n; for (;;) { if (n & 1) { y = y.times(x); } n >>= 1; if (!n) { break; } x = x.times(x); } return isNeg ? one.div(y) : y; }; /* * Return a new Big whose value is the value of this Big rounded to a * maximum of dp decimal places using rounding mode rm. * If dp is not specified, round to 0 decimal places. * If rm is not specified, use Big.RM. * * [dp] {number} Integer, 0 to MAX_DP inclusive. * [rm] 0, 1, 2 or 3 (ROUND_DOWN, ROUND_HALF_UP, ROUND_HALF_EVEN, ROUND_UP) */ P.round = function (dp, rm) { var x = this, Big = x.constructor; if (dp == null) { dp = 0; } else if (dp !== ~~dp || dp < 0 || dp > MAX_DP) { throwErr('!round!'); } rnd(x = new Big(x), dp, rm == null ? Big.RM : rm); return x; }; /* * Return a new Big whose value is the square root of the value of this Big, * rounded, if necessary, to a maximum of Big.DP decimal places using * rounding mode Big.RM. */ P.sqrt = function () { var estimate, r, approx, x = this, Big = x.constructor, xc = x.c, i = x.s, e = x.e, half = new Big('0.5'); // Zero? if (!xc[0]) { return new Big(x); } // If negative, throw NaN. if (i < 0) { throwErr(NaN); } // Estimate. i = Math.sqrt(x.toString()); // Math.sqrt underflow/overflow? // Pass x to Math.sqrt as integer, then adjust the result exponent. if (i === 0 || i === 1 / 0) { estimate = xc.join(''); if (!(estimate.length + e & 1)) { estimate += '0'; } r = new Big( Math.sqrt(estimate).toString() ); r.e = ((e + 1) / 2 | 0) - (e < 0 || e & 1); } else { r = new Big(i.toString()); } i = r.e + (Big.DP += 4); // Newton-Raphson iteration. do { approx = r; r = half.times( approx.plus( x.div(approx) ) ); } while ( approx.c.slice(0, i).join('') !== r.c.slice(0, i).join('') ); rnd(r, Big.DP -= 4, Big.RM); return r; }; /* * Return a new Big whose value is the value of this Big times the value of * Big y. */ P.mul = P.times = function (y) { var c, x = this, Big = x.constructor, xc = x.c, yc = (y = new Big(y)).c, a = xc.length, b = yc.length, i = x.e, j = y.e; // Determine sign of result. y.s = x.s == y.s ? 1 : -1; // Return signed 0 if either 0. if (!xc[0] || !yc[0]) { return new Big(y.s * 0); } // Initialise exponent of result as x.e + y.e. y.e = i + j; // If array xc has fewer digits than yc, swap xc and yc, and lengths. if (a < b) { c = xc; xc = yc; yc = c; j = a; a = b; b = j; } // Initialise coefficient array of result with zeros. for (c = new Array(j = a + b); j--; c[j] = 0) { } // Multiply. // i is initially xc.length. for (i = b; i--;) { b = 0; // a is yc.length. for (j = a + i; j > i;) { // Current sum of products at this digit position, plus carry. b = c[j] + yc[i] * xc[j - i - 1] + b; c[j--] = b % 10; // carry b = b / 10 | 0; } c[j] = (c[j] + b) % 10; } // Increment result exponent if there is a final carry. if (b) { ++y.e; } // Remove any leading zero. if (!c[0]) { c.shift(); } // Remove trailing zeros. for (i = c.length; !c[--i]; c.pop()) { } y.c = c; return y; }; /* * Return a string representing the value of this Big. * Return exponential notation if this Big has a positive exponent equal to * or greater than Big.E_POS, or a negative exponent equal to or less than * Big.E_NEG. */ P.toString = P.valueOf = P.toJSON = function () { var x = this, Big = x.constructor, e = x.e, str = x.c.join(''), strL = str.length; // Exponential notation? if (e <= Big.E_NEG || e >= Big.E_POS) { str = str.charAt(0) + (strL > 1 ? '.' + str.slice(1) : '') + (e < 0 ? 'e' : 'e+') + e; // Negative exponent? } else if (e < 0) { // Prepend zeros. for (; ++e; str = '0' + str) { } str = '0.' + str; // Positive exponent? } else if (e > 0) { if (++e > strL) { // Append zeros. for (e -= strL; e-- ; str += '0') { } } else if (e < strL) { str = str.slice(0, e) + '.' + str.slice(e); } // Exponent zero. } else if (strL > 1) { str = str.charAt(0) + '.' + str.slice(1); } // Avoid '-0' return x.s < 0 && x.c[0] ? '-' + str : str; }; /* *************************************************************************** * If toExponential, toFixed, toPrecision and format are not required they * can safely be commented-out or deleted. No redundant code will be left. * format is used only by toExponential, toFixed and toPrecision. *************************************************************************** */ /* * Return a string representing the value of this Big in exponential * notation to dp fixed decimal places and rounded, if necessary, using * Big.RM. * * [dp] {number} Integer, 0 to MAX_DP inclusive. */ P.toExponential = function (dp) { if (dp == null) { dp = this.c.length - 1; } else if (dp !== ~~dp || dp < 0 || dp > MAX_DP) { throwErr('!toExp!'); } return format(this, dp, 1); }; /* * Return a string representing the value of this Big in normal notation * to dp fixed decimal places and rounded, if necessary, using Big.RM. * * [dp] {number} Integer, 0 to MAX_DP inclusive. */ P.toFixed = function (dp) { var str, x = this, Big = x.constructor, neg = Big.E_NEG, pos = Big.E_POS; // Prevent the possibility of exponential notation. Big.E_NEG = -(Big.E_POS = 1 / 0); if (dp == null) { str = x.toString(); } else if (dp === ~~dp && dp >= 0 && dp <= MAX_DP) { str = format(x, x.e + dp); // (-0).toFixed() is '0', but (-0.1).toFixed() is '-0'. // (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'. if (x.s < 0 && x.c[0] && str.indexOf('-') < 0) { //E.g. -0.5 if rounded to -0 will cause toString to omit the minus sign. str = '-' + str; } } Big.E_NEG = neg; Big.E_POS = pos; if (!str) { throwErr('!toFix!'); } return str; }; /* * Return a string representing the value of this Big rounded to sd * significant digits using Big.RM. Use exponential notation if sd is less * than the number of digits necessary to represent the integer part of the * value in normal notation. * * sd {number} Integer, 1 to MAX_DP inclusive. */ P.toPrecision = function (sd) { if (sd == null) { return this.toString(); } else if (sd !== ~~sd || sd < 1 || sd > MAX_DP) { throwErr('!toPre!'); } return format(this, sd - 1, 2); }; // Export Big = bigFactory(); //AMD. if (typeof define === 'function' && define.amd) { define(function () { return Big; }); // Node and other CommonJS-like environments that support module.exports. } else if (typeof module !== 'undefined' && module.exports) { module.exports = Big; //Browser. } else { global.Big = Big; } })(this); },{}],5:[function(require,module,exports){ require('../../modules/core.regexp.escape'); module.exports = require('../../modules/_core').RegExp.escape; },{"../../modules/_core":26,"../../modules/core.regexp.escape":122}],6:[function(require,module,exports){ module.exports = function(it){ if(typeof it != 'function')throw TypeError(it + ' is not a function!'); return it; }; },{}],7:[function(require,module,exports){ var cof = require('./_cof'); module.exports = function(it, msg){ if(typeof it != 'number' && cof(it) != 'Number')throw TypeError(msg); return +it; }; },{"./_cof":21}],8:[function(require,module,exports){ // 22.1.3.31 Array.prototype[@@unscopables] var UNSCOPABLES = require('./_wks')('unscopables') , ArrayProto = Array.prototype; if(ArrayProto[UNSCOPABLES] == undefined)require('./_hide')(ArrayProto, UNSCOPABLES, {}); module.exports = function(key){ ArrayProto[UNSCOPABLES][key] = true; }; },{"./_hide":43,"./_wks":120}],9:[function(require,module,exports){ module.exports = function(it, Constructor, name, forbiddenField){ if(!(it instanceof Constructor) || (forbiddenField !== undefined && forbiddenField in it)){ throw TypeError(name + ': incorrect invocation!'); } return it; }; },{}],10:[function(require,module,exports){ var isObject = require('./_is-object'); module.exports = function(it){ if(!isObject(it))throw TypeError(it + ' is not an object!'); return it; }; },{"./_is-object":52}],11:[function(require,module,exports){ // 22.1.3.3 Array.prototype.copyWithin(target, start, end = this.length) 'use strict'; var toObject = require('./_to-object') , toIndex = require('./_to-index') , toLength = require('./_to-length'); module.exports = [].copyWithin || function copyWithin(target/*= 0*/, start/*= 0, end = @length*/){ var O = toObject(this) , len = toLength(O.length) , to = toIndex(target, len) , from = toIndex(start, len) , end = arguments.length > 2 ? arguments[2] : undefined , count = Math.min((end === undefined ? len : toIndex(end, len)) - from, len - to) , inc = 1; if(from < to && to < from + count){ inc = -1; from += count - 1; to += count - 1; } while(count-- > 0){ if(from in O)O[to] = O[from]; else delete O[to]; to += inc; from += inc; } return O; }; },{"./_to-index":108,"./_to-length":111,"./_to-object":112}],12:[function(require,module,exports){ // 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length) 'use strict'; var toObject = require('./_to-object') , toIndex = require('./_to-index') , toLength = require('./_to-length'); module.exports = function fill(value /*, start = 0, end = @length */){ var O = toObject(this) , length = toLength(O.length) , aLen = arguments.length , index = toIndex(aLen > 1 ? arguments[1] : undefined, length) , end = aLen > 2 ? arguments[2] : undefined , endPos = end === undefined ? length : toIndex(end, length); while(endPos > index)O[index++] = value; return O; }; },{"./_to-index":108,"./_to-length":111,"./_to-object":112}],13:[function(require,module,exports){ var forOf = require('./_for-of'); module.exports = function(iter, ITERATOR){ var result = []; forOf(iter, false, result.push, result, ITERATOR); return result; }; },{"./_for-of":40}],14:[function(require,module,exports){ // false -> Array#indexOf // true -> Array#includes var toIObject = require('./_to-iobject') , toLength = require('./_to-length') , toIndex = require('./_to-index'); module.exports = function(IS_INCLUDES){ return function($this, el, fromIndex){ var O = toIObject($this) , length = toLength(O.length) , index = toIndex(fromIndex, length) , value; // Array#includes uses SameValueZero equality algorithm if(IS_INCLUDES && el != el)while(length > index){ value = O[index++]; if(value != value)return true; // Array#toIndex ignores holes, Array#includes - not } else for(;length > index; index++)if(IS_INCLUDES || index in O){ if(O[index] === el)return IS_INCLUDES || index || 0; } return !IS_INCLUDES && -1; }; }; },{"./_to-index":108,"./_to-iobject":110,"./_to-length":111}],15:[function(require,module,exports){ // 0 -> Array#forEach // 1 -> Array#map // 2 -> Array#filter // 3 -> Array#some // 4 -> Array#every // 5 -> Array#find // 6 -> Array#findIndex var ctx = require('./_ctx') , IObject = require('./_iobject') , toObject = require('./_to-object') , toLength = require('./_to-length') , asc = require('./_array-species-create'); module.exports = function(TYPE, $create){ var IS_MAP = TYPE == 1 , IS_FILTER = TYPE == 2 , IS_SOME = TYPE == 3 , IS_EVERY = TYPE == 4 , IS_FIND_INDEX = TYPE == 6 , NO_HOLES = TYPE == 5 || IS_FIND_INDEX , create = $create || asc; return function($this, callbackfn, that){ var O = toObject($this) , self = IObject(O) , f = ctx(callbackfn, that, 3) , length = toLength(self.length) , index = 0 , result = IS_MAP ? create($this, length) : IS_FILTER ? create($this, 0) : undefined , val, res; for(;length > index; index++)if(NO_HOLES || index in self){ val = self[index]; res = f(val, index, O); if(TYPE){ if(IS_MAP)result[index] = res; // map else if(res)switch(TYPE){ case 3: return true; // some case 5: return val; // find case 6: return index; // findIndex case 2: result.push(val); // filter } else if(IS_EVERY)return false; // every } } return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : result; }; }; },{"./_array-species-create":18,"./_ctx":28,"./_iobject":48,"./_to-length":111,"./_to-object":112}],16:[function(require,module,exports){ var aFunction = require('./_a-function') , toObject = require('./_to-object') , IObject = require('./_iobject') , toLength = require('./_to-length'); module.exports = function(that, callbackfn, aLen, memo, isRight){ aFunction(callbackfn); var O = toObject(that) , self = IObject(O) , length = toLength(O.length) , index = isRight ? length - 1 : 0 , i = isRight ? -1 : 1; if(aLen < 2)for(;;){ if(index in self){ memo = self[index]; index += i; break; } index += i; if(isRight ? index < 0 : length <= index){ throw TypeError('Reduce of empty array with no initial value'); } } for(;isRight ? index >= 0 : length > index; index += i)if(index in self){ memo = callbackfn(memo, self[index], index, O); } return memo; }; },{"./_a-function":6,"./_iobject":48,"./_to-length":111,"./_to-object":112}],17:[function(require,module,exports){ var isObject = require('./_is-object') , isArray = require('./_is-array') , SPECIES = require('./_wks')('species'); module.exports = function(original){ var C; if(isArray(original)){ C = original.constructor; // cross-realm fallback if(typeof C == 'function' && (C === Array || isArray(C.prototype)))C = undefined; if(isObject(C)){ C = C[SPECIES]; if(C === null)C = undefined; } } return C === undefined ? Array : C; }; },{"./_is-array":50,"./_is-object":52,"./_wks":120}],18:[function(require,module,exports){ // 9.4.2.3 ArraySpeciesCreate(originalArray, length) var speciesConstructor = require('./_array-species-constructor'); module.exports = function(original, length){ return new (speciesConstructor(original))(length); }; },{"./_array-species-constructor":17}],19:[function(require,module,exports){ 'use strict'; var aFunction = require('./_a-function') , isObject = require('./_is-object') , invoke = require('./_invoke') , arraySlice = [].slice , factories = {}; var construct = function(F, len, args){ if(!(len in factories)){ for(var n = [], i = 0; i < len; i++)n[i] = 'a[' + i + ']'; factories[len] = Function('F,a', 'return new F(' + n.join(',') + ')'); } return factories[len](F, args); }; module.exports = Function.bind || function bind(that /*, args... */){ var fn = aFunction(this) , partArgs = arraySlice.call(arguments, 1); var bound = function(/* args... */){ var args = partArgs.concat(arraySlice.call(arguments)); return this instanceof bound ? construct(fn, args.length, args) : invoke(fn, args, that); }; if(isObject(fn.prototype))bound.prototype = fn.prototype; return bound; }; },{"./_a-function":6,"./_invoke":47,"./_is-object":52}],20:[function(require,module,exports){ // getting tag from 19.1.3.6 Object.prototype.toString() var cof = require('./_cof') , TAG = require('./_wks')('toStringTag') // ES3 wrong here , ARG = cof(function(){ return arguments; }()) == 'Arguments'; // fallback for IE11 Script Access Denied error var tryGet = function(it, key){ try { return it[key]; } catch(e){ /* empty */ } }; module.exports = function(it){ var O, T, B; return it === undefined ? 'Undefined' : it === null ? 'Null' // @@toStringTag case : typeof (T = tryGet(O = Object(it), TAG)) == 'string' ? T // builtinTag case : ARG ? cof(O) // ES3 arguments fallback : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B; }; },{"./_cof":21,"./_wks":120}],21:[function(require,module,exports){ var toString = {}.toString; module.exports = function(it){ return toString.call(it).slice(8, -1); }; },{}],22:[function(require,module,exports){ 'use strict'; var dP = require('./_object-dp').f , create = require('./_object-create') , redefineAll = require('./_redefine-all') , ctx = require('./_ctx') , anInstance = require('./_an-instance') , defined = require('./_defined') , forOf = require('./_for-of') , $iterDefine = require('./_iter-define') , step = require('./_iter-step') , setSpecies = require('./_set-species') , DESCRIPTORS = require('./_descriptors') , fastKey = require('./_meta').fastKey , SIZE = DESCRIPTORS ? '_s' : 'size'; var getEntry = function(that, key){ // fast case var index = fastKey(key), entry; if(index !== 'F')return that._i[index]; // frozen object case for(entry = that._f; entry; entry = entry.n){ if(entry.k == key)return entry; } }; module.exports = { getConstructor: function(wrapper, NAME, IS_MAP, ADDER){ var C = wrapper(function(that, iterable){ anInstance(that, C, NAME, '_i'); that._i = create(null); // index that._f = undefined; // first entry that._l = undefined; // last entry that[SIZE] = 0; // size if(iterable != undefined)forOf(iterable, IS_MAP, that[ADDER], that); }); redefineAll(C.prototype, { // 23.1.3.1 Map.prototype.clear() // 23.2.3.2 Set.prototype.clear() clear: function clear(){ for(var that = this, data = that._i, entry = that._f; entry; entry = entry.n){ entry.r = true; if(entry.p)entry.p = entry.p.n = undefined; delete data[entry.i]; } that._f = that._l = undefined; that[SIZE] = 0; }, // 23.1.3.3 Map.prototype.delete(key) // 23.2.3.4 Set.prototype.delete(value) 'delete': function(key){ var that = this , entry = getEntry(that, key); if(entry){ var next = entry.n , prev = entry.p; delete that._i[entry.i]; entry.r = true; if(prev)prev.n = next; if(next)next.p = prev; if(that._f == entry)that._f = next; if(that._l == entry)that._l = prev; that[SIZE]--; } return !!entry; }, // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined) // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined) forEach: function forEach(callbackfn /*, that = undefined */){ anInstance(this, C, 'forEach'); var f = ctx(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3) , entry; while(entry = entry ? entry.n : this._f){ f(entry.v, entry.k, this); // revert to the last existing entry while(entry && entry.r)entry = entry.p; } }, // 23.1.3.7 Map.prototype.has(key) // 23.2.3.7 Set.prototype.has(value) has: function has(key){ return !!getEntry(this, key); } }); if(DESCRIPTORS)dP(C.prototype, 'size', { get: function(){ return defined(this[SIZE]); } }); return C; }, def: function(that, key, value){ var entry = getEntry(that, key) , prev, index; // change existing entry if(entry){ entry.v = value; // create new entry } else { that._l = entry = { i: index = fastKey(key, true), // <- index k: key, // <- key v: value, // <- value p: prev = that._l, // <- previous entry n: undefined, // <- next entry r: false // <- removed }; if(!that._f)that._f = entry; if(prev)prev.n = entry; that[SIZE]++; // add to index if(index !== 'F')that._i[index] = entry; } return that; }, getEntry: getEntry, setStrong: function(C, NAME, IS_MAP){ // add .keys, .values, .entries, [@@iterator] // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11 $iterDefine(C, NAME, function(iterated, kind){ this._t = iterated; // target this._k = kind; // kind this._l = undefined; // previous }, function(){ var that = this , kind = that._k , entry = that._l; // revert to the last existing entry while(entry && entry.r)entry = entry.p; // get next entry if(!that._t || !(that._l = entry = entry ? entry.n : that._t._f)){ // or finish the iteration that._t = undefined; return step(1); } // return step by kind if(kind == 'keys' )return step(0, entry.k); if(kind == 'values')return step(0, entry.v); return step(0, [entry.k, entry.v]); }, IS_MAP ? 'entries' : 'values' , !IS_MAP, true); // add [@@species], 23.1.2.2, 23.2.2.2 setSpecies(NAME); } }; },{"./_an-instance":9,"./_ctx":28,"./_defined":30,"./_descriptors":31,"./_for-of":40,"./_iter-define":56,"./_iter-step":58,"./_meta":65,"./_object-create":69,"./_object-dp":70,"./_redefine-all":89,"./_set-species":94}],23:[function(require,module,exports){ // https://github.com/DavidBruant/Map-Set.prototype.toJSON var classof = require('./_classof') , from = require('./_array-from-iterable'); module.exports = function(NAME){ return function toJSON(){ if(classof(this) != NAME)throw TypeError(NAME + "#toJSON isn't generic"); return from(this); }; }; },{"./_array-from-iterable":13,"./_classof":20}],24:[function(require,module,exports){ 'use strict'; var redefineAll = require('./_redefine-all') , getWeak = require('./_meta').getWeak , anObject = require('./_an-object') , isObject = require('./_is-object') , anInstance = require('./_an-instance') , forOf = require('./_for-of') , createArrayMethod = require('./_array-methods') , $has = require('./_has') , arrayFind = createArrayMethod(5) , arrayFindIndex = createArrayMethod(6) , id = 0; // fallback for uncaught frozen keys var uncaughtFrozenStore = function(that){ return that._l || (that._l = new UncaughtFrozenStore); }; var UncaughtFrozenStore = function(){ this.a = []; }; var findUncaughtFrozen = func