Comparing version 2.2.5 to 2.3.0
{ | ||
"name": "long", | ||
"version": "2.2.5", | ||
"version": "2.3.0", | ||
"author": "Daniel Wirtz <dcode@dcode.io>", | ||
@@ -5,0 +5,0 @@ "description": "A Long class for representing a 64 bit two's-complement integer value.", |
@@ -23,3 +23,12 @@ /* | ||
*/ | ||
(function(global) { | ||
(function(global, factory) { | ||
/* AMD */ if (typeof define === 'function' && define["amd"]) | ||
define([], factory); | ||
/* CommonJS */ else if (typeof require === 'function' && typeof module === "object" && module && module["exports"]) | ||
module["exports"] = factory(); | ||
/* Global */ else | ||
(global["dcodeIO"] = global["dcodeIO"] || {})["Long"] = factory(); | ||
})(this, function() { | ||
"use strict"; | ||
@@ -79,2 +88,17 @@ | ||
/** | ||
* An indicator used to reliably determine if an object is a Long or not. | ||
* @type {boolean} | ||
* @const | ||
* @expose | ||
* @private | ||
*/ | ||
Long.__isLong__; | ||
Object.defineProperty(Long.prototype, "__isLong__", { | ||
value: true, | ||
enumerable: false, | ||
configurable: false | ||
}); | ||
/** | ||
* Tests if the specified object is a Long. | ||
@@ -86,3 +110,3 @@ * @param {*} obj Object | ||
Long.isLong = function(obj) { | ||
return (obj && obj instanceof Long) === true; | ||
return (obj && obj["__isLong__"]) === true; | ||
}; | ||
@@ -226,2 +250,4 @@ | ||
Long.fromValue = function(val) { | ||
if (val /* is compatible */ instanceof Long) | ||
return val; | ||
if (typeof val === 'number') | ||
@@ -231,5 +257,3 @@ return Long.fromNumber(val); | ||
return Long.fromString(val); | ||
if (Long.isLong(val)) | ||
return val; | ||
// Throws for not an object (undefined, null): | ||
// Throws for non-objects, converts non-instanceof Long: | ||
return new Long(val.low, val.high, val.unsigned); | ||
@@ -524,5 +548,3 @@ }; | ||
Long.prototype.notEquals = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return !this.equals(other); | ||
return !this.equals(/* validates */ other); | ||
}; | ||
@@ -537,5 +559,3 @@ | ||
Long.prototype.lessThan = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) < 0; | ||
return this.compare(/* validates */ other) < 0; | ||
}; | ||
@@ -550,5 +570,3 @@ | ||
Long.prototype.lessThanOrEqual = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) <= 0; | ||
return this.compare(/* validates */ other) <= 0; | ||
}; | ||
@@ -563,5 +581,3 @@ | ||
Long.prototype.greaterThan = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) > 0; | ||
return this.compare(/* validates */ other) > 0; | ||
}; | ||
@@ -576,5 +592,3 @@ | ||
Long.prototype.greaterThanOrEqual = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) >= 0; | ||
return this.compare(/* validates */ other) >= 0; | ||
}; | ||
@@ -590,2 +604,4 @@ | ||
Long.prototype.compare = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
if (this.equals(other)) | ||
@@ -948,9 +964,3 @@ return 0; | ||
/* CommonJS */ if (typeof require === 'function' && typeof module === 'object' && module && typeof exports === 'object' && exports) | ||
module["exports"] = Long; | ||
/* AMD */ else if (typeof define === 'function' && define["amd"]) | ||
define(function() { return Long; }); | ||
/* Global */ else | ||
(global["dcodeIO"] = global["dcodeIO"] || {})["Long"] = Long; | ||
})(this); | ||
return Long; | ||
}); |
@@ -1,2 +0,2 @@ | ||
(function(){/* | ||
/* | ||
Long.js (c) 2013 Daniel Wirtz <dcode@dcode.io> | ||
@@ -6,18 +6,17 @@ Released under the Apache License, Version 2.0 | ||
*/ | ||
(function(q){function b(a,b,d){this.low=a|0;this.high=b|0;this.unsigned=!!d}b.isLong=function(a){return!0===(a&&a instanceof b)};var r={},s={};b.fromInt=function(a,c){var d;if(c){a>>>=0;if(0<=a&&256>a&&(d=s[a]))return d;d=new b(a,0>(a|0)?-1:0,!0);0<=a&&256>a&&(s[a]=d)}else{a|=0;if(-128<=a&&128>a&&(d=r[a]))return d;d=new b(a,0>a?-1:0,!1);-128<=a&&128>a&&(r[a]=d)}return d};b.fromNumber=function(a,c){c=!!c;return isNaN(a)||!isFinite(a)?b.ZERO:!c&&a<=-t?b.MIN_VALUE:!c&&a+1>=t?b.MAX_VALUE:c&&a>=u?b.MAX_UNSIGNED_VALUE: | ||
0>a?b.fromNumber(-a,c).negate():new b(a%4294967296|0,a/4294967296|0,c)};b.fromBits=function(a,c,d){return new b(a,c,d)};b.fromString=function(a,c,d){if(0===a.length)throw Error("number format error: empty string");if("NaN"===a||"Infinity"===a||"+Infinity"===a||"-Infinity"===a)return b.ZERO;"number"===typeof c&&(d=c,c=!1);d=d||10;if(2>d||36<d)throw Error("radix out of range: "+d);var e;if(0<(e=a.indexOf("-")))throw Error('number format error: interior "-" character: '+a);if(0===e)return b.fromString(a.substring(1), | ||
c,d).negate();e=b.fromNumber(Math.pow(d,8));for(var f=b.ZERO,g=0;g<a.length;g+=8){var k=Math.min(8,a.length-g),l=parseInt(a.substring(g,g+k),d);8>k?(k=b.fromNumber(Math.pow(d,k)),f=f.multiply(k).add(b.fromNumber(l))):(f=f.multiply(e),f=f.add(b.fromNumber(l)))}f.unsigned=c;return f};b.fromValue=function(a){return"number"===typeof a?b.fromNumber(a):"string"===typeof a?b.fromString(a):b.isLong(a)?a:new b(a.low,a.high,a.unsigned)};var u=4294967296*4294967296,t=u/2,v=b.fromInt(16777216);b.ZERO=b.fromInt(0); | ||
b.UZERO=b.fromInt(0,!0);b.ONE=b.fromInt(1);b.UONE=b.fromInt(1,!0);b.NEG_ONE=b.fromInt(-1);b.MAX_VALUE=b.fromBits(-1,2147483647,!1);b.MAX_UNSIGNED_VALUE=b.fromBits(-1,-1,!0);b.MIN_VALUE=b.fromBits(0,-2147483648,!1);b.prototype.toInt=function(){return this.unsigned?this.low>>>0:this.low};b.prototype.toNumber=function(){return this.unsigned?4294967296*(this.high>>>0)+(this.low>>>0):4294967296*this.high+(this.low>>>0)};b.prototype.toString=function(a){a=a||10;if(2>a||36<a)throw RangeError("radix out of range: "+ | ||
a);if(this.isZero())return"0";var c;if(this.isNegative()){if(this.equals(b.MIN_VALUE)){c=b.fromNumber(a);var d=this.div(c);c=d.multiply(c).subtract(this);return d.toString(a)+c.toInt().toString(a)}return"-"+this.negate().toString(a)}d=b.fromNumber(Math.pow(a,6),this.unsigned);c=this;for(var e="";;){var f=c.div(d),g=(c.subtract(f.multiply(d)).toInt()>>>0).toString(a);c=f;if(c.isZero())return g+e;for(;6>g.length;)g="0"+g;e=""+g+e}};b.prototype.getHighBits=function(){return this.high};b.prototype.getHighBitsUnsigned= | ||
function(){return this.high>>>0};b.prototype.getLowBits=function(){return this.low};b.prototype.getLowBitsUnsigned=function(){return this.low>>>0};b.prototype.getNumBitsAbs=function(){if(this.isNegative())return this.equals(b.MIN_VALUE)?64:this.negate().getNumBitsAbs();for(var a=0!=this.high?this.high:this.low,c=31;0<c&&0==(a&1<<c);c--);return 0!=this.high?c+33:c+1};b.prototype.isZero=function(){return 0===this.high&&0===this.low};b.prototype.isNegative=function(){return!this.unsigned&&0>this.high}; | ||
b.prototype.isPositive=function(){return this.unsigned||0<=this.high};b.prototype.isOdd=function(){return 1===(this.low&1)};b.prototype.isEven=function(){return 0===(this.low&1)};b.prototype.equals=function(a){b.isLong(a)||(a=b.fromValue(a));return this.unsigned!==a.unsigned&&1===this.high>>>31&&1===a.high>>>31?!1:this.high===a.high&&this.low===a.low};b.prototype.notEquals=function(a){b.isLong(a)||(a=b.fromValue(a));return!this.equals(a)};b.prototype.lessThan=function(a){b.isLong(a)||(a=b.fromValue(a)); | ||
return 0>this.compare(a)};b.prototype.lessThanOrEqual=function(a){b.isLong(a)||(a=b.fromValue(a));return 0>=this.compare(a)};b.prototype.greaterThan=function(a){b.isLong(a)||(a=b.fromValue(a));return 0<this.compare(a)};b.prototype.greaterThanOrEqual=function(a){b.isLong(a)||(a=b.fromValue(a));return 0<=this.compare(a)};b.prototype.compare=function(a){if(this.equals(a))return 0;var b=this.isNegative(),d=a.isNegative();return b&&!d?-1:!b&&d?1:this.unsigned?a.high>>>0>this.high>>>0||a.high===this.high&& | ||
a.low>>>0>this.low>>>0?-1:1:this.subtract(a).isNegative()?-1:1};b.prototype.negate=function(){return!this.unsigned&&this.equals(b.MIN_VALUE)?b.MIN_VALUE:this.not().add(b.ONE)};b.prototype.add=function(a){b.isLong(a)||(a=b.fromValue(a));var c=this.high>>>16,d=this.high&65535,e=this.low>>>16,f=a.high>>>16,g=a.high&65535,k=a.low>>>16,l;l=0+((this.low&65535)+(a.low&65535));a=0+(l>>>16);a+=e+k;e=0+(a>>>16);e+=d+g;d=0+(e>>>16);d=d+(c+f)&65535;return b.fromBits((a&65535)<<16|l&65535,d<<16|e&65535,this.unsigned)}; | ||
b.prototype.subtract=function(a){b.isLong(a)||(a=b.fromValue(a));return this.add(a.negate())};b.prototype.multiply=function(a){if(this.isZero())return b.ZERO;b.isLong(a)||(a=b.fromValue(a));if(a.isZero())return b.ZERO;if(this.equals(b.MIN_VALUE))return a.isOdd()?b.MIN_VALUE:b.ZERO;if(a.equals(b.MIN_VALUE))return this.isOdd()?b.MIN_VALUE:b.ZERO;if(this.isNegative())return a.isNegative()?this.negate().multiply(a.negate()):this.negate().multiply(a).negate();if(a.isNegative())return this.multiply(a.negate()).negate(); | ||
if(this.lessThan(v)&&a.lessThan(v))return b.fromNumber(this.toNumber()*a.toNumber(),this.unsigned);var c=this.high>>>16,d=this.high&65535,e=this.low>>>16,f=this.low&65535,g=a.high>>>16,k=a.high&65535,l=a.low>>>16;a=a.low&65535;var n,h,m,p;p=0+f*a;m=0+(p>>>16);m+=e*a;h=0+(m>>>16);m=(m&65535)+f*l;h+=m>>>16;m&=65535;h+=d*a;n=0+(h>>>16);h=(h&65535)+e*l;n+=h>>>16;h&=65535;h+=f*k;n+=h>>>16;h&=65535;n=n+(c*a+d*l+e*k+f*g)&65535;return b.fromBits(m<<16|p&65535,n<<16|h,this.unsigned)};b.prototype.div=function(a){b.isLong(a)|| | ||
(a=b.fromValue(a));if(a.isZero())throw Error("division by zero");if(this.isZero())return this.unsigned?b.UZERO:b.ZERO;var c,d,e;if(this.equals(b.MIN_VALUE)){if(a.equals(b.ONE)||a.equals(b.NEG_ONE))return b.MIN_VALUE;if(a.equals(b.MIN_VALUE))return b.ONE;c=this.shiftRight(1).div(a).shiftLeft(1);if(c.equals(b.ZERO))return a.isNegative()?b.ONE:b.NEG_ONE;d=this.subtract(a.multiply(c));return e=c.add(d.div(a))}if(a.equals(b.MIN_VALUE))return this.unsigned?b.UZERO:b.ZERO;if(this.isNegative())return a.isNegative()? | ||
this.negate().div(a.negate()):this.negate().div(a).negate();if(a.isNegative())return this.div(a.negate()).negate();e=b.ZERO;for(d=this;d.greaterThanOrEqual(a);){c=Math.max(1,Math.floor(d.toNumber()/a.toNumber()));for(var f=Math.ceil(Math.log(c)/Math.LN2),f=48>=f?1:Math.pow(2,f-48),g=b.fromNumber(c),k=g.multiply(a);k.isNegative()||k.greaterThan(d);)c-=f,g=b.fromNumber(c,this.unsigned),k=g.multiply(a);g.isZero()&&(g=b.ONE);e=e.add(g);d=d.subtract(k)}return e};b.prototype.modulo=function(a){b.isLong(a)|| | ||
(a=b.fromValue(a));return this.subtract(this.div(a).multiply(a))};b.prototype.not=function(){return b.fromBits(~this.low,~this.high,this.unsigned)};b.prototype.and=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low&a.low,this.high&a.high,this.unsigned)};b.prototype.or=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low|a.low,this.high|a.high,this.unsigned)};b.prototype.xor=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low^a.low,this.high^ | ||
a.high,this.unsigned)};b.prototype.shiftLeft=function(a){b.isLong(a)&&(a=a.toInt());return 0===(a&=63)?this:32>a?b.fromBits(this.low<<a,this.high<<a|this.low>>>32-a,this.unsigned):b.fromBits(0,this.low<<a-32,this.unsigned)};b.prototype.shiftRight=function(a){b.isLong(a)&&(a=a.toInt());return 0===(a&=63)?this:32>a?b.fromBits(this.low>>>a|this.high<<32-a,this.high>>a,this.unsigned):b.fromBits(this.high>>a-32,0<=this.high?0:-1,this.unsigned)};b.prototype.shiftRightUnsigned=function(a){b.isLong(a)&&(a= | ||
a.toInt());a&=63;if(0===a)return this;var c=this.high;return 32>a?b.fromBits(this.low>>>a|c<<32-a,c>>>a,this.unsigned):32===a?b.fromBits(c,0,this.unsigned):b.fromBits(c>>>a-32,0,this.unsigned)};b.prototype.toSigned=function(){return this.unsigned?new b(this.low,this.high,!1):this};b.prototype.toUnsigned=function(){return this.unsigned?this:new b(this.low,this.high,!0)};"function"===typeof require&&"object"===typeof module&&module&&"object"===typeof exports&&exports?module.exports=b:"function"===typeof define&& | ||
define.amd?define(function(){return b}):(q.dcodeIO=q.dcodeIO||{}).Long=b})(this);})(); | ||
function p(){function b(a,b,d){this.low=a|0;this.high=b|0;this.unsigned=!!d}Object.defineProperty(b.prototype,"__isLong__",{value:!0,enumerable:!1,configurable:!1});b.isLong=function(a){return!0===(a&&a.__isLong__)};var r={},s={};b.fromInt=function(a,c){var d;if(c){a>>>=0;if(0<=a&&256>a&&(d=s[a]))return d;d=new b(a,0>(a|0)?-1:0,!0);0<=a&&256>a&&(s[a]=d)}else{a|=0;if(-128<=a&&128>a&&(d=r[a]))return d;d=new b(a,0>a?-1:0,!1);-128<=a&&128>a&&(r[a]=d)}return d};b.fromNumber=function(a,c){c=!!c;return isNaN(a)|| | ||
!isFinite(a)?b.ZERO:!c&&a<=-t?b.MIN_VALUE:!c&&a+1>=t?b.MAX_VALUE:c&&a>=u?b.MAX_UNSIGNED_VALUE:0>a?b.fromNumber(-a,c).negate():new b(a%4294967296|0,a/4294967296|0,c)};b.fromBits=function(a,c,d){return new b(a,c,d)};b.fromString=function(a,c,d){if(0===a.length)throw Error("number format error: empty string");if("NaN"===a||"Infinity"===a||"+Infinity"===a||"-Infinity"===a)return b.ZERO;"number"===typeof c&&(d=c,c=!1);d=d||10;if(2>d||36<d)throw Error("radix out of range: "+d);var e;if(0<(e=a.indexOf("-")))throw Error('number format error: interior "-" character: '+ | ||
a);if(0===e)return b.fromString(a.substring(1),c,d).negate();e=b.fromNumber(Math.pow(d,8));for(var f=b.ZERO,g=0;g<a.length;g+=8){var k=Math.min(8,a.length-g),l=parseInt(a.substring(g,g+k),d);8>k?(k=b.fromNumber(Math.pow(d,k)),f=f.multiply(k).add(b.fromNumber(l))):(f=f.multiply(e),f=f.add(b.fromNumber(l)))}f.unsigned=c;return f};b.fromValue=function(a){return a instanceof b?a:"number"===typeof a?b.fromNumber(a):"string"===typeof a?b.fromString(a):new b(a.low,a.high,a.unsigned)};var u=4294967296*4294967296, | ||
t=u/2,v=b.fromInt(16777216);b.ZERO=b.fromInt(0);b.UZERO=b.fromInt(0,!0);b.ONE=b.fromInt(1);b.UONE=b.fromInt(1,!0);b.NEG_ONE=b.fromInt(-1);b.MAX_VALUE=b.fromBits(-1,2147483647,!1);b.MAX_UNSIGNED_VALUE=b.fromBits(-1,-1,!0);b.MIN_VALUE=b.fromBits(0,-2147483648,!1);b.prototype.toInt=function(){return this.unsigned?this.low>>>0:this.low};b.prototype.toNumber=function(){return this.unsigned?4294967296*(this.high>>>0)+(this.low>>>0):4294967296*this.high+(this.low>>>0)};b.prototype.toString=function(a){a= | ||
a||10;if(2>a||36<a)throw RangeError("radix out of range: "+a);if(this.isZero())return"0";var c;if(this.isNegative()){if(this.equals(b.MIN_VALUE)){c=b.fromNumber(a);var d=this.div(c);c=d.multiply(c).subtract(this);return d.toString(a)+c.toInt().toString(a)}return"-"+this.negate().toString(a)}d=b.fromNumber(Math.pow(a,6),this.unsigned);c=this;for(var e="";;){var f=c.div(d),g=(c.subtract(f.multiply(d)).toInt()>>>0).toString(a);c=f;if(c.isZero())return g+e;for(;6>g.length;)g="0"+g;e=""+g+e}};b.prototype.getHighBits= | ||
function(){return this.high};b.prototype.getHighBitsUnsigned=function(){return this.high>>>0};b.prototype.getLowBits=function(){return this.low};b.prototype.getLowBitsUnsigned=function(){return this.low>>>0};b.prototype.getNumBitsAbs=function(){if(this.isNegative())return this.equals(b.MIN_VALUE)?64:this.negate().getNumBitsAbs();for(var a=0!=this.high?this.high:this.low,c=31;0<c&&0==(a&1<<c);c--);return 0!=this.high?c+33:c+1};b.prototype.isZero=function(){return 0===this.high&&0===this.low};b.prototype.isNegative= | ||
function(){return!this.unsigned&&0>this.high};b.prototype.isPositive=function(){return this.unsigned||0<=this.high};b.prototype.isOdd=function(){return 1===(this.low&1)};b.prototype.isEven=function(){return 0===(this.low&1)};b.prototype.equals=function(a){b.isLong(a)||(a=b.fromValue(a));return this.unsigned!==a.unsigned&&1===this.high>>>31&&1===a.high>>>31?!1:this.high===a.high&&this.low===a.low};b.prototype.notEquals=function(a){return!this.equals(a)};b.prototype.lessThan=function(a){return 0>this.compare(a)}; | ||
b.prototype.lessThanOrEqual=function(a){return 0>=this.compare(a)};b.prototype.greaterThan=function(a){return 0<this.compare(a)};b.prototype.greaterThanOrEqual=function(a){return 0<=this.compare(a)};b.prototype.compare=function(a){b.isLong(a)||(a=b.fromValue(a));if(this.equals(a))return 0;var c=this.isNegative(),d=a.isNegative();return c&&!d?-1:!c&&d?1:this.unsigned?a.high>>>0>this.high>>>0||a.high===this.high&&a.low>>>0>this.low>>>0?-1:1:this.subtract(a).isNegative()?-1:1};b.prototype.negate=function(){return!this.unsigned&& | ||
this.equals(b.MIN_VALUE)?b.MIN_VALUE:this.not().add(b.ONE)};b.prototype.add=function(a){b.isLong(a)||(a=b.fromValue(a));var c=this.high>>>16,d=this.high&65535,e=this.low>>>16,f=a.high>>>16,g=a.high&65535,k=a.low>>>16,l;l=0+((this.low&65535)+(a.low&65535));a=0+(l>>>16);a+=e+k;e=0+(a>>>16);e+=d+g;d=0+(e>>>16);d=d+(c+f)&65535;return b.fromBits((a&65535)<<16|l&65535,d<<16|e&65535,this.unsigned)};b.prototype.subtract=function(a){b.isLong(a)||(a=b.fromValue(a));return this.add(a.negate())};b.prototype.multiply= | ||
function(a){if(this.isZero())return b.ZERO;b.isLong(a)||(a=b.fromValue(a));if(a.isZero())return b.ZERO;if(this.equals(b.MIN_VALUE))return a.isOdd()?b.MIN_VALUE:b.ZERO;if(a.equals(b.MIN_VALUE))return this.isOdd()?b.MIN_VALUE:b.ZERO;if(this.isNegative())return a.isNegative()?this.negate().multiply(a.negate()):this.negate().multiply(a).negate();if(a.isNegative())return this.multiply(a.negate()).negate();if(this.lessThan(v)&&a.lessThan(v))return b.fromNumber(this.toNumber()*a.toNumber(),this.unsigned); | ||
var c=this.high>>>16,d=this.high&65535,e=this.low>>>16,f=this.low&65535,g=a.high>>>16,k=a.high&65535,l=a.low>>>16;a=a.low&65535;var n,h,m,q;q=0+f*a;m=0+(q>>>16);m+=e*a;h=0+(m>>>16);m=(m&65535)+f*l;h+=m>>>16;m&=65535;h+=d*a;n=0+(h>>>16);h=(h&65535)+e*l;n+=h>>>16;h&=65535;h+=f*k;n+=h>>>16;h&=65535;n=n+(c*a+d*l+e*k+f*g)&65535;return b.fromBits(m<<16|q&65535,n<<16|h,this.unsigned)};b.prototype.div=function(a){b.isLong(a)||(a=b.fromValue(a));if(a.isZero())throw Error("division by zero");if(this.isZero())return this.unsigned? | ||
b.UZERO:b.ZERO;var c,d,e;if(this.equals(b.MIN_VALUE)){if(a.equals(b.ONE)||a.equals(b.NEG_ONE))return b.MIN_VALUE;if(a.equals(b.MIN_VALUE))return b.ONE;c=this.shiftRight(1).div(a).shiftLeft(1);if(c.equals(b.ZERO))return a.isNegative()?b.ONE:b.NEG_ONE;d=this.subtract(a.multiply(c));return e=c.add(d.div(a))}if(a.equals(b.MIN_VALUE))return this.unsigned?b.UZERO:b.ZERO;if(this.isNegative())return a.isNegative()?this.negate().div(a.negate()):this.negate().div(a).negate();if(a.isNegative())return this.div(a.negate()).negate(); | ||
e=b.ZERO;for(d=this;d.greaterThanOrEqual(a);){c=Math.max(1,Math.floor(d.toNumber()/a.toNumber()));for(var f=Math.ceil(Math.log(c)/Math.LN2),f=48>=f?1:Math.pow(2,f-48),g=b.fromNumber(c),k=g.multiply(a);k.isNegative()||k.greaterThan(d);)c-=f,g=b.fromNumber(c,this.unsigned),k=g.multiply(a);g.isZero()&&(g=b.ONE);e=e.add(g);d=d.subtract(k)}return e};b.prototype.modulo=function(a){b.isLong(a)||(a=b.fromValue(a));return this.subtract(this.div(a).multiply(a))};b.prototype.not=function(){return b.fromBits(~this.low, | ||
~this.high,this.unsigned)};b.prototype.and=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low&a.low,this.high&a.high,this.unsigned)};b.prototype.or=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low|a.low,this.high|a.high,this.unsigned)};b.prototype.xor=function(a){b.isLong(a)||(a=b.fromValue(a));return b.fromBits(this.low^a.low,this.high^a.high,this.unsigned)};b.prototype.shiftLeft=function(a){b.isLong(a)&&(a=a.toInt());return 0===(a&=63)?this:32>a?b.fromBits(this.low<< | ||
a,this.high<<a|this.low>>>32-a,this.unsigned):b.fromBits(0,this.low<<a-32,this.unsigned)};b.prototype.shiftRight=function(a){b.isLong(a)&&(a=a.toInt());return 0===(a&=63)?this:32>a?b.fromBits(this.low>>>a|this.high<<32-a,this.high>>a,this.unsigned):b.fromBits(this.high>>a-32,0<=this.high?0:-1,this.unsigned)};b.prototype.shiftRightUnsigned=function(a){b.isLong(a)&&(a=a.toInt());a&=63;if(0===a)return this;var c=this.high;return 32>a?b.fromBits(this.low>>>a|c<<32-a,c>>>a,this.unsigned):32===a?b.fromBits(c, | ||
0,this.unsigned):b.fromBits(c>>>a-32,0,this.unsigned)};b.prototype.toSigned=function(){return this.unsigned?new b(this.low,this.high,!1):this};b.prototype.toUnsigned=function(){return this.unsigned?this:new b(this.low,this.high,!0)};return b}"function"===typeof define&&define.amd?define([],p):"function"===typeof require&&"object"===typeof module&&module&&module.exports?module.exports=p():(this.dcodeIO=this.dcodeIO||{}).Long=p(); |
{ | ||
"name": "long", | ||
"version": "2.2.5", | ||
"version": "2.3.0", | ||
"author": "Daniel Wirtz <dcode@dcode.io>", | ||
@@ -26,3 +26,3 @@ "description": "A Long class for representing a 64-bit two's-complement integer value.", | ||
"make": "npm run-script build && npm run-script compile && npm run-script compress && npm test", | ||
"compile": "ccjs dist/Long.js --compilation_level=ADVANCED_OPTIMIZATIONS --output_wrapper=\"(function(){%output%})();\" --create_source_map=dist/Long.min.map > dist/Long.min.js", | ||
"compile": "ccjs dist/Long.js --compilation_level=ADVANCED_OPTIMIZATIONS --create_source_map=dist/Long.min.map > dist/Long.min.js", | ||
"compress": "gzip -c -9 dist/Long.min.js > dist/Long.min.js.gz", | ||
@@ -29,0 +29,0 @@ "test": "node node_modules/testjs/bin/testjs tests/suite.js" |
@@ -17,3 +17,3 @@ var MetaScript = require("metascript"), | ||
path.join(distDir, "Long.js"), | ||
MetaScript.transform(fs.readFileSync(filename = path.join(srcDir, "Long.js")), filename, scope, srcDir) | ||
MetaScript.transform(fs.readFileSync(filename = path.join(srcDir, "wrap.js")), filename, scope, srcDir) | ||
); | ||
@@ -20,0 +20,0 @@ |
1691
src/Long.js
@@ -1,944 +0,917 @@ | ||
/* | ||
Copyright 2013 Daniel Wirtz <dcode@dcode.io> | ||
Copyright 2009 The Closure Library Authors. All Rights Reserved. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS-IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
*/ | ||
/** | ||
* @license Long.js (c) 2013 Daniel Wirtz <dcode@dcode.io> | ||
* Released under the Apache License, Version 2.0 | ||
* see: https://github.com/dcodeIO/Long.js for details | ||
* Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers. | ||
* See the from* functions below for more convenient ways of constructing Longs. | ||
* @exports Long | ||
* @class A Long class for representing a 64 bit two's-complement integer value. | ||
* @param {number} low The low (signed) 32 bits of the long | ||
* @param {number} high The high (signed) 32 bits of the long | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @constructor | ||
*/ | ||
(function(global) { | ||
"use strict"; | ||
var Long = function(low, high, unsigned) { | ||
/** | ||
* Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers. | ||
* See the from* functions below for more convenient ways of constructing Longs. | ||
* @exports Long | ||
* @class A Long class for representing a 64 bit two's-complement integer value. | ||
* @param {number} low The low (signed) 32 bits of the long | ||
* @param {number} high The high (signed) 32 bits of the long | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @constructor | ||
* The low 32 bits as a signed value. | ||
* @type {number} | ||
* @expose | ||
*/ | ||
var Long = function(low, high, unsigned) { | ||
/** | ||
* The low 32 bits as a signed value. | ||
* @type {number} | ||
* @expose | ||
*/ | ||
this.low = low|0; | ||
this.low = low|0; | ||
/** | ||
* The high 32 bits as a signed value. | ||
* @type {number} | ||
* @expose | ||
*/ | ||
this.high = high|0; | ||
/** | ||
* Whether unsigned or not. | ||
* @type {boolean} | ||
* @expose | ||
*/ | ||
this.unsigned = !!unsigned; | ||
}; | ||
// The internal representation of a long is the two given signed, 32-bit values. | ||
// We use 32-bit pieces because these are the size of integers on which | ||
// Javascript performs bit-operations. For operations like addition and | ||
// multiplication, we split each number into 16 bit pieces, which can easily be | ||
// multiplied within Javascript's floating-point representation without overflow | ||
// or change in sign. | ||
// | ||
// In the algorithms below, we frequently reduce the negative case to the | ||
// positive case by negating the input(s) and then post-processing the result. | ||
// Note that we must ALWAYS check specially whether those values are MIN_VALUE | ||
// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as | ||
// a positive number, it overflows back into a negative). Not handling this | ||
// case would often result in infinite recursion. | ||
// | ||
// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from* | ||
// methods on which they depend. | ||
/** | ||
* Tests if the specified object is a Long. | ||
* @param {*} obj Object | ||
* @returns {boolean} | ||
* The high 32 bits as a signed value. | ||
* @type {number} | ||
* @expose | ||
*/ | ||
Long.isLong = function(obj) { | ||
return (obj && obj instanceof Long) === true; | ||
}; | ||
/** | ||
* A cache of the Long representations of small integer values. | ||
* @type {!Object} | ||
* @inner | ||
*/ | ||
var INT_CACHE = {}; | ||
this.high = high|0; | ||
/** | ||
* A cache of the Long representations of small unsigned integer values. | ||
* @type {!Object} | ||
* @inner | ||
* Whether unsigned or not. | ||
* @type {boolean} | ||
* @expose | ||
*/ | ||
var UINT_CACHE = {}; | ||
this.unsigned = !!unsigned; | ||
}; | ||
/** | ||
* Returns a Long representing the given 32 bit integer value. | ||
* @param {number} value The 32 bit integer in question | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromInt = function(value, unsigned) { | ||
var obj, cachedObj; | ||
if (!unsigned) { | ||
value = value | 0; | ||
if (-128 <= value && value < 128) { | ||
cachedObj = INT_CACHE[value]; | ||
if (cachedObj) | ||
return cachedObj; | ||
} | ||
obj = new Long(value, value < 0 ? -1 : 0, false); | ||
if (-128 <= value && value < 128) | ||
INT_CACHE[value] = obj; | ||
return obj; | ||
} else { | ||
value = value >>> 0; | ||
if (0 <= value && value < 256) { | ||
cachedObj = UINT_CACHE[value]; | ||
if (cachedObj) | ||
return cachedObj; | ||
} | ||
obj = new Long(value, (value | 0) < 0 ? -1 : 0, true); | ||
if (0 <= value && value < 256) | ||
UINT_CACHE[value] = obj; | ||
return obj; | ||
// The internal representation of a long is the two given signed, 32-bit values. | ||
// We use 32-bit pieces because these are the size of integers on which | ||
// Javascript performs bit-operations. For operations like addition and | ||
// multiplication, we split each number into 16 bit pieces, which can easily be | ||
// multiplied within Javascript's floating-point representation without overflow | ||
// or change in sign. | ||
// | ||
// In the algorithms below, we frequently reduce the negative case to the | ||
// positive case by negating the input(s) and then post-processing the result. | ||
// Note that we must ALWAYS check specially whether those values are MIN_VALUE | ||
// (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as | ||
// a positive number, it overflows back into a negative). Not handling this | ||
// case would often result in infinite recursion. | ||
// | ||
// Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from* | ||
// methods on which they depend. | ||
/** | ||
* An indicator used to reliably determine if an object is a Long or not. | ||
* @type {boolean} | ||
* @const | ||
* @expose | ||
* @private | ||
*/ | ||
Long.__isLong__; | ||
Object.defineProperty(Long.prototype, "__isLong__", { | ||
value: true, | ||
enumerable: false, | ||
configurable: false | ||
}); | ||
/** | ||
* Tests if the specified object is a Long. | ||
* @param {*} obj Object | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.isLong = function(obj) { | ||
return (obj && obj["__isLong__"]) === true; | ||
}; | ||
/** | ||
* A cache of the Long representations of small integer values. | ||
* @type {!Object} | ||
* @inner | ||
*/ | ||
var INT_CACHE = {}; | ||
/** | ||
* A cache of the Long representations of small unsigned integer values. | ||
* @type {!Object} | ||
* @inner | ||
*/ | ||
var UINT_CACHE = {}; | ||
/** | ||
* Returns a Long representing the given 32 bit integer value. | ||
* @param {number} value The 32 bit integer in question | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromInt = function(value, unsigned) { | ||
var obj, cachedObj; | ||
if (!unsigned) { | ||
value = value | 0; | ||
if (-128 <= value && value < 128) { | ||
cachedObj = INT_CACHE[value]; | ||
if (cachedObj) | ||
return cachedObj; | ||
} | ||
}; | ||
obj = new Long(value, value < 0 ? -1 : 0, false); | ||
if (-128 <= value && value < 128) | ||
INT_CACHE[value] = obj; | ||
return obj; | ||
} else { | ||
value = value >>> 0; | ||
if (0 <= value && value < 256) { | ||
cachedObj = UINT_CACHE[value]; | ||
if (cachedObj) | ||
return cachedObj; | ||
} | ||
obj = new Long(value, (value | 0) < 0 ? -1 : 0, true); | ||
if (0 <= value && value < 256) | ||
UINT_CACHE[value] = obj; | ||
return obj; | ||
} | ||
}; | ||
/** | ||
* Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned. | ||
* @param {number} value The number in question | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromNumber = function(value, unsigned) { | ||
unsigned = !!unsigned; | ||
if (isNaN(value) || !isFinite(value)) | ||
return Long.ZERO; | ||
if (!unsigned && value <= -TWO_PWR_63_DBL) | ||
return Long.MIN_VALUE; | ||
if (!unsigned && value + 1 >= TWO_PWR_63_DBL) | ||
return Long.MAX_VALUE; | ||
if (unsigned && value >= TWO_PWR_64_DBL) | ||
return Long.MAX_UNSIGNED_VALUE; | ||
if (value < 0) | ||
return Long.fromNumber(-value, unsigned).negate(); | ||
return new Long((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned); | ||
}; | ||
/** | ||
* Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned. | ||
* @param {number} value The number in question | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromNumber = function(value, unsigned) { | ||
unsigned = !!unsigned; | ||
if (isNaN(value) || !isFinite(value)) | ||
return Long.ZERO; | ||
if (!unsigned && value <= -TWO_PWR_63_DBL) | ||
return Long.MIN_VALUE; | ||
if (!unsigned && value + 1 >= TWO_PWR_63_DBL) | ||
return Long.MAX_VALUE; | ||
if (unsigned && value >= TWO_PWR_64_DBL) | ||
return Long.MAX_UNSIGNED_VALUE; | ||
if (value < 0) | ||
return Long.fromNumber(-value, unsigned).negate(); | ||
return new Long((value % TWO_PWR_32_DBL) | 0, (value / TWO_PWR_32_DBL) | 0, unsigned); | ||
}; | ||
/** | ||
* Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is | ||
* assumed to use 32 bits. | ||
* @param {number} lowBits The low 32 bits | ||
* @param {number} highBits The high 32 bits | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromBits = function(lowBits, highBits, unsigned) { | ||
return new Long(lowBits, highBits, unsigned); | ||
}; | ||
/** | ||
* Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is | ||
* assumed to use 32 bits. | ||
* @param {number} lowBits The low 32 bits | ||
* @param {number} highBits The high 32 bits | ||
* @param {boolean=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromBits = function(lowBits, highBits, unsigned) { | ||
return new Long(lowBits, highBits, unsigned); | ||
}; | ||
/** | ||
* Returns a Long representation of the given string, written using the specified radix. | ||
* @param {string} str The textual representation of the Long | ||
* @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @param {number=} radix The radix in which the text is written (2-36), defaults to 10 | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromString = function(str, unsigned, radix) { | ||
if (str.length === 0) | ||
throw Error('number format error: empty string'); | ||
if (str === "NaN" || str === "Infinity" || str === "+Infinity" || str === "-Infinity") | ||
return Long.ZERO; | ||
if (typeof unsigned === 'number') // For goog.math.long compatibility | ||
radix = unsigned, | ||
unsigned = false; | ||
radix = radix || 10; | ||
if (radix < 2 || 36 < radix) | ||
throw Error('radix out of range: ' + radix); | ||
var p; | ||
if ((p = str.indexOf('-')) > 0) | ||
throw Error('number format error: interior "-" character: ' + str); | ||
else if (p === 0) | ||
return Long.fromString(str.substring(1), unsigned, radix).negate(); | ||
/** | ||
* Returns a Long representation of the given string, written using the specified radix. | ||
* @param {string} str The textual representation of the Long | ||
* @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to `false` for signed | ||
* @param {number=} radix The radix in which the text is written (2-36), defaults to 10 | ||
* @returns {!Long} The corresponding Long value | ||
* @expose | ||
*/ | ||
Long.fromString = function(str, unsigned, radix) { | ||
if (str.length === 0) | ||
throw Error('number format error: empty string'); | ||
if (str === "NaN" || str === "Infinity" || str === "+Infinity" || str === "-Infinity") | ||
return Long.ZERO; | ||
if (typeof unsigned === 'number') // For goog.math.long compatibility | ||
radix = unsigned, | ||
unsigned = false; | ||
radix = radix || 10; | ||
if (radix < 2 || 36 < radix) | ||
throw Error('radix out of range: ' + radix); | ||
// Do several (8) digits each time through the loop, so as to | ||
// minimize the calls to the very expensive emulated div. | ||
var radixToPower = Long.fromNumber(Math.pow(radix, 8)); | ||
var p; | ||
if ((p = str.indexOf('-')) > 0) | ||
throw Error('number format error: interior "-" character: ' + str); | ||
else if (p === 0) | ||
return Long.fromString(str.substring(1), unsigned, radix).negate(); | ||
var result = Long.ZERO; | ||
for (var i = 0; i < str.length; i += 8) { | ||
var size = Math.min(8, str.length - i); | ||
var value = parseInt(str.substring(i, i + size), radix); | ||
if (size < 8) { | ||
var power = Long.fromNumber(Math.pow(radix, size)); | ||
result = result.multiply(power).add(Long.fromNumber(value)); | ||
} else { | ||
result = result.multiply(radixToPower); | ||
result = result.add(Long.fromNumber(value)); | ||
} | ||
// Do several (8) digits each time through the loop, so as to | ||
// minimize the calls to the very expensive emulated div. | ||
var radixToPower = Long.fromNumber(Math.pow(radix, 8)); | ||
var result = Long.ZERO; | ||
for (var i = 0; i < str.length; i += 8) { | ||
var size = Math.min(8, str.length - i); | ||
var value = parseInt(str.substring(i, i + size), radix); | ||
if (size < 8) { | ||
var power = Long.fromNumber(Math.pow(radix, size)); | ||
result = result.multiply(power).add(Long.fromNumber(value)); | ||
} else { | ||
result = result.multiply(radixToPower); | ||
result = result.add(Long.fromNumber(value)); | ||
} | ||
result.unsigned = unsigned; | ||
return result; | ||
}; | ||
} | ||
result.unsigned = unsigned; | ||
return result; | ||
}; | ||
/** | ||
* Converts the specified value to a Long. | ||
* @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.fromValue = function(val) { | ||
if (typeof val === 'number') | ||
return Long.fromNumber(val); | ||
if (typeof val === 'string') | ||
return Long.fromString(val); | ||
if (Long.isLong(val)) | ||
return val; | ||
// Throws for not an object (undefined, null): | ||
return new Long(val.low, val.high, val.unsigned); | ||
}; | ||
/** | ||
* Converts the specified value to a Long. | ||
* @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.fromValue = function(val) { | ||
if (val /* is compatible */ instanceof Long) | ||
return val; | ||
if (typeof val === 'number') | ||
return Long.fromNumber(val); | ||
if (typeof val === 'string') | ||
return Long.fromString(val); | ||
// Throws for non-objects, converts non-instanceof Long: | ||
return new Long(val.low, val.high, val.unsigned); | ||
}; | ||
// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be | ||
// no runtime penalty for these. | ||
// NOTE: the compiler should inline these constant values below and then remove these variables, so there should be | ||
// no runtime penalty for these. | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_16_DBL = 1 << 16; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_16_DBL = 1 << 16; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_24_DBL = 1 << 24; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_24_DBL = 1 << 24; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2; | ||
/** | ||
* @type {number} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2; | ||
/** | ||
* @type {!Long} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_24 = Long.fromInt(TWO_PWR_24_DBL); | ||
/** | ||
* @type {!Long} | ||
* @const | ||
* @inner | ||
*/ | ||
var TWO_PWR_24 = Long.fromInt(TWO_PWR_24_DBL); | ||
/** | ||
* Signed zero. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.ZERO = Long.fromInt(0); | ||
/** | ||
* Signed zero. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.ZERO = Long.fromInt(0); | ||
/** | ||
* Unsigned zero. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.UZERO = Long.fromInt(0, true); | ||
/** | ||
* Unsigned zero. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.UZERO = Long.fromInt(0, true); | ||
/** | ||
* Signed one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.ONE = Long.fromInt(1); | ||
/** | ||
* Signed one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.ONE = Long.fromInt(1); | ||
/** | ||
* Unsigned one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.UONE = Long.fromInt(1, true); | ||
/** | ||
* Unsigned one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.UONE = Long.fromInt(1, true); | ||
/** | ||
* Signed negative one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.NEG_ONE = Long.fromInt(-1); | ||
/** | ||
* Signed negative one. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.NEG_ONE = Long.fromInt(-1); | ||
/** | ||
* Maximum signed value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MAX_VALUE = Long.fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false); | ||
/** | ||
* Maximum signed value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MAX_VALUE = Long.fromBits(0xFFFFFFFF|0, 0x7FFFFFFF|0, false); | ||
/** | ||
* Maximum unsigned value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MAX_UNSIGNED_VALUE = Long.fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true); | ||
/** | ||
* Minimum signed value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MIN_VALUE = Long.fromBits(0, 0x80000000|0, false); | ||
/** | ||
* Maximum unsigned value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MAX_UNSIGNED_VALUE = Long.fromBits(0xFFFFFFFF|0, 0xFFFFFFFF|0, true); | ||
/** | ||
* Converts the Long to a 32 bit integer, assuming it is a 32 bit integer. | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.toInt = function() { | ||
return this.unsigned ? this.low >>> 0 : this.low; | ||
}; | ||
/** | ||
* Minimum signed value. | ||
* @type {!Long} | ||
* @expose | ||
*/ | ||
Long.MIN_VALUE = Long.fromBits(0, 0x80000000|0, false); | ||
/** | ||
* Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa). | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.toNumber = function() { | ||
if (this.unsigned) { | ||
return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0); | ||
} | ||
return this.high * TWO_PWR_32_DBL + (this.low >>> 0); | ||
}; | ||
/** | ||
* Converts the Long to a 32 bit integer, assuming it is a 32 bit integer. | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.toInt = function() { | ||
return this.unsigned ? this.low >>> 0 : this.low; | ||
}; | ||
/** | ||
* Converts the Long to a string written in the specified radix. | ||
* @param {number=} radix Radix (2-36), defaults to 10 | ||
* @returns {string} | ||
* @override | ||
* @throws {RangeError} If `radix` is out of range | ||
* @expose | ||
*/ | ||
Long.prototype.toString = function(radix) { | ||
radix = radix || 10; | ||
if (radix < 2 || 36 < radix) | ||
throw RangeError('radix out of range: ' + radix); | ||
if (this.isZero()) | ||
return '0'; | ||
var rem; | ||
if (this.isNegative()) { // Unsigned Longs are never negative | ||
if (this.equals(Long.MIN_VALUE)) { | ||
// We need to change the Long value before it can be negated, so we remove | ||
// the bottom-most digit in this base and then recurse to do the rest. | ||
var radixLong = Long.fromNumber(radix); | ||
var div = this.div(radixLong); | ||
rem = div.multiply(radixLong).subtract(this); | ||
return div.toString(radix) + rem.toInt().toString(radix); | ||
} else | ||
return '-' + this.negate().toString(radix); | ||
} | ||
/** | ||
* Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa). | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.toNumber = function() { | ||
if (this.unsigned) { | ||
return ((this.high >>> 0) * TWO_PWR_32_DBL) + (this.low >>> 0); | ||
} | ||
return this.high * TWO_PWR_32_DBL + (this.low >>> 0); | ||
}; | ||
// Do several (6) digits each time through the loop, so as to | ||
// minimize the calls to the very expensive emulated div. | ||
var radixToPower = Long.fromNumber(Math.pow(radix, 6), this.unsigned); | ||
rem = this; | ||
var result = ''; | ||
while (true) { | ||
var remDiv = rem.div(radixToPower), | ||
intval = rem.subtract(remDiv.multiply(radixToPower)).toInt() >>> 0, | ||
digits = intval.toString(radix); | ||
rem = remDiv; | ||
if (rem.isZero()) | ||
return digits + result; | ||
else { | ||
while (digits.length < 6) | ||
digits = '0' + digits; | ||
result = '' + digits + result; | ||
} | ||
/** | ||
* Converts the Long to a string written in the specified radix. | ||
* @param {number=} radix Radix (2-36), defaults to 10 | ||
* @returns {string} | ||
* @override | ||
* @throws {RangeError} If `radix` is out of range | ||
* @expose | ||
*/ | ||
Long.prototype.toString = function(radix) { | ||
radix = radix || 10; | ||
if (radix < 2 || 36 < radix) | ||
throw RangeError('radix out of range: ' + radix); | ||
if (this.isZero()) | ||
return '0'; | ||
var rem; | ||
if (this.isNegative()) { // Unsigned Longs are never negative | ||
if (this.equals(Long.MIN_VALUE)) { | ||
// We need to change the Long value before it can be negated, so we remove | ||
// the bottom-most digit in this base and then recurse to do the rest. | ||
var radixLong = Long.fromNumber(radix); | ||
var div = this.div(radixLong); | ||
rem = div.multiply(radixLong).subtract(this); | ||
return div.toString(radix) + rem.toInt().toString(radix); | ||
} else | ||
return '-' + this.negate().toString(radix); | ||
} | ||
// Do several (6) digits each time through the loop, so as to | ||
// minimize the calls to the very expensive emulated div. | ||
var radixToPower = Long.fromNumber(Math.pow(radix, 6), this.unsigned); | ||
rem = this; | ||
var result = ''; | ||
while (true) { | ||
var remDiv = rem.div(radixToPower), | ||
intval = rem.subtract(remDiv.multiply(radixToPower)).toInt() >>> 0, | ||
digits = intval.toString(radix); | ||
rem = remDiv; | ||
if (rem.isZero()) | ||
return digits + result; | ||
else { | ||
while (digits.length < 6) | ||
digits = '0' + digits; | ||
result = '' + digits + result; | ||
} | ||
}; | ||
} | ||
}; | ||
/** | ||
* Gets the high 32 bits as a signed integer. | ||
* @returns {number} Signed high bits | ||
* @expose | ||
*/ | ||
Long.prototype.getHighBits = function() { | ||
return this.high; | ||
}; | ||
/** | ||
* Gets the high 32 bits as a signed integer. | ||
* @returns {number} Signed high bits | ||
* @expose | ||
*/ | ||
Long.prototype.getHighBits = function() { | ||
return this.high; | ||
}; | ||
/** | ||
* Gets the high 32 bits as an unsigned integer. | ||
* @returns {number} Unsigned high bits | ||
* @expose | ||
*/ | ||
Long.prototype.getHighBitsUnsigned = function() { | ||
return this.high >>> 0; | ||
}; | ||
/** | ||
* Gets the high 32 bits as an unsigned integer. | ||
* @returns {number} Unsigned high bits | ||
* @expose | ||
*/ | ||
Long.prototype.getHighBitsUnsigned = function() { | ||
return this.high >>> 0; | ||
}; | ||
/** | ||
* Gets the low 32 bits as a signed integer. | ||
* @returns {number} Signed low bits | ||
* @expose | ||
*/ | ||
Long.prototype.getLowBits = function() { | ||
return this.low; | ||
}; | ||
/** | ||
* Gets the low 32 bits as a signed integer. | ||
* @returns {number} Signed low bits | ||
* @expose | ||
*/ | ||
Long.prototype.getLowBits = function() { | ||
return this.low; | ||
}; | ||
/** | ||
* Gets the low 32 bits as an unsigned integer. | ||
* @returns {number} Unsigned low bits | ||
* @expose | ||
*/ | ||
Long.prototype.getLowBitsUnsigned = function() { | ||
return this.low >>> 0; | ||
}; | ||
/** | ||
* Gets the low 32 bits as an unsigned integer. | ||
* @returns {number} Unsigned low bits | ||
* @expose | ||
*/ | ||
Long.prototype.getLowBitsUnsigned = function() { | ||
return this.low >>> 0; | ||
}; | ||
/** | ||
* Gets the number of bits needed to represent the absolute value of this Long. | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.getNumBitsAbs = function() { | ||
if (this.isNegative()) // Unsigned Longs are never negative | ||
return this.equals(Long.MIN_VALUE) ? 64 : this.negate().getNumBitsAbs(); | ||
var val = this.high != 0 ? this.high : this.low; | ||
for (var bit = 31; bit > 0; bit--) | ||
if ((val & (1 << bit)) != 0) | ||
break; | ||
return this.high != 0 ? bit + 33 : bit + 1; | ||
}; | ||
/** | ||
* Gets the number of bits needed to represent the absolute value of this Long. | ||
* @returns {number} | ||
* @expose | ||
*/ | ||
Long.prototype.getNumBitsAbs = function() { | ||
if (this.isNegative()) // Unsigned Longs are never negative | ||
return this.equals(Long.MIN_VALUE) ? 64 : this.negate().getNumBitsAbs(); | ||
var val = this.high != 0 ? this.high : this.low; | ||
for (var bit = 31; bit > 0; bit--) | ||
if ((val & (1 << bit)) != 0) | ||
break; | ||
return this.high != 0 ? bit + 33 : bit + 1; | ||
}; | ||
/** | ||
* Tests if this Long's value equals zero. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isZero = function() { | ||
return this.high === 0 && this.low === 0; | ||
}; | ||
/** | ||
* Tests if this Long's value equals zero. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isZero = function() { | ||
return this.high === 0 && this.low === 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is negative. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isNegative = function() { | ||
return !this.unsigned && this.high < 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is negative. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isNegative = function() { | ||
return !this.unsigned && this.high < 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is positive. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isPositive = function() { | ||
return this.unsigned || this.high >= 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is positive. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isPositive = function() { | ||
return this.unsigned || this.high >= 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is odd. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isOdd = function() { | ||
return (this.low & 1) === 1; | ||
}; | ||
/** | ||
* Tests if this Long's value is odd. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isOdd = function() { | ||
return (this.low & 1) === 1; | ||
}; | ||
/** | ||
* Tests if this Long's value is even. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isEven = function() { | ||
return (this.low & 1) === 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is even. | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.isEven = function() { | ||
return (this.low & 1) === 0; | ||
}; | ||
/** | ||
* Tests if this Long's value equals the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.equals = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1) | ||
return false; | ||
return this.high === other.high && this.low === other.low; | ||
}; | ||
/** | ||
* Tests if this Long's value equals the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.equals = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
if (this.unsigned !== other.unsigned && (this.high >>> 31) === 1 && (other.high >>> 31) === 1) | ||
return false; | ||
return this.high === other.high && this.low === other.low; | ||
}; | ||
/** | ||
* Tests if this Long's value differs from the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.notEquals = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return !this.equals(other); | ||
}; | ||
/** | ||
* Tests if this Long's value differs from the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.notEquals = function(other) { | ||
return !this.equals(/* validates */ other); | ||
}; | ||
/** | ||
* Tests if this Long's value is less than the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.lessThan = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) < 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is less than the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.lessThan = function(other) { | ||
return this.compare(/* validates */ other) < 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is less than or equal the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.lessThanOrEqual = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) <= 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is less than or equal the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.lessThanOrEqual = function(other) { | ||
return this.compare(/* validates */ other) <= 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is greater than the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.greaterThan = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) > 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is greater than the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.greaterThan = function(other) { | ||
return this.compare(/* validates */ other) > 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is greater than or equal the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.greaterThanOrEqual = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return this.compare(other) >= 0; | ||
}; | ||
/** | ||
* Tests if this Long's value is greater than or equal the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {boolean} | ||
* @expose | ||
*/ | ||
Long.prototype.greaterThanOrEqual = function(other) { | ||
return this.compare(/* validates */ other) >= 0; | ||
}; | ||
/** | ||
* Compares this Long's value with the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {number} 0 if they are the same, 1 if the this is greater and -1 | ||
* if the given one is greater | ||
* @expose | ||
*/ | ||
Long.prototype.compare = function(other) { | ||
if (this.equals(other)) | ||
return 0; | ||
var thisNeg = this.isNegative(), | ||
otherNeg = other.isNegative(); | ||
if (thisNeg && !otherNeg) | ||
return -1; | ||
if (!thisNeg && otherNeg) | ||
return 1; | ||
// At this point the sign bits are the same | ||
if (!this.unsigned) | ||
return this.subtract(other).isNegative() ? -1 : 1; | ||
// Both are positive if at least one is unsigned | ||
return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1; | ||
}; | ||
/** | ||
* Compares this Long's value with the specified's. | ||
* @param {!Long|number|string} other Other value | ||
* @returns {number} 0 if they are the same, 1 if the this is greater and -1 | ||
* if the given one is greater | ||
* @expose | ||
*/ | ||
Long.prototype.compare = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
if (this.equals(other)) | ||
return 0; | ||
var thisNeg = this.isNegative(), | ||
otherNeg = other.isNegative(); | ||
if (thisNeg && !otherNeg) | ||
return -1; | ||
if (!thisNeg && otherNeg) | ||
return 1; | ||
// At this point the sign bits are the same | ||
if (!this.unsigned) | ||
return this.subtract(other).isNegative() ? -1 : 1; | ||
// Both are positive if at least one is unsigned | ||
return (other.high >>> 0) > (this.high >>> 0) || (other.high === this.high && (other.low >>> 0) > (this.low >>> 0)) ? -1 : 1; | ||
}; | ||
/** | ||
* Negates this Long's value. | ||
* @returns {!Long} Negated Long | ||
* @expose | ||
*/ | ||
Long.prototype.negate = function() { | ||
if (!this.unsigned && this.equals(Long.MIN_VALUE)) | ||
return Long.MIN_VALUE; | ||
return this.not().add(Long.ONE); | ||
}; | ||
/** | ||
* Negates this Long's value. | ||
* @returns {!Long} Negated Long | ||
* @expose | ||
*/ | ||
Long.prototype.negate = function() { | ||
if (!this.unsigned && this.equals(Long.MIN_VALUE)) | ||
return Long.MIN_VALUE; | ||
return this.not().add(Long.ONE); | ||
}; | ||
/** | ||
* Returns the sum of this and the specified Long. | ||
* @param {!Long|number|string} addend Addend | ||
* @returns {!Long} Sum | ||
* @expose | ||
*/ | ||
Long.prototype.add = function(addend) { | ||
if (!Long.isLong(addend)) | ||
addend = Long.fromValue(addend); | ||
// Divide each number into 4 chunks of 16 bits, and then sum the chunks. | ||
var a48 = this.high >>> 16; | ||
var a32 = this.high & 0xFFFF; | ||
var a16 = this.low >>> 16; | ||
var a00 = this.low & 0xFFFF; | ||
/** | ||
* Returns the sum of this and the specified Long. | ||
* @param {!Long|number|string} addend Addend | ||
* @returns {!Long} Sum | ||
* @expose | ||
*/ | ||
Long.prototype.add = function(addend) { | ||
if (!Long.isLong(addend)) | ||
addend = Long.fromValue(addend); | ||
var b48 = addend.high >>> 16; | ||
var b32 = addend.high & 0xFFFF; | ||
var b16 = addend.low >>> 16; | ||
var b00 = addend.low & 0xFFFF; | ||
// Divide each number into 4 chunks of 16 bits, and then sum the chunks. | ||
var c48 = 0, c32 = 0, c16 = 0, c00 = 0; | ||
c00 += a00 + b00; | ||
c16 += c00 >>> 16; | ||
c00 &= 0xFFFF; | ||
c16 += a16 + b16; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c32 += a32 + b32; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c48 += a48 + b48; | ||
c48 &= 0xFFFF; | ||
return Long.fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned); | ||
}; | ||
var a48 = this.high >>> 16; | ||
var a32 = this.high & 0xFFFF; | ||
var a16 = this.low >>> 16; | ||
var a00 = this.low & 0xFFFF; | ||
/** | ||
* Returns the difference of this and the specified Long. | ||
* @param {!Long|number|string} subtrahend Subtrahend | ||
* @returns {!Long} Difference | ||
* @expose | ||
*/ | ||
Long.prototype.subtract = function(subtrahend) { | ||
if (!Long.isLong(subtrahend)) | ||
subtrahend = Long.fromValue(subtrahend); | ||
return this.add(subtrahend.negate()); | ||
}; | ||
var b48 = addend.high >>> 16; | ||
var b32 = addend.high & 0xFFFF; | ||
var b16 = addend.low >>> 16; | ||
var b00 = addend.low & 0xFFFF; | ||
/** | ||
* Returns the product of this and the specified Long. | ||
* @param {!Long|number|string} multiplier Multiplier | ||
* @returns {!Long} Product | ||
* @expose | ||
*/ | ||
Long.prototype.multiply = function(multiplier) { | ||
if (this.isZero()) | ||
return Long.ZERO; | ||
if (!Long.isLong(multiplier)) | ||
multiplier = Long.fromValue(multiplier); | ||
if (multiplier.isZero()) | ||
return Long.ZERO; | ||
if (this.equals(Long.MIN_VALUE)) | ||
return multiplier.isOdd() ? Long.MIN_VALUE : Long.ZERO; | ||
if (multiplier.equals(Long.MIN_VALUE)) | ||
return this.isOdd() ? Long.MIN_VALUE : Long.ZERO; | ||
if (this.isNegative()) { | ||
if (multiplier.isNegative()) | ||
return this.negate().multiply(multiplier.negate()); | ||
else | ||
return this.negate().multiply(multiplier).negate(); | ||
} else if (multiplier.isNegative()) | ||
return this.multiply(multiplier.negate()).negate(); | ||
// If both longs are small, use float multiplication | ||
if (this.lessThan(TWO_PWR_24) && multiplier.lessThan(TWO_PWR_24)) | ||
return Long.fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned); | ||
var c48 = 0, c32 = 0, c16 = 0, c00 = 0; | ||
c00 += a00 + b00; | ||
c16 += c00 >>> 16; | ||
c00 &= 0xFFFF; | ||
c16 += a16 + b16; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c32 += a32 + b32; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c48 += a48 + b48; | ||
c48 &= 0xFFFF; | ||
return Long.fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned); | ||
}; | ||
// Divide each long into 4 chunks of 16 bits, and then add up 4x4 products. | ||
// We can skip products that would overflow. | ||
var a48 = this.high >>> 16; | ||
var a32 = this.high & 0xFFFF; | ||
var a16 = this.low >>> 16; | ||
var a00 = this.low & 0xFFFF; | ||
/** | ||
* Returns the difference of this and the specified Long. | ||
* @param {!Long|number|string} subtrahend Subtrahend | ||
* @returns {!Long} Difference | ||
* @expose | ||
*/ | ||
Long.prototype.subtract = function(subtrahend) { | ||
if (!Long.isLong(subtrahend)) | ||
subtrahend = Long.fromValue(subtrahend); | ||
return this.add(subtrahend.negate()); | ||
}; | ||
var b48 = multiplier.high >>> 16; | ||
var b32 = multiplier.high & 0xFFFF; | ||
var b16 = multiplier.low >>> 16; | ||
var b00 = multiplier.low & 0xFFFF; | ||
/** | ||
* Returns the product of this and the specified Long. | ||
* @param {!Long|number|string} multiplier Multiplier | ||
* @returns {!Long} Product | ||
* @expose | ||
*/ | ||
Long.prototype.multiply = function(multiplier) { | ||
if (this.isZero()) | ||
return Long.ZERO; | ||
if (!Long.isLong(multiplier)) | ||
multiplier = Long.fromValue(multiplier); | ||
if (multiplier.isZero()) | ||
return Long.ZERO; | ||
if (this.equals(Long.MIN_VALUE)) | ||
return multiplier.isOdd() ? Long.MIN_VALUE : Long.ZERO; | ||
if (multiplier.equals(Long.MIN_VALUE)) | ||
return this.isOdd() ? Long.MIN_VALUE : Long.ZERO; | ||
var c48 = 0, c32 = 0, c16 = 0, c00 = 0; | ||
c00 += a00 * b00; | ||
c16 += c00 >>> 16; | ||
c00 &= 0xFFFF; | ||
c16 += a16 * b00; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c16 += a00 * b16; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c32 += a32 * b00; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c32 += a16 * b16; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c32 += a00 * b32; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48; | ||
c48 &= 0xFFFF; | ||
return Long.fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned); | ||
}; | ||
if (this.isNegative()) { | ||
if (multiplier.isNegative()) | ||
return this.negate().multiply(multiplier.negate()); | ||
else | ||
return this.negate().multiply(multiplier).negate(); | ||
} else if (multiplier.isNegative()) | ||
return this.multiply(multiplier.negate()).negate(); | ||
/** | ||
* Returns this Long divided by the specified. | ||
* @param {!Long|number|string} divisor Divisor | ||
* @returns {!Long} Quotient | ||
* @expose | ||
*/ | ||
Long.prototype.div = function(divisor) { | ||
if (!Long.isLong(divisor)) | ||
divisor = Long.fromValue(divisor); | ||
if (divisor.isZero()) | ||
throw(new Error('division by zero')); | ||
if (this.isZero()) | ||
return this.unsigned ? Long.UZERO : Long.ZERO; | ||
var approx, rem, res; | ||
if (this.equals(Long.MIN_VALUE)) { | ||
if (divisor.equals(Long.ONE) || divisor.equals(Long.NEG_ONE)) | ||
return Long.MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE | ||
else if (divisor.equals(Long.MIN_VALUE)) | ||
return Long.ONE; | ||
else { | ||
// At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|. | ||
var halfThis = this.shiftRight(1); | ||
approx = halfThis.div(divisor).shiftLeft(1); | ||
if (approx.equals(Long.ZERO)) { | ||
return divisor.isNegative() ? Long.ONE : Long.NEG_ONE; | ||
} else { | ||
rem = this.subtract(divisor.multiply(approx)); | ||
res = approx.add(rem.div(divisor)); | ||
return res; | ||
} | ||
} | ||
} else if (divisor.equals(Long.MIN_VALUE)) | ||
return this.unsigned ? Long.UZERO : Long.ZERO; | ||
if (this.isNegative()) { | ||
if (divisor.isNegative()) | ||
return this.negate().div(divisor.negate()); | ||
return this.negate().div(divisor).negate(); | ||
} else if (divisor.isNegative()) | ||
return this.div(divisor.negate()).negate(); | ||
// Repeat the following until the remainder is less than other: find a | ||
// floating-point that approximates remainder / other *from below*, add this | ||
// into the result, and subtract it from the remainder. It is critical that | ||
// the approximate value is less than or equal to the real value so that the | ||
// remainder never becomes negative. | ||
res = Long.ZERO; | ||
rem = this; | ||
while (rem.greaterThanOrEqual(divisor)) { | ||
// Approximate the result of division. This may be a little greater or | ||
// smaller than the actual value. | ||
approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber())); | ||
// If both longs are small, use float multiplication | ||
if (this.lessThan(TWO_PWR_24) && multiplier.lessThan(TWO_PWR_24)) | ||
return Long.fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned); | ||
// We will tweak the approximate result by changing it in the 48-th digit or | ||
// the smallest non-fractional digit, whichever is larger. | ||
var log2 = Math.ceil(Math.log(approx) / Math.LN2), | ||
delta = (log2 <= 48) ? 1 : Math.pow(2, log2 - 48), | ||
// Divide each long into 4 chunks of 16 bits, and then add up 4x4 products. | ||
// We can skip products that would overflow. | ||
// Decrease the approximation until it is smaller than the remainder. Note | ||
// that if it is too large, the product overflows and is negative. | ||
approxRes = Long.fromNumber(approx), | ||
approxRem = approxRes.multiply(divisor); | ||
while (approxRem.isNegative() || approxRem.greaterThan(rem)) { | ||
approx -= delta; | ||
approxRes = Long.fromNumber(approx, this.unsigned); | ||
approxRem = approxRes.multiply(divisor); | ||
var a48 = this.high >>> 16; | ||
var a32 = this.high & 0xFFFF; | ||
var a16 = this.low >>> 16; | ||
var a00 = this.low & 0xFFFF; | ||
var b48 = multiplier.high >>> 16; | ||
var b32 = multiplier.high & 0xFFFF; | ||
var b16 = multiplier.low >>> 16; | ||
var b00 = multiplier.low & 0xFFFF; | ||
var c48 = 0, c32 = 0, c16 = 0, c00 = 0; | ||
c00 += a00 * b00; | ||
c16 += c00 >>> 16; | ||
c00 &= 0xFFFF; | ||
c16 += a16 * b00; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c16 += a00 * b16; | ||
c32 += c16 >>> 16; | ||
c16 &= 0xFFFF; | ||
c32 += a32 * b00; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c32 += a16 * b16; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c32 += a00 * b32; | ||
c48 += c32 >>> 16; | ||
c32 &= 0xFFFF; | ||
c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48; | ||
c48 &= 0xFFFF; | ||
return Long.fromBits((c16 << 16) | c00, (c48 << 16) | c32, this.unsigned); | ||
}; | ||
/** | ||
* Returns this Long divided by the specified. | ||
* @param {!Long|number|string} divisor Divisor | ||
* @returns {!Long} Quotient | ||
* @expose | ||
*/ | ||
Long.prototype.div = function(divisor) { | ||
if (!Long.isLong(divisor)) | ||
divisor = Long.fromValue(divisor); | ||
if (divisor.isZero()) | ||
throw(new Error('division by zero')); | ||
if (this.isZero()) | ||
return this.unsigned ? Long.UZERO : Long.ZERO; | ||
var approx, rem, res; | ||
if (this.equals(Long.MIN_VALUE)) { | ||
if (divisor.equals(Long.ONE) || divisor.equals(Long.NEG_ONE)) | ||
return Long.MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE | ||
else if (divisor.equals(Long.MIN_VALUE)) | ||
return Long.ONE; | ||
else { | ||
// At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|. | ||
var halfThis = this.shiftRight(1); | ||
approx = halfThis.div(divisor).shiftLeft(1); | ||
if (approx.equals(Long.ZERO)) { | ||
return divisor.isNegative() ? Long.ONE : Long.NEG_ONE; | ||
} else { | ||
rem = this.subtract(divisor.multiply(approx)); | ||
res = approx.add(rem.div(divisor)); | ||
return res; | ||
} | ||
} | ||
} else if (divisor.equals(Long.MIN_VALUE)) | ||
return this.unsigned ? Long.UZERO : Long.ZERO; | ||
if (this.isNegative()) { | ||
if (divisor.isNegative()) | ||
return this.negate().div(divisor.negate()); | ||
return this.negate().div(divisor).negate(); | ||
} else if (divisor.isNegative()) | ||
return this.div(divisor.negate()).negate(); | ||
// We know the answer can't be zero... and actually, zero would cause | ||
// infinite recursion since we would make no progress. | ||
if (approxRes.isZero()) | ||
approxRes = Long.ONE; | ||
// Repeat the following until the remainder is less than other: find a | ||
// floating-point that approximates remainder / other *from below*, add this | ||
// into the result, and subtract it from the remainder. It is critical that | ||
// the approximate value is less than or equal to the real value so that the | ||
// remainder never becomes negative. | ||
res = Long.ZERO; | ||
rem = this; | ||
while (rem.greaterThanOrEqual(divisor)) { | ||
// Approximate the result of division. This may be a little greater or | ||
// smaller than the actual value. | ||
approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber())); | ||
res = res.add(approxRes); | ||
rem = rem.subtract(approxRem); | ||
// We will tweak the approximate result by changing it in the 48-th digit or | ||
// the smallest non-fractional digit, whichever is larger. | ||
var log2 = Math.ceil(Math.log(approx) / Math.LN2), | ||
delta = (log2 <= 48) ? 1 : Math.pow(2, log2 - 48), | ||
// Decrease the approximation until it is smaller than the remainder. Note | ||
// that if it is too large, the product overflows and is negative. | ||
approxRes = Long.fromNumber(approx), | ||
approxRem = approxRes.multiply(divisor); | ||
while (approxRem.isNegative() || approxRem.greaterThan(rem)) { | ||
approx -= delta; | ||
approxRes = Long.fromNumber(approx, this.unsigned); | ||
approxRem = approxRes.multiply(divisor); | ||
} | ||
return res; | ||
}; | ||
/** | ||
* Returns this Long modulo the specified. | ||
* @param {!Long|number|string} divisor Divisor | ||
* @returns {!Long} Remainder | ||
* @expose | ||
*/ | ||
Long.prototype.modulo = function(divisor) { | ||
if (!Long.isLong(divisor)) | ||
divisor = Long.fromValue(divisor); | ||
return this.subtract(this.div(divisor).multiply(divisor)); | ||
}; | ||
// We know the answer can't be zero... and actually, zero would cause | ||
// infinite recursion since we would make no progress. | ||
if (approxRes.isZero()) | ||
approxRes = Long.ONE; | ||
/** | ||
* Returns the bitwise NOT of this Long. | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.not = function() { | ||
return Long.fromBits(~this.low, ~this.high, this.unsigned); | ||
}; | ||
res = res.add(approxRes); | ||
rem = rem.subtract(approxRem); | ||
} | ||
return res; | ||
}; | ||
/** | ||
* Returns the bitwise AND of this Long and the specified. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.and = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low & other.low, this.high & other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns this Long modulo the specified. | ||
* @param {!Long|number|string} divisor Divisor | ||
* @returns {!Long} Remainder | ||
* @expose | ||
*/ | ||
Long.prototype.modulo = function(divisor) { | ||
if (!Long.isLong(divisor)) | ||
divisor = Long.fromValue(divisor); | ||
return this.subtract(this.div(divisor).multiply(divisor)); | ||
}; | ||
/** | ||
* Returns the bitwise OR of this Long and the specified. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.or = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low | other.low, this.high | other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns the bitwise NOT of this Long. | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.not = function() { | ||
return Long.fromBits(~this.low, ~this.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns the bitwise XOR of this Long and the given one. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.xor = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns the bitwise AND of this Long and the specified. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.and = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low & other.low, this.high & other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns this Long with bits shifted to the left by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftLeft = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
if ((numBits &= 63) === 0) | ||
return this; | ||
else if (numBits < 32) | ||
return Long.fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned); | ||
else | ||
return Long.fromBits(0, this.low << (numBits - 32), this.unsigned); | ||
}; | ||
/** | ||
* Returns the bitwise OR of this Long and the specified. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.or = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low | other.low, this.high | other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns this Long with bits arithmetically shifted to the right by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftRight = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
if ((numBits &= 63) === 0) | ||
return this; | ||
else if (numBits < 32) | ||
return Long.fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned); | ||
else | ||
return Long.fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned); | ||
}; | ||
/** | ||
* Returns the bitwise XOR of this Long and the given one. | ||
* @param {!Long|number|string} other Other Long | ||
* @returns {!Long} | ||
* @expose | ||
*/ | ||
Long.prototype.xor = function(other) { | ||
if (!Long.isLong(other)) | ||
other = Long.fromValue(other); | ||
return Long.fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned); | ||
}; | ||
/** | ||
* Returns this Long with bits logically shifted to the right by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftRightUnsigned = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
numBits &= 63; | ||
if (numBits === 0) | ||
return this; | ||
else { | ||
var high = this.high; | ||
if (numBits < 32) { | ||
var low = this.low; | ||
return Long.fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned); | ||
} else if (numBits === 32) | ||
return Long.fromBits(high, 0, this.unsigned); | ||
else | ||
return Long.fromBits(high >>> (numBits - 32), 0, this.unsigned); | ||
} | ||
}; | ||
/** | ||
* Returns this Long with bits shifted to the left by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftLeft = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
if ((numBits &= 63) === 0) | ||
return this; | ||
else if (numBits < 32) | ||
return Long.fromBits(this.low << numBits, (this.high << numBits) | (this.low >>> (32 - numBits)), this.unsigned); | ||
else | ||
return Long.fromBits(0, this.low << (numBits - 32), this.unsigned); | ||
}; | ||
/** | ||
* Converts this Long to signed. | ||
* @returns {!Long} Signed long | ||
* @expose | ||
*/ | ||
Long.prototype.toSigned = function() { | ||
if (!this.unsigned) | ||
return this; | ||
return new Long(this.low, this.high, false); | ||
}; | ||
/** | ||
* Returns this Long with bits arithmetically shifted to the right by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftRight = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
if ((numBits &= 63) === 0) | ||
return this; | ||
else if (numBits < 32) | ||
return Long.fromBits((this.low >>> numBits) | (this.high << (32 - numBits)), this.high >> numBits, this.unsigned); | ||
else | ||
return Long.fromBits(this.high >> (numBits - 32), this.high >= 0 ? 0 : -1, this.unsigned); | ||
}; | ||
/** | ||
* Converts this Long to unsigned. | ||
* @returns {!Long} Unsigned long | ||
* @expose | ||
*/ | ||
Long.prototype.toUnsigned = function() { | ||
if (this.unsigned) | ||
return this; | ||
return new Long(this.low, this.high, true); | ||
}; | ||
/** | ||
* Returns this Long with bits logically shifted to the right by the given amount. | ||
* @param {number|!Long} numBits Number of bits | ||
* @returns {!Long} Shifted Long | ||
* @expose | ||
*/ | ||
Long.prototype.shiftRightUnsigned = function(numBits) { | ||
if (Long.isLong(numBits)) | ||
numBits = numBits.toInt(); | ||
numBits &= 63; | ||
if (numBits === 0) | ||
return this; | ||
else { | ||
var high = this.high; | ||
if (numBits < 32) { | ||
var low = this.low; | ||
return Long.fromBits((low >>> numBits) | (high << (32 - numBits)), high >>> numBits, this.unsigned); | ||
} else if (numBits === 32) | ||
return Long.fromBits(high, 0, this.unsigned); | ||
else | ||
return Long.fromBits(high >>> (numBits - 32), 0, this.unsigned); | ||
} | ||
}; | ||
/* CommonJS */ if (typeof require === 'function' && typeof module === 'object' && module && typeof exports === 'object' && exports) | ||
module["exports"] = Long; | ||
/* AMD */ else if (typeof define === 'function' && define["amd"]) | ||
define(function() { return Long; }); | ||
/* Global */ else | ||
(global["dcodeIO"] = global["dcodeIO"] || {})["Long"] = Long; | ||
/** | ||
* Converts this Long to signed. | ||
* @returns {!Long} Signed long | ||
* @expose | ||
*/ | ||
Long.prototype.toSigned = function() { | ||
if (!this.unsigned) | ||
return this; | ||
return new Long(this.low, this.high, false); | ||
}; | ||
})(this); | ||
/** | ||
* Converts this Long to unsigned. | ||
* @returns {!Long} Unsigned long | ||
* @expose | ||
*/ | ||
Long.prototype.toUnsigned = function() { | ||
if (this.unsigned) | ||
return this; | ||
return new Long(this.low, this.high, true); | ||
}; |
@@ -35,2 +35,10 @@ /* | ||
}, | ||
"isLong": function(test) { | ||
var longVal = new Long(0xFFFFFFFF, 0x7FFFFFFF); | ||
test.strictEqual(Long.isLong(longVal), true); | ||
longVal = {"__isLong__": true}; | ||
test.strictEqual(Long.isLong(longVal), true); | ||
test.done(); | ||
}, | ||
@@ -37,0 +45,0 @@ // Let's assume goog.math.Long has been tested properly and focus on our extensions: |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Native code
Supply chain riskContains native code (e.g., compiled binaries or shared libraries). Including native code can obscure malicious behavior.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
24
2914
179683
1