{"version":3,"sources":["webpack:///./node_modules/create-hmac/browser.js","webpack:///./node_modules/crypto-browserify/index.js","webpack:///./node_modules/create-ecdh/node_modules/bn.js/lib/bn.js","webpack:///./node_modules/create-hash/md5.js","webpack:///./node_modules/create-hash/browser.js","webpack:///./node_modules/create-hmac/legacy.js","webpack:///./node_modules/create-ecdh/browser.js"],"names":["inherits","Legacy","Base","Buffer","md5","RIPEMD160","sha","ZEROS","alloc","Hmac","alg","key","call","this","from","blocksize","_alg","_key","length","hash","update","digest","concat","ipad","_ipad","allocUnsafe","opad","_opad","i","_hash","prototype","_update","data","_final","h","module","exports","toLowerCase","randomBytes","rng","pseudoRandomBytes","prng","createHash","Hash","createHmac","algos","algoKeys","Object","keys","hashes","getHashes","p","pbkdf2","pbkdf2Sync","aes","Cipher","createCipher","Cipheriv","createCipheriv","Decipher","createDecipher","Decipheriv","createDecipheriv","getCiphers","listCiphers","dh","DiffieHellmanGroup","createDiffieHellmanGroup","getDiffieHellman","createDiffieHellman","DiffieHellman","sign","createSign","Sign","createVerify","Verify","createECDH","publicEncrypt","privateEncrypt","publicDecrypt","privateDecrypt","rf","randomFill","randomFillSync","createCredentials","Error","join","constants","assert","val","msg","ctor","superCtor","super_","TempCtor","constructor","BN","number","base","endian","isBN","negative","words","red","_init","wordSize","e","parseHex","str","start","end","r","len","Math","min","c","charCodeAt","parseBase","mul","num","Array","isArray","max","left","right","cmp","_initNumber","_initArray","toString","replace","_parseHex","_parseBase","strip","toArray","ceil","j","w","off","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","dest","clone","_expand","size","_normSign","inspect","zeros","groupSizes","groupBases","toBitArray","bitLength","bit","wbit","smallMulTo","self","out","a","b","lo","carry","k","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","res","q","andln","iushrn","clz32","_countBits","t","_zeroBits","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","iadd","isub","add","sub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","imul","w0","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","fftm","FFTM","mulp","x","y","mulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","s","rtwdf","cos","PI","itwdf","sin","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","n","m","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","iushln","bits","carryMask","newCarry","ishln","hint","extended","mask","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","isubn","addn","subn","iabs","_ishlnsubmul","shift","_wordDiv","mode","bhi","bhiBits","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","acc","egcd","A","B","C","D","g","isEven","yp","xp","im","isOdd","jm","gcd","_invmp","x1","x2","delta","cmpn","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","toRed","ctx","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","redSqr","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","redPow","primes","k256","p224","p192","p25519","MPrime","name","tmp","_tmp","K256","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","_strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","windowSize","wnd","current","currentLen","mont","u","MD5","buffer","push","curve","ECDH","aliases","secp256k1","secp224r1","prime256v1","prime192v1","ed25519","secp384r1","secp521r1","curveType","elliptic","ec","formatReturnValue","bn","enc","buf","fill","p256","secp256r1","secp192r1","p384","p521","generateKeys","format","genKeyPair","getPublicKey","computeSecret","other","inenc","isBuffer","otherPub","keyFromPublic","getPublic","getPrivate","getX","getPrivateKey","setPublicKey","pub","_importPublic","setPrivateKey","priv","_priv","_importPrivate"],"mappings":"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","file":"js/chunk-vendors~8a3ac071.bae3f201.js","sourcesContent":["'use strict'\nvar inherits = require('inherits')\nvar Legacy = require('./legacy')\nvar Base = require('cipher-base')\nvar Buffer = require('safe-buffer').Buffer\nvar md5 = require('create-hash/md5')\nvar RIPEMD160 = require('ripemd160')\n\nvar sha = require('sha.js')\n\nvar ZEROS = Buffer.alloc(128)\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64\n\n this._alg = alg\n this._key = key\n if (key.length > blocksize) {\n var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n key = hash.update(key).digest()\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n this._hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n this._hash.update(ipad)\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._hash.digest()\n var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg)\n return hash.update(this._opad).update(h).digest()\n}\n\nmodule.exports = function createHmac (alg, key) {\n alg = alg.toLowerCase()\n if (alg === 'rmd160' || alg === 'ripemd160') {\n return new Hmac('rmd160', key)\n }\n if (alg === 'md5') {\n return new Legacy(md5, key)\n }\n return new Hmac(alg, key)\n}\n","'use strict'\n\nexports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes')\nexports.createHash = exports.Hash = require('create-hash')\nexports.createHmac = exports.Hmac = require('create-hmac')\n\nvar algos = require('browserify-sign/algos')\nvar algoKeys = Object.keys(algos)\nvar hashes = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160'].concat(algoKeys)\nexports.getHashes = function () {\n return hashes\n}\n\nvar p = require('pbkdf2')\nexports.pbkdf2 = p.pbkdf2\nexports.pbkdf2Sync = p.pbkdf2Sync\n\nvar aes = require('browserify-cipher')\n\nexports.Cipher = aes.Cipher\nexports.createCipher = aes.createCipher\nexports.Cipheriv = aes.Cipheriv\nexports.createCipheriv = aes.createCipheriv\nexports.Decipher = aes.Decipher\nexports.createDecipher = aes.createDecipher\nexports.Decipheriv = aes.Decipheriv\nexports.createDecipheriv = aes.createDecipheriv\nexports.getCiphers = aes.getCiphers\nexports.listCiphers = aes.listCiphers\n\nvar dh = require('diffie-hellman')\n\nexports.DiffieHellmanGroup = dh.DiffieHellmanGroup\nexports.createDiffieHellmanGroup = dh.createDiffieHellmanGroup\nexports.getDiffieHellman = dh.getDiffieHellman\nexports.createDiffieHellman = dh.createDiffieHellman\nexports.DiffieHellman = dh.DiffieHellman\n\nvar sign = require('browserify-sign')\n\nexports.createSign = sign.createSign\nexports.Sign = sign.Sign\nexports.createVerify = sign.createVerify\nexports.Verify = sign.Verify\n\nexports.createECDH = require('create-ecdh')\n\nvar publicEncrypt = require('public-encrypt')\n\nexports.publicEncrypt = publicEncrypt.publicEncrypt\nexports.privateEncrypt = publicEncrypt.privateEncrypt\nexports.publicDecrypt = publicEncrypt.publicDecrypt\nexports.privateDecrypt = publicEncrypt.privateDecrypt\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\n// ;[\n// 'createCredentials'\n// ].forEach(function (name) {\n// exports[name] = function () {\n// throw new Error([\n// 'sorry, ' + name + ' is not implemented yet',\n// 'we accept pull requests',\n// 'https://github.com/crypto-browserify/crypto-browserify'\n// ].join('\\n'))\n// }\n// })\n\nvar rf = require('randomfill')\n\nexports.randomFill = rf.randomFill\nexports.randomFillSync = rf.randomFillSync\n\nexports.createCredentials = function () {\n throw new Error([\n 'sorry, createCredentials is not implemented yet',\n 'we accept pull requests',\n 'https://github.com/crypto-browserify/crypto-browserify'\n ].join('\\n'))\n}\n\nexports.constants = {\n 'DH_CHECK_P_NOT_SAFE_PRIME': 2,\n 'DH_CHECK_P_NOT_PRIME': 1,\n 'DH_UNABLE_TO_CHECK_GENERATOR': 4,\n 'DH_NOT_SUITABLE_GENERATOR': 8,\n 'NPN_ENABLED': 1,\n 'ALPN_ENABLED': 1,\n 'RSA_PKCS1_PADDING': 1,\n 'RSA_SSLV23_PADDING': 2,\n 'RSA_NO_PADDING': 3,\n 'RSA_PKCS1_OAEP_PADDING': 4,\n 'RSA_X931_PADDING': 5,\n 'RSA_PKCS1_PSS_PADDING': 6,\n 'POINT_CONVERSION_COMPRESSED': 2,\n 'POINT_CONVERSION_UNCOMPRESSED': 4,\n 'POINT_CONVERSION_HYBRID': 6\n}\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n Buffer = require('buffer').Buffer;\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n }\n\n if (base === 16) {\n this._parseHex(number, start);\n } else {\n this._parseBase(number, base, start);\n }\n\n if (number[0] === '-') {\n this.negative = 1;\n }\n\n this.strip();\n\n if (endian !== 'le') return;\n\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [ number & 0x3ffffff ];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [ 0 ];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n\n function parseHex (str, start, end) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r <<= 4;\n\n // 'a' - 'f'\n if (c >= 49 && c <= 54) {\n r |= c - 49 + 0xa;\n\n // 'A' - 'F'\n } else if (c >= 17 && c <= 22) {\n r |= c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r |= c & 0xf;\n }\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n // Scan 24-bit chunks and add them to the number\n var off = 0;\n for (i = number.length - 6, j = 0; i >= start; i -= 6) {\n w = parseHex(number, i, i + 6);\n this.words[j] |= (w << off) & 0x3ffffff;\n // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb\n this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n if (i + 6 !== start) {\n w = parseHex(number, start, i + 6);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\n }\n this.strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [ 0 ];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n BN.prototype.inspect = function inspect () {\n return (this.red ? '';\n };\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this.strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this.strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this.strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out.strip();\n }\n\n function jumboMulTo (self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n\n return this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this.strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this.strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this.strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modn = function modn (num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n return this.strip();\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this.strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","var MD5 = require('md5.js')\n\nmodule.exports = function (buffer) {\n return new MD5().update(buffer).digest()\n}\n","'use strict'\nvar inherits = require('inherits')\nvar MD5 = require('md5.js')\nvar RIPEMD160 = require('ripemd160')\nvar sha = require('sha.js')\nvar Base = require('cipher-base')\n\nfunction Hash (hash) {\n Base.call(this, 'digest')\n\n this._hash = hash\n}\n\ninherits(Hash, Base)\n\nHash.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHash.prototype._final = function () {\n return this._hash.digest()\n}\n\nmodule.exports = function createHash (alg) {\n alg = alg.toLowerCase()\n if (alg === 'md5') return new MD5()\n if (alg === 'rmd160' || alg === 'ripemd160') return new RIPEMD160()\n\n return new Hash(sha(alg))\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar Base = require('cipher-base')\n\nvar ZEROS = Buffer.alloc(128)\nvar blocksize = 64\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n this._alg = alg\n this._key = key\n\n if (key.length > blocksize) {\n key = alg(key)\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n\n this._hash = [ipad]\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.push(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._alg(Buffer.concat(this._hash))\n return this._alg(Buffer.concat([this._opad, h]))\n}\nmodule.exports = Hmac\n","var elliptic = require('elliptic')\nvar BN = require('bn.js')\n\nmodule.exports = function createECDH (curve) {\n return new ECDH(curve)\n}\n\nvar aliases = {\n secp256k1: {\n name: 'secp256k1',\n byteLength: 32\n },\n secp224r1: {\n name: 'p224',\n byteLength: 28\n },\n prime256v1: {\n name: 'p256',\n byteLength: 32\n },\n prime192v1: {\n name: 'p192',\n byteLength: 24\n },\n ed25519: {\n name: 'ed25519',\n byteLength: 32\n },\n secp384r1: {\n name: 'p384',\n byteLength: 48\n },\n secp521r1: {\n name: 'p521',\n byteLength: 66\n }\n}\n\naliases.p224 = aliases.secp224r1\naliases.p256 = aliases.secp256r1 = aliases.prime256v1\naliases.p192 = aliases.secp192r1 = aliases.prime192v1\naliases.p384 = aliases.secp384r1\naliases.p521 = aliases.secp521r1\n\nfunction ECDH (curve) {\n this.curveType = aliases[curve]\n if (!this.curveType) {\n this.curveType = {\n name: curve\n }\n }\n this.curve = new elliptic.ec(this.curveType.name) // eslint-disable-line new-cap\n this.keys = void 0\n}\n\nECDH.prototype.generateKeys = function (enc, format) {\n this.keys = this.curve.genKeyPair()\n return this.getPublicKey(enc, format)\n}\n\nECDH.prototype.computeSecret = function (other, inenc, enc) {\n inenc = inenc || 'utf8'\n if (!Buffer.isBuffer(other)) {\n other = new Buffer(other, inenc)\n }\n var otherPub = this.curve.keyFromPublic(other).getPublic()\n var out = otherPub.mul(this.keys.getPrivate()).getX()\n return formatReturnValue(out, enc, this.curveType.byteLength)\n}\n\nECDH.prototype.getPublicKey = function (enc, format) {\n var key = this.keys.getPublic(format === 'compressed', true)\n if (format === 'hybrid') {\n if (key[key.length - 1] % 2) {\n key[0] = 7\n } else {\n key[0] = 6\n }\n }\n return formatReturnValue(key, enc)\n}\n\nECDH.prototype.getPrivateKey = function (enc) {\n return formatReturnValue(this.keys.getPrivate(), enc)\n}\n\nECDH.prototype.setPublicKey = function (pub, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc)\n }\n this.keys._importPublic(pub)\n return this\n}\n\nECDH.prototype.setPrivateKey = function (priv, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc)\n }\n\n var _priv = new BN(priv)\n _priv = _priv.toString(16)\n this.keys = this.curve.genKeyPair()\n this.keys._importPrivate(_priv)\n return this\n}\n\nfunction formatReturnValue (bn, enc, len) {\n if (!Array.isArray(bn)) {\n bn = bn.toArray()\n }\n var buf = new Buffer(bn)\n if (len && buf.length < len) {\n var zeros = new Buffer(len - buf.length)\n zeros.fill(0)\n buf = Buffer.concat([zeros, buf])\n }\n if (!enc) {\n return buf\n } else {\n return buf.toString(enc)\n }\n}\n"],"sourceRoot":""}