{"version":3,"sources":["../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../src/utils.ts","../../src/error.ts","../../src/struct.ts","../../src/structs/utilities.ts","../../src/structs/types.ts","../node_modules/@babel/runtime/helpers/esm/toArray.js","../../src/structs/coercions.ts","../node_modules/@babel/runtime/regenerator/index.js","../../src/Layout.ts","../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/node-libs-browser/node_modules/buffer/index.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../../src/util/to-buffer.ts","../../node_modules/minimalistic-assert/index.js","../../node_modules/inherits/inherits_browser.js","../../node_modules/hash.js/lib/hash/utils.js","../../node_modules/hash.js/lib/hash/common.js","../../node_modules/hash.js/lib/hash/sha/common.js","../../node_modules/hash.js/lib/hash/sha/1.js","../../node_modules/hash.js/lib/hash/sha/256.js","../../node_modules/hash.js/lib/hash/sha/224.js","../../node_modules/hash.js/lib/hash/sha/512.js","../../node_modules/hash.js/lib/hash/sha/384.js","../../node_modules/hash.js/lib/hash/sha.js","../../node_modules/hash.js/lib/hash/ripemd.js","../../node_modules/hash.js/lib/hash/hmac.js","../../node_modules/hash.js/lib/hash.js","../../node_modules/@ethersproject/logger/lib.esm/index.js","../../node_modules/@ethersproject/logger/lib.esm/_version.js","../../node_modules/@ethersproject/bytes/lib.esm/_version.js","../../node_modules/@ethersproject/bytes/lib.esm/index.js","../../node_modules/@ethersproject/sha2/lib.esm/sha2.js","../../node_modules/@ethersproject/sha2/lib.esm/_version.js","../../src/util/borsh-schema.ts","../../src/publickey.ts","../../src/account.ts","../../src/bpf-loader-deprecated.ts","../../src/layout.ts","../../src/util/shortvec-encoding.ts","../../src/message.ts","../../src/util/assert.ts","../../src/transaction.ts","../../src/sysvar.ts","../../src/util/send-and-confirm-transaction.ts","../../src/util/sleep.ts","../../src/instruction.ts","../../src/fee-calculator.ts","../../src/nonce-account.ts","../../src/system-program.ts","../../src/loader.ts","../../src/bpf-loader.ts","../../node_modules/cross-fetch/dist/browser-ponyfill.js","../../src/epoch-schedule.ts","../../src/errors.ts","../../src/util/promise-timeout.ts","../../src/connection.ts","../../src/util/url.ts","../../src/keypair.ts","../../src/ed25519-program.ts","../../src/stake-program.ts","../../src/secp256k1-program.ts","../../src/validator-info.ts","../../src/vote-account.ts","../../src/util/send-and-confirm-raw-transaction.ts","../../src/util/cluster.ts","../../src/index.ts","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../../../src/index.ts","../node_modules/bs58/index.js","../../../../src/program/common.ts","../node_modules/react/jsx-runtime.js","../node_modules/camelcase/index.js","../../../../src/coder/index.ts","../../../src/error.ts","../node_modules/js-sha256/src/sha256.js","../node_modules/tweetnacl/nacl-fast.js","../node_modules/elliptic/lib/elliptic/utils.js","../node_modules/hash.js/lib/hash/utils.js","../node_modules/bn.js/lib/bn.js","../node_modules/react/index.js","../node_modules/pako/dist/pako.esm.mjs","../../../../src/program/context.ts","../../../../src/program/namespace/instruction.ts","../../../../src/program/namespace/rpc.ts","../../../../src/program/namespace/transaction.ts","../../../../src/program/namespace/state.ts","../../../../src/program/event.ts","../../../../src/program/namespace/simulate.ts","../../../../src/program/namespace/index.ts","../../../../src/utils/bytes/utf8.ts","../../../../src/program/index.ts","../../../src/workspace.ts","../../../../src/utils/token.ts","../node_modules/elliptic/node_modules/bn.js/lib/bn.js","../../../../src/coder/idl.ts","../../../../src/utils/pubkey.ts","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../../../../src/coder/common.ts","../node_modules/base64-js/index.js","../node_modules/minimalistic-assert/index.js","../node_modules/process/browser.js","../../../src/provider.ts","../node_modules/@babel/runtime/helpers/esm/construct.js","../node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","../node_modules/assert/assert.js","../node_modules/webpack/buildin/global.js","../node_modules/@babel/runtime/helpers/classCallCheck.js","../node_modules/@babel/runtime/helpers/inherits.js","../node_modules/eventemitter3/index.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../../../../src/utils/common.ts","../node_modules/@babel/runtime/helpers/createClass.js","../node_modules/@babel/runtime/helpers/getPrototypeOf.js","../node_modules/hash.js/lib/hash/common.js","../../../../src/coder/accounts.ts","../../../../src/coder/event.ts","../../../../src/coder/state.ts","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/object-assign/index.js","../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","../node_modules/elliptic/lib/elliptic/curve/base.js","../node_modules/inherits/inherits_browser.js","../../../../src/coder/instruction.ts","../../../../src/utils/features.ts","../../../../src/program/namespace/account.ts","../../../../src/utils/rpc.ts","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/borsh/lib/index.js","../node_modules/@babel/runtime/helpers/createForOfIteratorHelper.js","../node_modules/@babel/runtime/helpers/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/createSuper.js","../node_modules/@babel/runtime/helpers/interopRequireDefault.js","../node_modules/elliptic/lib/elliptic/curves.js","../node_modules/hash.js/lib/hash.js","../node_modules/util/util.js","../node_modules/secp256k1/elliptic.js","../node_modules/js-sha3/src/sha3.js","../../../src/idl.ts","../node_modules/webpack/buildin/module.js","../node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","../node_modules/@babel/runtime/helpers/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/typeof.js","../node_modules/@babel/runtime/helpers/assertThisInitialized.js","../node_modules/minimalistic-crypto-utils/lib/utils.js","../node_modules/brorand/index.js","../node_modules/elliptic/lib/elliptic/curve/index.js","../node_modules/hash.js/lib/hash/sha/common.js","../node_modules/hash.js/lib/hash/sha/256.js","../node_modules/hash.js/lib/hash/sha/512.js","../node_modules/webpack/buildin/amd-options.js","../node_modules/buffer-layout/lib/Layout.js","../../../../src/utils/bytes/hex.ts","../../../../src/utils/bytes/base64.ts","../node_modules/uuid/dist/esm-browser/rng.js","../node_modules/uuid/dist/esm-browser/regex.js","../node_modules/uuid/dist/esm-browser/stringify.js","../node_modules/uuid/dist/esm-browser/validate.js","../node_modules/uuid/dist/esm-browser/v1.js","../node_modules/uuid/dist/esm-browser/parse.js","../node_modules/uuid/dist/esm-browser/v35.js","../node_modules/uuid/dist/esm-browser/md5.js","../node_modules/uuid/dist/esm-browser/v3.js","../node_modules/uuid/dist/esm-browser/v4.js","../node_modules/uuid/dist/esm-browser/sha1.js","../node_modules/uuid/dist/esm-browser/v5.js","../node_modules/uuid/dist/esm-browser/nil.js","../node_modules/uuid/dist/esm-browser/version.js","../node_modules/react-dom/index.js","../node_modules/rpc-websockets/dist/index.browser.js","../node_modules/jayson/lib/client/browser/index.js","../node_modules/toml/index.js","../node_modules/tslib/tslib.es6.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/scheduler/index.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/regenerator-runtime/runtime.js","../node_modules/ieee754/index.js","../node_modules/isarray/index.js","../node_modules/base-x/src/index.js","../node_modules/safe-buffer/index.js","../node_modules/@babel/runtime/helpers/defineProperty.js","../node_modules/@babel/runtime/helpers/slicedToArray.js","../node_modules/@babel/runtime/helpers/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/nonIterableRest.js","../node_modules/@babel/runtime/helpers/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/isNativeFunction.js","../node_modules/@babel/runtime/helpers/construct.js","../node_modules/text-encoding-utf-8/lib/encoding.lib.mjs","../node_modules/rpc-websockets/dist/lib/client/websocket.browser.js","../node_modules/rpc-websockets/dist/lib/client.js","../node_modules/@babel/runtime/helpers/asyncToGenerator.js","../node_modules/circular-json/build/circular-json.node.js","../node_modules/jayson/lib/generateRequest.js","../node_modules/secp256k1/lib/index.js","../node_modules/secp256k1/lib/elliptic.js","../node_modules/elliptic/lib/elliptic.js","../node_modules/elliptic/lib/elliptic/curve/short.js","../node_modules/elliptic/lib/elliptic/curve/mont.js","../node_modules/elliptic/lib/elliptic/curve/edwards.js","../node_modules/hash.js/lib/hash/sha.js","../node_modules/hash.js/lib/hash/sha/1.js","../node_modules/hash.js/lib/hash/sha/224.js","../node_modules/hash.js/lib/hash/sha/384.js","../node_modules/hash.js/lib/hash/ripemd.js","../node_modules/hash.js/lib/hash/hmac.js","../node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js","../node_modules/elliptic/lib/elliptic/ec/index.js","../node_modules/hmac-drbg/lib/hmac-drbg.js","../node_modules/elliptic/lib/elliptic/ec/key.js","../node_modules/elliptic/lib/elliptic/ec/signature.js","../node_modules/elliptic/lib/elliptic/eddsa/index.js","../node_modules/elliptic/lib/elliptic/eddsa/key.js","../node_modules/elliptic/lib/elliptic/eddsa/signature.js","../node_modules/toml/lib/parser.js","../node_modules/toml/lib/compiler.js","../node_modules/util/support/isBufferBrowser.js","../node_modules/util/node_modules/inherits/inherits_browser.js","../node_modules/path-browserify/index.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js"],"names":["_objectWithoutProperties","source","excluded","key","i","target","sourceKeys","Object","keys","length","indexOf","getOwnPropertySymbols","sourceSymbolKeys","prototype","propertyIsEnumerable","call","toFailures","run","StructError","constructor","failure","failures","rest","path","msg","cached","TypeError","isObject","x","print","value","JSON","shiftIterator","input","done","undefined","toFailure","result","context","struct","message","branch","type","refinement","Symbol","r","options","coerce","mask","ctx","Array","valid","ts","v","s","k","t","Struct","props","coercer","entries","this","validator","refiner","assert","create","is","validate","tuples","tuple","error","f","define","name","schema","any","array","Element","boolean","instance","Class","literal","constant","description","never","nullable","number","isNaN","optional","record","Key","Value","string","Elements","Never","Math","union","Structs","arr","arrayWithHoles","iterableToArray","unsupportedIterableToArray","nonIterableRest","unknown","condition","module","exports","Layout","makeDestinationObject","ExternalLayout","isCount","GreedyCount","layout","offset","_this","IntBE","asyncGeneratorStep","gen","resolve","reject","_next","_throw","arg","info","Promise","then","_asyncToGenerator","fn","self","args","arguments","apply","err","_classCallCheck","Constructor","_defineProperties","descriptor","enumerable","configurable","writable","defineProperty","_createClass","protoProps","staticProps","base64","require","ieee754","isArray","kMaxLength","Buffer","TYPED_ARRAY_SUPPORT","createBuffer","that","RangeError","Uint8Array","__proto__","encodingOrOffset","Error","allocUnsafe","from","ArrayBuffer","byteOffset","byteLength","fromArrayLike","fromArrayBuffer","encoding","isEncoding","actual","write","slice","fromString","obj","isBuffer","len","checked","copy","buffer","val","data","fromObject","assertSize","size","toString","isView","loweredCase","utf8ToBytes","base64ToBytes","toLowerCase","slowToString","start","end","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","b","n","m","bidirectionalIndexOf","dir","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","String","read","buf","readUInt16BE","foundIndex","found","j","hexWrite","Number","remaining","strLen","parsed","parseInt","substr","utf8Write","blitBuffer","asciiWrite","str","byteArray","push","charCodeAt","asciiToBytes","latin1Write","base64Write","ucs2Write","units","c","hi","lo","utf16leToBytes","fromByteArray","min","res","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","decodeCodePointsArray","SlowBuffer","alloc","INSPECT_MAX_BYTES","global","foo","subarray","e","typedArraySupport","poolSize","_augment","species","fill","allocUnsafeSlow","_isBuffer","compare","a","y","concat","list","pos","swap16","swap32","swap64","equals","inspect","max","match","join","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","toJSON","_arr","ret","out","toHex","bytes","checkOffset","ext","checkInt","objectWriteUInt16","littleEndian","objectWriteUInt32","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","sliceLen","readUIntLE","mul","readUIntBE","readUInt8","readUInt16LE","readUInt32LE","readUInt32BE","readIntLE","pow","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUIntLE","writeUIntBE","writeUInt8","floor","writeUInt16LE","writeUInt16BE","writeUInt32LE","writeUInt32BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","set","code","INVALID_BASE64_RE","Infinity","leadSurrogate","toByteArray","trim","replace","stringtrim","base64clean","src","dst","_defineProperty","ownKeys","object","enumerableOnly","symbols","filter","sym","getOwnPropertyDescriptor","_objectSpread2","forEach","getOwnPropertyDescriptors","defineProperties","toBuffer","equal","l","inherits_browserModule","ctor","superCtor","super_","TempCtor","require$$0","inherits","require$$1","isSurrogatePair","htonl","w","zero2","word","zero8","enc","p","endian","d","ah","al","bh","bl","ch","cl","dh","dl","carry","eh","el","num","utils","BlockHash","pending","pendingTotal","blockSize","outSize","hmacStrength","padLength","_delta8","_delta32","update","toArray","join32","_update","digest","_pad","_digest","rotr32","ch32","z","maj32","p32","common","shaCommon","require$$2","rotl32","sum32","sum32_5","ft_1","sha1_K","SHA1","h","W","toHex32","split32","require$$3","sum32_4","s0_256","s1_256","g0_256","g1_256","sha256_K","SHA256","g","T1","T2","SHA224","rotr64_hi","rotr64_lo","shr64_hi","shr64_lo","sum64","sum64_hi","sum64_lo","sum64_4_hi","sum64_4_lo","sum64_5_hi","sum64_5_lo","sha512_K","SHA512","ch64_hi","xh","xl","yh","yl","zh","ch64_lo","zl","maj64_hi","maj64_lo","s0_512_hi","s0_512_lo","s1_512_hi","s1_512_lo","g0_512_hi","g0_512_lo","g1_512_hi","g1_512_lo","_prepareBlock","c0_hi","c0_lo","c1_hi","c1_lo","c2_hi","c2_lo","c3_hi","c3_lo","fh","fl","gh","gl","hh","hl","c4_hi","c4_lo","T1_hi","T1_lo","T2_hi","T2_lo","SHA384","require$$4","sum32_3","RIPEMD160","K","Kh","A","B","C","D","E","Ah","Bh","Ch","Dh","Eh","T","rh","sh","Hmac","hash","Hash","inner","outer","_init","sha","ripemd","hmac","sha1","sha256","sha224","sha384","sha512","ripemd160","_permanentCensorErrors","_censorErrors","LogLevels","debug","warning","off","_logLevel","_globalLogger","LogLevel","ErrorCode","_normalizeError","missing","form","normalize","_checkNormalize","HEX","Logger","version","logLevel","level","throwArgumentError","console","log","_log","levels","DEBUG","INFO","WARNING","params","makeError","errors","UNKNOWN_ERROR","messageDetails","hex","stringify","reason","throwError","INVALID_ARGUMENT","argument","UNSUPPORTED_OPERATION","operation","NUMERIC_FAULT","fault","count","expectedCount","MISSING_ARGUMENT","UNEXPECTED_ARGUMENT","kind","MISSING_NEW","censorship","permanent","globalLogger","warn","logger","addSlice","isInteger","arrayify","checkSafeUint53","unshift","allowMissingPrefix","substring","toHexString","isHexable","isHexString","hexPad","isBytes","encode","serialize","SOLANA_SCHEMA","decode","deserialize","decodeUnchecked","deserializeUnchecked","enum","Map","MAX_SEED_LENGTH","_bn","isPublicKeyData","decoded","bs58","eq","publicKey","toBase58","toBytes","toArrayLike","zeroPad","createWithSeed","fromPublicKey","programId","PublicKey","createProgramAddress","seeds","seed","is_on_curve","publicKeyBytes","findProgramAddress","nonce","seedsWithNonce","address","isOnCurve","default","fields","naclLowLevel","nacl","chk","den","den2","den4","den6","neq25519","gf1","I","_keypair","secretKey","BPF_LOADER_DEPRECATED_PROGRAM_ID","property","BufferLayout","rustString","rsl","_decode","_encode","chars","decodeLength","elem","encodeLength","rem_len","header","accountKeys","recentBlockhash","instructions","indexToProgramIds","account","ix","isAccountSigner","index","isAccountWritable","numRequiredSignatures","isProgramId","has","programIds","nonProgramIds","numKeys","keyCount","shortvec","map","instruction","programIdIndex","keyIndicesCount","accounts","dataCount","keyIndices","dataLength","instructionCount","instructionBuffer","instructionBufferLength","instructionLayout","signDataLayout","transaction","numReadonlySignedAccounts","numReadonlyUnsignedAccounts","signData","accountCount","dataSlice","Message","DEFAULT_SIGNATURE","PACKET_DATA_SIZE","opts","signatures","feePayer","nonceInfo","signature","add","items","item","TransactionInstruction","compileMessage","accountMetas","accountMeta","pubkey","isSigner","isWritable","pubkeySorting","checkSigner","checkWritable","uniqueMetas","pubkeyString","uniqueIndex","feePayerIndex","payerMeta","signedKeys","unsignedKeys","meta","invariant","keyIndex","_compile","every","pair","serializeMessage","setSigners","signers","seen","sign","uniqueSigners","signer","partialSign","_partialSign","addSignature","_addSignature","findIndex","sigpair","verifySignatures","_verifySignatures","requireAllSignatures","_serialize","signatureCount","transactionLength","wireTransaction","keyObj","Transaction","populate","sigPubkeyPair","SYSVAR_CLOCK_PUBKEY","SYSVAR_EPOCH_SCHEDULE_PUBKEY","SYSVAR_INSTRUCTIONS_PUBKEY","SYSVAR_RECENT_BLOCKHASHES_PUBKEY","SYSVAR_RENT_PUBKEY","SYSVAR_REWARDS_PUBKEY","SYSVAR_SLOT_HASHES_PUBKEY","SYSVAR_SLOT_HISTORY_PUBKEY","SYSVAR_STAKE_HISTORY_PUBKEY","sendOptions","skipPreflight","preflightCommitment","commitment","connection","status","sleep","ms","setTimeout","encodeData","allocLength","layoutFields","decodeData","FeeCalculatorLayout","NonceAccountLayout","NONCE_ACCOUNT_LENGTH","span","authorizedPubkey","feeCalculator","fromAccountData","nonceAccount","NonceAccount","decodeInstructionType","typeIndex","instructionTypeLayout","decodeCreateAccount","SYSTEM_INSTRUCTION_LAYOUTS","fromPubkey","newAccountPubkey","lamports","space","decodeTransfer","toPubkey","decodeTransferWithSeed","basePubkey","decodeAllocate","accountPubkey","decodeAllocateWithSeed","decodeAssign","decodeAssignWithSeed","decodeCreateWithSeed","decodeNonceInitialize","authorized","noncePubkey","decodeNonceAdvance","decodeNonceWithdraw","decodeNonceAuthorize","newAuthorizedPubkey","checkProgramId","SystemProgram","checkKeyLength","Create","Assign","Transfer","CreateWithSeed","AdvanceNonceAccount","WithdrawNonceAccount","InitializeNonceAccount","AuthorizeNonceAccount","Allocate","AllocateWithSeed","AssignWithSeed","TransferWithSeed","createAccount","transfer","assign","base","createAccountWithSeed","createNonceAccount","initParams","nonceInitialize","instructionData","nonceAdvance","nonceWithdraw","nonceAuthorize","allocate","CHUNK_SIZE","getMinNumSignatures","Loader","load","balanceNeeded","program","programInfo","payer","sendAndConfirmTransaction","dataLayout","chunkSize","transactions","BPF_LOADER_PROGRAM_ID","__self__","F","fetch","DOMException","support","Blob","viewClasses","isArrayBufferView","normalizeName","test","normalizeValue","iteratorFor","iterator","next","shift","Headers","headers","append","getOwnPropertyNames","consumed","body","bodyUsed","fileReaderReady","reader","onload","onerror","readBlobAsArrayBuffer","blob","FileReader","promise","readAsArrayBuffer","bufferClone","view","Body","_initBody","_bodyInit","_bodyText","isPrototypeOf","_bodyBlob","FormData","_bodyFormData","URLSearchParams","DataView","_bodyArrayBuffer","get","rejected","arrayBuffer","text","readAsText","readBlobAsText","readArrayBufferAsText","formData","json","parse","oldValue","hasOwnProperty","callback","thisArg","values","methods","Request","url","credentials","method","mode","signal","upcased","toUpperCase","normalizeMethod","referrer","split","decodeURIComponent","parseHeaders","rawHeaders","line","parts","Response","bodyInit","ok","statusText","clone","response","redirectStatuses","redirect","location","stack","init","request","aborted","xhr","XMLHttpRequest","abortXhr","abort","getAllResponseHeaders","responseURL","responseText","ontimeout","onabort","open","withCredentials","responseType","setRequestHeader","addEventListener","onreadystatechange","readyState","removeEventListener","send","polyfill","ponyfill","trailingZeros","slotsPerEpoch","leaderScheduleSlotOffset","warmup","firstNormalEpoch","firstNormalSlot","getEpoch","getEpochAndSlotIndex","slot","epoch","getSlotsInEpoch","normalSlotIndex","normalEpochIndex","getFirstSlotInEpoch","getLastSlotInEpoch","logs","promiseTimeout","timeoutPromise","timeoutId","clearTimeout","PublicKeyFromString","RawAccountDataResult","BufferFromRawAccountData","BLOCKHASH_CACHE_TIMEOUT_MS","createRpcResult","pick","jsonrpc","id","UnknownRpcResult","jsonRpcResult","jsonRpcResultAndContext","notificationResultAndContext","GetInflationGovernorResult","foundation","foundationTerm","initial","taper","terminal","GetInflationRewardResult","effectiveSlot","amount","postBalance","GetEpochInfoResult","slotIndex","slotsInEpoch","absoluteSlot","blockHeight","transactionCount","GetEpochScheduleResult","GetLeaderScheduleResult","TransactionErrorResult","SignatureStatusResult","SignatureReceivedResult","VersionResult","SimulatedTransactionResponseStruct","executable","owner","rentEpoch","unitsConsumed","GetInflationGovernorRpcResult","GetEpochInfoRpcResult","GetEpochScheduleRpcResult","GetLeaderScheduleRpcResult","SlotRpcResult","GetSupplyRpcResult","total","circulating","nonCirculating","nonCirculatingAccounts","TokenAmountResult","uiAmount","decimals","uiAmountString","GetTokenLargestAccountsResult","GetTokenAccountsByOwner","ParsedAccountDataResult","GetParsedTokenAccountsByOwner","GetLargestAccountsRpcResult","AccountInfoResult","KeyedAccountInfoResult","ParsedOrRawAccountData","ParsedAccountInfoResult","KeyedParsedAccountInfoResult","StakeActivationResult","state","active","inactive","GetConfirmedSignaturesForAddress2RpcResult","memo","blockTime","GetSignaturesForAddressRpcResult","AccountNotificationResult","subscription","ProgramAccountInfoResult","ProgramAccountNotificationResult","SlotInfoResult","parent","root","SlotNotificationResult","SlotUpdateResult","timestamp","stats","numTransactionEntries","numSuccessfulTransactions","numFailedTransactions","maxTransactionsPerEntry","SlotUpdateNotificationResult","SignatureNotificationResult","RootNotificationResult","ContactInfoResult","gossip","tpu","rpc","VoteAccountInfoResult","votePubkey","nodePubkey","activatedStake","epochVoteAccount","epochCredits","commission","lastVote","rootSlot","GetVoteAccounts","current","delinquent","ConfirmationStatus","SignatureStatusResponse","confirmations","confirmationStatus","GetSignatureStatusesRpcResult","GetMinimumBalanceForRentExemptionRpcResult","ConfirmedTransactionResult","ParsedInstructionResult","RawInstructionResult","InstructionResult","UnknownInstructionResult","ParsedOrRawInstruction","ParsedConfirmedTransactionResult","TokenBalanceResult","accountIndex","mint","uiTokenAmount","ConfirmedTransactionMetaResult","fee","innerInstructions","preBalances","postBalances","logMessages","preTokenBalances","postTokenBalances","ParsedConfirmedTransactionMetaResult","GetConfirmedBlockRpcResult","blockhash","previousBlockhash","parentSlot","rewards","rewardType","GetConfirmedBlockSignaturesRpcResult","GetConfirmedTransactionRpcResult","GetParsedConfirmedTransactionRpcResult","GetRecentBlockhashAndContextRpcResult","lamportsPerSignature","PerfSampleResult","numTransactions","numSlots","samplePeriodSecs","GetRecentPerformanceSamplesRpcResult","GetFeeCalculatorRpcResult","RequestAirdropRpcResult","SendTransactionRpcResult","LogsResult","LogsNotificationResult","_commitment","_confirmTransactionInitialTimeout","_rpcEndpoint","_rpcWsEndpoint","_rpcClient","_rpcRequest","_rpcBatchRequest","_rpcWebSocket","_rpcWebSocketConnected","_rpcWebSocketHeartbeat","_rpcWebSocketIdleTimeout","_disableBlockhashCaching","_pollingBlockhash","_blockhashInfo","lastFetch","transactionSignatures","simulatedSignatures","_accountChangeSubscriptionCounter","_accountChangeSubscriptions","_programAccountChangeSubscriptionCounter","_programAccountChangeSubscriptions","_rootSubscriptionCounter","_rootSubscriptions","_signatureSubscriptionCounter","_signatureSubscriptions","_slotSubscriptionCounter","_slotSubscriptions","_logsSubscriptionCounter","_logsSubscriptions","_slotUpdateSubscriptionCounter","_slotUpdateSubscriptions","client","URL","commitmentOrConfig","wsEndpoint","httpHeaders","fetchMiddleware","disableRetryOnRateLimit","endpoint","useHttps","makeWebsocketUrl","fetchWithMiddleware","modifiedUrl","modifiedFetchArgs","clientBrowser","agent","too_many_requests_retries","waitTime","createRpcClient","requests","batch","createRpcBatchRequest","autoconnect","max_reconnects","_wsOnOpen","bind","_wsOnError","_wsOnClose","_wsOnAccountNotification","_wsOnProgramAccountNotification","_wsOnSlotNotification","_wsOnSlotUpdatesNotification","_wsOnSignatureNotification","_wsOnRootNotification","_wsOnLogsNotification","getBalanceAndContext","_buildArgs","unsafeRes","getBalance","getBlockTime","getMinimumLedgerSlot","getFirstAvailableBlock","getSupply","configArg","config","getTokenSupply","tokenMintAddress","getTokenAccountBalance","tokenAddress","getTokenAccountsByOwner","_args","ownerAddress","getParsedTokenAccountsByOwner","getLargestAccounts","getTokenLargestAccounts","mintAddress","getAccountInfoAndContext","getParsedAccountInfo","getAccountInfo","getMultipleAccountsInfo","publicKeys","configOrCommitment","getStakeActivation","getProgramAccounts","extra","getParsedProgramAccounts","confirmTransaction","decodedSignature","Date","subscriptionCommitment","confirmPromise","subscriptionId","timeoutMs","duration","getClusterNodes","getVoteAccounts","getSlot","getSlotLeader","getSlotLeaders","startSlot","getSignatureStatus","getSignatureStatuses","getTransactionCount","getTotalSupply","excludeNonCirculatingAccountsList","getInflationGovernor","getInflationReward","addresses","getEpochInfo","getEpochSchedule","epochSchedule","EpochSchedule","getLeaderSchedule","getMinimumBalanceForRentExemption","getRecentBlockhashAndContext","getRecentPerformanceSamples","getFeeCalculatorForBlockhash","getFeeForMessage","wireMessage","getRecentBlockhash","getVersion","getGenesisHash","getBlock","_buildArgsAtLeastConfirmed","getTransaction","getConfirmedBlock","getBlocks","endSlot","getConfirmedBlockSignatures","transactionDetails","getConfirmedTransaction","getParsedConfirmedTransaction","getParsedConfirmedTransactions","methodName","getConfirmedSignaturesForAddress","firstAvailableBlock","block","highestConfirmedRoot","getConfirmedSignaturesForAddress2","confirmedSignatureInfo","getSignaturesForAddress","getNonceAndContext","accountInfo","getNonce","requestAirdrop","to","_recentBlockhash","timeSinceFetch","expired","_pollNewBlockhash","startTime","MS_PER_SLOT","simulateTransaction","transactionOrMessage","disableCache","encodedTransaction","logTrace","traceIndent","SendTransactionError","sendTransaction","sendRawTransaction","sendEncodedTransaction","setInterval","clearInterval","_subscribe","rpcMethod","_unsubscribe","unsubscribeId","_resetSubscriptions","_updateSubscriptions","programKeys","slotKeys","slotUpdateKeys","signatureKeys","rootKeys","logsKeys","filters","mentions","notification","onAccountChange","removeAccountChangeListener","subInfo","accountId","onProgramAccountChange","removeProgramAccountChangeListener","onLogs","removeOnLogsListener","onSlotChange","removeSlotChangeListener","onSlotUpdate","removeSlotUpdateListener","override","onSignature","onSignatureWithOptions","removeSignatureListener","onRootChange","removeRootChangeListener","generate","Keypair","fromSecretKey","keypair","encoder","fromSeed","ED25519_INSTRUCTION_LAYOUT","createInstructionWithPublicKey","instructionIndex","publicKeyOffset","signatureOffset","messageDataOffset","numSignatures","padding","signatureInstructionIndex","publicKeyInstructionIndex","messageDataSize","messageInstructionIndex","Ed25519Program","createInstructionWithPrivateKey","privateKey","STAKE_CONFIG_ID","staker","withdrawer","unixTimestamp","custodian","Lockup","decodeInitialize","STAKE_INSTRUCTION_LAYOUTS","lockup","stakePubkey","Authorized","decodeDelegate","decodeAuthorize","stakeAuthorizationType","o","decodeAuthorizeWithSeed","authorityOwner","authorityBase","authoritySeed","decodeSplit","splitStakePubkey","decodeMerge","sourceStakePubKey","decodeWithdraw","decodeDeactivate","StakeProgram","Initialize","Authorize","Delegate","Split","Withdraw","Deactivate","Merge","AuthorizeWithSeed","StakeAuthorizationLayout","Staker","Withdrawer","initialize","delegate","authorize","custodianPubkey","newAuthorized","authorizeWithSeed","merge","withdraw","deactivate","ecdsaSign","SECP256K1_INSTRUCTION_LAYOUT","publicKeyToEthAddress","sha3","Secp256k1Program","ethAddress","recoveryId","createInstructionWithEthAddress","rawAddress","ethAddressOffset","ethAddressInstructionIndex","pkey","publicKeyCreate","messageHash","recid","VALIDATOR_INFO_KEY","InfoString","website","details","keybaseUsername","fromConfigData","configKeys","rawInfo","assertType","ValidatorInfo","VOTE_PROGRAM_ID","VoteAccountLayout","authorizedWithdrawer","votes","authorizedVoters","priorVoters","lastTimestamp","va","VoteAccount","getPriorVoters","parseAuthorizedVoter","authorizedVoter","parsePriorVoters","targetEpoch","epochOfLastAuthorizedSwitch","isEmpty","idx","http","devnet","testnet","https","clusterApiUrl","cluster","tls","LAMPORTS_PER_SOL","_slicedToArray","_i","_s","_e","_n","_d","_createForOfIteratorHelper","allowArrayLike","it","normalCompletion","didErr","step","_e2","_toConsumableArray","arrayLikeToArray","basex","camelCase","pascalCase","isLastCharLower","isLastCharUpper","isLastLastCharUpper","character","preserveCamelCase","_","p1","charAt","IdlError","errorMsg","ERROR","WINDOW","window","JS_SHA256_NO_WINDOW","WEB_WORKER","NODE_JS","JS_SHA256_NO_NODE_JS","process","versions","node","COMMON_JS","JS_SHA256_NO_COMMON_JS","AMD","ARRAY_BUFFER","JS_SHA256_NO_ARRAY_BUFFER","HEX_CHARS","EXTRA","SHIFT","OUTPUT_TYPES","blocks","JS_SHA256_NO_ARRAY_BUFFER_IS_VIEW","createOutputMethod","outputType","is224","Sha256","createMethod","nodeWrap","crypto","eval","algorithm","nodeMethod","createHash","createHmacOutputMethod","HmacSha256","createHmacMethod","sharedMemory","h0","h1","h2","h3","h4","h5","h6","h7","hBytes","finalized","hashed","first","oKeyPad","iKeyPad","notString","lastByteIndex","finalize","s0","s1","maj","t1","ab","da","cd","bc","dataView","setUint32","innerHash","gf","Float64Array","randombytes","_0","_9","gf0","_121665","D2","X","Y","ts64","vn","xi","yi","crypto_verify_16","crypto_verify_32","crypto_core_salsa20","inp","u","j0","j1","j2","j3","j4","j5","j6","j7","j8","j9","j10","j11","j12","j13","j14","j15","x0","x1","x2","x3","x4","x5","x6","x7","x8","x9","x10","x11","x12","x13","x14","x15","core_salsa20","crypto_core_hsalsa20","core_hsalsa20","sigma","crypto_stream_salsa20_xor","cpos","mpos","crypto_stream_salsa20","crypto_stream","sn","crypto_stream_xor","poly1305","t0","t2","t3","t4","t5","t6","t7","Uint16Array","pad","leftover","fin","crypto_onetimeauth","outpos","finish","crypto_onetimeauth_verify","hpos","crypto_secretbox","crypto_secretbox_open","set25519","car25519","sel25519","q","pack25519","par25519","unpack25519","Z","M","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","t30","b0","b1","b2","b3","b4","b5","b6","b7","b8","b9","b10","b11","b12","b13","b14","b15","S","inv25519","pow2523","crypto_scalarmult","x32","x16","crypto_scalarmult_base","crypto_box_keypair","crypto_box_beforenm","d0","d1","d2","d3","d4","d5","d6","d7","d8","d9","hibit","h8","h9","r0","r1","r2","r3","r4","r5","r6","r7","r8","r9","mac","macpos","want","crypto_box_afternm","crypto_box_open_afternm","crypto_hashblocks_hl","bh0","bh1","bh2","bh3","bh4","bh5","bh6","bh7","bl0","bl1","bl2","bl3","bl4","bl5","bl6","bl7","th","tl","wh","Int32Array","wl","ah0","ah1","ah2","ah3","ah4","ah5","ah6","ah7","al0","al1","al2","al3","al4","al5","al6","al7","crypto_hash","cswap","pack","tx","ty","zi","scalarmult","scalarbase","crypto_sign_keypair","pk","sk","seeded","L","modL","reduce","crypto_sign","sm","smlen","crypto_sign_open","unpackneg","crypto_secretbox_BOXZEROBYTES","crypto_sign_BYTES","crypto_sign_PUBLICKEYBYTES","crypto_sign_SECRETKEYBYTES","checkLengths","checkArrayTypes","cleanup","lowlevel","crypto_box","crypto_box_open","crypto_secretbox_KEYBYTES","crypto_secretbox_NONCEBYTES","crypto_secretbox_ZEROBYTES","crypto_scalarmult_BYTES","crypto_scalarmult_SCALARBYTES","crypto_box_PUBLICKEYBYTES","crypto_box_SECRETKEYBYTES","crypto_box_BEFORENMBYTES","crypto_box_NONCEBYTES","crypto_box_ZEROBYTES","crypto_box_BOXZEROBYTES","crypto_sign_SEEDBYTES","crypto_hash_BYTES","randomBytes","secretbox","box","keyLength","nonceLength","overheadLength","scalarMult","scalarLength","groupElementLength","before","checkBoxLengths","after","keyPair","publicKeyLength","secretKeyLength","sharedKeyLength","signedMsg","tmp","mlen","detached","sig","verify","seedLength","signatureLength","hashLength","setPRNG","msCrypto","getRandomValues","BN","minAssert","minUtils","getNAF","bits","naf","bitLength","ws","mod","andln","isOdd","isubn","iushrn","getJSF","k1","k2","jsf","m8","cmpn","u1","u2","m14","m24","cachedProperty","computer","parseBytes","intFromLE","isBN","negative","words","red","wordSize","parseHex4Bits","parseHexByte","lowerBound","parseBase","move","dest","left","right","cmp","_initNumber","_initArray","_parseHex","_parseBase","ceil","_strip","limbLen","limbPow","imuln","_iaddn","_move","_expand","_normSign","for","zeros","groupSizes","groupBases","groupSize","groupBase","isZero","modrn","idivn","toNumber","smallMulTo","ncarry","rword","maxJ","ArrayType","reqLength","_toArrayLikeLE","position","_toArrayLikeBE","clz32","_countBits","_zeroBits","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","bit","wbit","iadd","isub","comb10MulTo","mid","a0","a1","a2","a3","a4","a5","a6","a7","a8","al8","ah8","a9","al9","ah9","bl8","bh8","bl9","bh9","w0","imul","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","FFTM","mulTo","makeRBT","N","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","rtwdf","cos","PI","itwdf","sin","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","odd","conjugate","normalize13b","round","convert13b","stub","ph","mulp","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","isNegNum","muln","sqr","isqr","toBitArray","iushln","carryMask","newCarry","ishln","hint","extended","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","addn","subn","iabs","_ishlnsubmul","_wordDiv","bhi","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","acc","modn","egcd","isEven","yp","xp","im","jm","gcd","_invmp","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","Red","toRed","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","_tmp","K256","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","imulK","strip","output","outLen","prev","mod3","one","nOne","lpow","inv","wnd","currentLen","mont","zero$1","LITERALS$1","L_CODES$1","D_CODES$1","MAX_BITS$1","extra_lbits","extra_dbits","extra_blbits","bl_order","static_ltree","static_dtree","_dist_code","_length_code","MAX_MATCH$1","base_length","static_l_desc","static_d_desc","static_bl_desc","base_dist","StaticTreeDesc","static_tree","extra_bits","extra_base","elems","max_length","has_stree","TreeDesc","dyn_tree","stat_desc","max_code","d_code","dist","put_short","pending_buf","send_bits","bi_valid","bi_buf","send_code","tree","bi_reverse","gen_codes","bl_count","next_code","init_block","dyn_ltree","dyn_dtree","bl_tree","END_BLOCK","opt_len","static_len","last_lit","matches","bi_windup","smaller","depth","_n2","_m2","pqdownheap","heap","heap_len","compress_block","ltree","dtree","lc","lx","d_buf","l_buf","build_tree","desc","stree","heap_max","xbits","overflow","gen_bitlen","scan_tree","curlen","prevlen","nextlen","max_count","min_count","REP_3_6","REPZ_3_10","REPZ_11_138","send_tree","static_init_done","_tr_stored_block$1","stored_len","last","copy_block","_tr_flush_block_1","opt_lenb","static_lenb","max_blindex","strm","data_type","black_mask","detect_data_type","l_desc","d_desc","bl_desc","BL_CODES$1","build_bl_tree","strategy","lcodes","dcodes","blcodes","rank","send_all_trees","trees","_tr_init","LENGTH_CODES$1","tr_static_init","_tr_stored_block","_tr_flush_block","_tr_tally","lit_bufsize","_tr_align","STATIC_TREES","bi_flush","adler32_1","adler","s2","crcTable","Uint32Array","table","makeTable","crc32_1","crc","messages","constants$2","Z_NO_FLUSH","Z_PARTIAL_FLUSH","Z_SYNC_FLUSH","Z_FULL_FLUSH","Z_FINISH","Z_BLOCK","Z_TREES","Z_OK","Z_STREAM_END","Z_NEED_DICT","Z_ERRNO","Z_STREAM_ERROR","Z_DATA_ERROR","Z_MEM_ERROR","Z_BUF_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","Z_DEFLATED","Z_NO_FLUSH$2","Z_FULL_FLUSH$1","Z_FINISH$3","Z_BLOCK$1","Z_OK$3","Z_STREAM_END$3","Z_STREAM_ERROR$2","Z_DATA_ERROR$2","Z_BUF_ERROR$1","Z_DEFAULT_COMPRESSION$1","Z_DEFAULT_STRATEGY$1","Z_DEFLATED$2","MAX_MATCH","MIN_LOOKAHEAD","HCRC_STATE","BUSY_STATE","FINISH_STATE","errorCode","zero","HASH","hash_shift","hash_mask","flush_pending","avail_out","pending_out","next_out","total_out","flush_block_only","block_start","strstart","put_byte","putShortMSB","read_buf","avail_in","next_in","wrap","total_in","longest_match","cur_match","chain_length","max_chain_length","scan","best_len","prev_length","nice_match","w_size","_win","wmask","w_mask","strend","scan_end1","scan_end","good_match","lookahead","match_start","fill_window","more","_w_size","window_size","hash_size","head","insert","ins_h","deflate_fast","flush","hash_head","bflush","match_length","max_lazy_match","MIN_MATCH","deflate_slow","max_insert","prev_match","match_available","Config","good_length","max_lazy","nice_length","max_chain","func","configuration_table","max_block_size","pending_buf_size","max_start","DeflateState","gzhead","gzindex","last_flush","w_bits","hash_bits","HEAP_SIZE","MAX_BITS","deflateResetKeep","deflateReset","deflateInit2","windowBits","memLevel","deflate_1$2","deflateInit","deflateSetHeader","deflate","beg","old_flush","hcrc","comment","time","os","bstate","deflate_huff","deflate_rle","deflateEnd","deflateSetDictionary","dictionary","dictLength","tmpDict","avail","deflateInfo","_has","sources","chunks","chunk","STR_APPLY_UIA_OK","__","_utf8len","strings","TextEncoder","c2","m_pos","str_len","buf_len","TextDecoder","utf16buf","c_len","buf2binstring","zstream","toString$1","Z_NO_FLUSH$1","Z_FINISH$2","Z_OK$2","Z_STREAM_END$2","Z_DEFLATED$1","Deflate$1","opt","raw","gzip","ended","dict","_dict_set","flush_mode","_flush_mode","onData","onEnd","inffast","_in","_out","dmax","wsize","whave","wnext","s_window","hold","lcode","dcode","lmask","dmask","here","op","from_source","lencode","distcode","lenbits","distbits","top","dolen","dodist","sane","MAXBITS","lbase","lext","dbase","dext","inftrees","lens","lens_index","codes","table_index","work","incr","low","here_bits","here_op","here_val","curr","drop","used","huff","base_index","offs","extra_index","Z_FINISH$1","Z_OK$1","Z_STREAM_END$1","Z_NEED_DICT$1","Z_STREAM_ERROR$1","Z_DATA_ERROR$1","Z_MEM_ERROR$1","TYPE","BAD","zswap32","InflateState","havedict","flags","check","wbits","ncode","nlen","ndist","have","lendyn","distdyn","back","was","lenfix","distfix","inflateResetKeep","inflateReset","inflateReset2","inflateInit2","virgin","fixedtables","updatewindow","inflate_1$2","inflateInit","inflate","put","last_bits","last_op","last_val","hbuf","order","inf_leave","xflags","extra_len","inflateEnd","inflateGetHeader","inflateSetDictionary","inflateInfo","gzheader","Inflate$1","inflate$1","inflator","last_avail_out","next_out_utf8","tail","utf8str","inflate_1$1","Inflate","inflateRaw","ungzip","constants","inflate_1","_inherits","subClass","superClass","_typeof","_possibleConstructorReturn","assertThisInitialized","_createSuper","Derived","hasNativeReflectConstruct","isNativeReflectConstruct","Super","getPrototypeOf","NewTarget","Reflect","construct","_unsupportedIterableToArray","minLen","b64","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","maxChunkLength","len2","encodeChunk","lookup","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","marker","runClearTimeout","Item","noop","nextTick","title","browser","env","argv","on","addListener","once","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","umask","Parent","Function","setPrototypeOf","_cache","Wrapper","objectAssign","util","hasOwn","pSlice","functionsHaveNames","pToString","arrbuf","regex","getName","isFunction","truncate","something","rawname","fail","expected","operator","stackStartFunction","AssertionError","_deepEqual","strict","memos","isDate","getTime","isRegExp","multiline","lastIndex","ignoreCase","Float32Array","actualIndex","actualVisitedObjects","isPrimitive","aIsArgs","isArguments","bIsArgs","ka","objectKeys","kb","sort","objEquiv","expectedException","_throws","shouldThrow","_tryBlock","userProvidedMessage","isUnexpectedException","isError","generatedMessage","getMessage","captureStackTrace","fn_name","next_line","notEqual","deepEqual","deepStrictEqual","notDeepEqual","notDeepStrictEqual","strictEqual","notStrictEqual","throws","doesNotThrow","ifError","__esModule","prefix","Events","EE","emitter","event","listener","evt","_events","_eventsCount","clearEvent","EventEmitter","eventNames","events","names","handlers","ee","listenerCount","prefixed","_setPrototypeOf","_getPrototypeOf","_arrayLikeToArray","arr2","propIsEnumerable","toObject","test1","test2","test3","letter","shouldUseNative","BaseCurve","conf","two","pointFromJSON","gRed","_wnafT1","_wnafT2","_wnafT3","_wnafT4","_bitLength","adjustCount","redN","_maxwellTrick","BasePoint","curve","precomputed","point","_fixedNafMul","doubles","_getDoubles","nafW","repr","jpoint","mixedAdd","points","toP","_wnafMul","nafPoints","_getNAFPoints","dblp","_wnafMulAdd","defW","coeffs","jacobianResult","wndWidth","comb","toJ","ja","jb","decodePoint","pointFromX","encodeCompressed","compact","getX","getY","precompute","power","beta","_getBeta","_hasDoubles","dbl","Set","_arrayWithHoles","_nonIterableRest","_isNativeReflectConstruct","sham","Proxy","Boolean","valueOf","_iterableToArray","iter","_assertThisInitialized","ReferenceError","__createBinding","__setModuleDefault","__decorate","decorators","decorate","__importStar","__importDefault","BinaryReader","BinaryWriter","BorshError","baseDecode","baseEncode","bn_js_1","bs58_1","textDecoder","fatal","INITIAL_LENGTH","fieldPath","originalMessage","fieldName","splice","maybeResize","writeBuffer","writeU32","handlingRangeError","propertyKey","propertyDescriptor","originalMethod","readBuffer","readU32","capitalizeFirstLetter","serializeField","fieldType","writer","writeFixedArray","writeArray","writeU8","serializeStruct","addToFieldPath","structSchema","field","deserializeField","readFixedArray","readArray","readU8","deserializeStruct","classType","fieldValue","possibleConstructorReturn","pre","curves","PresetCurve","short","edwards","isInfinity","defineCurve","lambda","basis","descriptors","formatRegExp","format","isString","objects","isNull","deprecate","noDeprecation","warned","throwDeprecation","traceDeprecation","trace","debugEnviron","debugs","stylize","stylizeNoColor","colors","isBoolean","showHidden","_extend","isUndefined","customInspect","stylizeWithColor","formatValue","styleType","style","styles","recurseTimes","primitive","simple","isNumber","formatPrimitive","visibleKeys","arrayToHash","formatError","RegExp","braces","toUTCString","formatProperty","formatArray","pop","cur","numLinesEst","reduceToSingleString","ar","objectToString","debuglog","NODE_DEBUG","pid","isNullOrUndefined","isSymbol","months","getHours","getMinutes","getSeconds","getDate","getMonth","prop","origin","kCustomPromisifiedSymbol","callbackifyOnRejected","cb","newReason","promisify","original","promiseResolve","promiseReject","custom","callbackify","callbackified","maybeCb","rej","INPUT_ERROR","JS_SHA3_NO_WINDOW","JS_SHA3_NO_NODE_JS","JS_SHA3_NO_COMMON_JS","JS_SHA3_NO_ARRAY_BUFFER","CSHAKE_PADDING","RC","BITS","SHAKE_BITS","CSHAKE_BYTEPAD","JS_SHA3_NO_ARRAY_BUFFER_IS_VIEW","Keccak","createShakeOutputMethod","outputBits","createCshakeOutputMethod","createKmacOutputMethod","createOutputMethods","algorithms","bytepad","Kmac","methodNames","newMethodName","reset","blockCount","byteCount","outputBlocks","encodeString","strs","paddingBytes","c0","c1","c3","c4","c5","c6","c7","c8","c9","b16","b17","b18","b19","b20","b21","b22","b23","b24","b25","b26","b27","b28","b29","b30","b31","b32","b33","b34","b35","b36","b37","b38","b39","b40","b41","b42","b43","b44","b45","b46","b47","b48","b49","webpackPolyfill","paths","children","Rand","rand","_rand","getBytes","getByte","__webpack_amd_options__","rv","nameWithProperty","bindConstructorLayout","layout_","boundConstructor_","elementSpan","rem","OffsetLayout","UInt","UIntBE","Int","V2E32","divmodInt64","hi32","lo32","roundedInt64","NearUInt64","NearUInt64BE","NearInt64","NearInt64BE","Float","FloatBE","Double","DoubleBE","Sequence","elementLayout","getSpan","elo","Structure","decodePrefixes","fd","fsp","firstOffset","lastOffset","lastWrote","fv","UnionDiscriminator","UnionLayoutDiscriminator","Union","discr","defaultLayout","upv","replicate","discriminator","usesPrefixDiscriminator","registry","boundGetSourceVariant","defaultGetSourceVariant","getSourceVariant","configGetSourceVariant","gsv","vlo","getVariant","tag","dlo","clo","contentOffset","variant","VariantLayout","vb","fromArray","fixBitwiseResult","BitStructure","msb","_packedSetValue","_packedGetValue","bf","BitField","container","totalBits","usedBits","sum","valueMask","wordMask","wordValue","CString","srcb","UTF8","maxSpan","Constant","greedy","u8","u16","u24","u32","u40","u48","nu64","u16be","u24be","u32be","u40be","u48be","nu64be","s8","s16","s24","s32","s40","s48","ns64","s16be","s24be","s32be","s40be","s48be","ns64be","f32","f32be","f64","f64be","seq","unionLayoutDiscriminator","cstr","utf8","const","rnds8","rng","uuid","REGEX","byteToHex","_nodeId","_clockseq","_lastMSecs","_lastNSecs","v1","clockseq","seedBytes","random","msecs","now","nsecs","dt","tmh","hashfunc","generateUUID","namespace","unescape","encodeURIComponent","stringToBytes","DNS","getOutputLength","inputLength8","safeAdd","lsw","md5cmn","cnt","md5ff","md5gg","md5hh","md5ii","md5","v3","v35","length32","hexTab","md5ToHexEncodedArray","olda","oldb","oldc","oldd","wordsToMd5","length8","bytesToWords","v4","rnds","ROTL","v5","H","_i2","_t","_t2","checkDCE","__REACT_DEVTOOLS_GLOBAL_HOOK__","_interopRequireDefault","Client","_classCallCheck2","_inherits2","_possibleConstructorReturn2","_getPrototypeOf2","_websocket","_CommonClient","_super","_ref","_ref$autoconnect","_ref$reconnect","reconnect","_ref$reconnect_interv","reconnect_interval","_ref$max_reconnects","generate_request_id","generateRequest","ClientBrowser","callServer","reviver","replacer","generator","notificationIdNull","isBatch","hasCallback","_parseResponse","parser","compiler","nodes","compile","__assign","delimiter","snakeCase","dotCase","Fragment","StrictMode","Profiler","Suspense","isMounted","enqueueForceUpdate","enqueueReplaceState","enqueueSetState","refs","updater","isReactComponent","setState","forceUpdate","isPureReactComponent","G","ref","__self","__source","J","defaultProps","$$typeof","_owner","escape","O","P","Q","_status","_result","R","ReactCurrentDispatcher","ReactCurrentBatchConfig","transition","ReactCurrentOwner","IsSomeRendererActing","Children","only","Component","PureComponent","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","cloneElement","createContext","_calculateChangedBits","_currentValue","_currentValue2","_threadCount","Provider","Consumer","_context","createElement","createFactory","createRef","forwardRef","render","isValidElement","lazy","_payload","useCallback","useContext","useDebugValue","useEffect","useImperativeHandle","useLayoutEffect","useMemo","useReducer","useRef","useState","aa","ba","ca","ea","fa","document","ha","ia","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","oa","pa","qa","ma","na","la","removeAttribute","setAttribute","setAttributeNS","xlinkHref","ra","sa","ta","ua","wa","xa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","Ma","Ka","La","Na","Oa","Pa","prepareStackTrace","displayName","Qa","_render","Ra","Sa","Ta","nodeName","Va","_valueTracker","getValue","setValue","stopTracking","Ua","Wa","Xa","activeElement","Ya","defaultChecked","defaultValue","_wrapperState","initialChecked","Za","initialValue","controlled","$a","bb","ownerDocument","eb","db","fb","selected","defaultSelected","disabled","gb","dangerouslySetInnerHTML","hb","ib","textContent","lb","mb","nb","ob","namespaceURI","innerHTML","firstChild","removeChild","appendChild","MSApp","execUnsafeLocalFunction","pb","lastChild","nodeType","nodeValue","qb","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","opacity","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","sb","tb","setProperty","ub","menuitem","area","br","col","embed","hr","img","keygen","link","param","track","wbr","wb","xb","srcElement","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","Ob","Pb","Qb","Rb","onError","Sb","Tb","Ub","Vb","Wb","Xb","Zb","alternate","return","$b","memoizedState","dehydrated","ac","cc","child","sibling","dc","ec","fc","gc","hc","ic","jc","kc","mc","nc","oc","pc","qc","rc","blockedOn","domEventName","eventSystemFlags","nativeEvent","targetContainers","sc","delete","pointerId","tc","vc","wc","lanePriority","unstable_runWithPriority","priority","hydrate","containerInfo","xc","yc","zc","Ac","Bc","unstable_scheduleCallback","unstable_NormalPriority","Cc","Dc","Ec","animationend","animationiteration","animationstart","transitionend","Fc","Gc","Hc","animation","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Pc","Qc","unstable_now","Rc","Uc","pendingLanes","expiredLanes","suspendedLanes","pingedLanes","Vc","entangledLanes","entanglements","Wc","Xc","Yc","Zc","$c","eventTimes","bd","LN2","dd","unstable_UserBlockingPriority","ed","gd","hd","uc","jd","kd","ld","md","nd","od","keyCode","charCode","pd","qd","rd","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","stopPropagation","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","isTrusted","td","ud","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","repeat","locale","which","Rd","Td","height","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","fe","ge","he","le","color","date","datetime","email","month","password","range","search","tel","week","me","ne","oe","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","Le","nextSibling","Me","contains","compareDocumentPosition","Ne","HTMLIFrameElement","contentWindow","href","Oe","contentEditable","Pe","Qe","Re","Se","Te","Ue","selectionStart","selectionEnd","anchorNode","defaultView","getSelection","anchorOffset","focusNode","focusOffset","Ve","We","Xe","Ye","Ze","Yb","$e","af","cf","df","capture","passive","Nb","ef","ff","parentWindow","hf","je","char","ke","jf","kf","lf","mf","autoFocus","nf","__html","of","pf","qf","rf","sf","previousSibling","tf","vf","wf","xf","yf","zf","Af","Bf","Cf","Df","Ef","contextTypes","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Ff","childContextTypes","Gf","Hf","If","getChildContext","Jf","__reactInternalMemoizedMergedChildContext","Kf","Lf","Mf","Nf","Of","Pf","unstable_cancelCallback","Qf","unstable_shouldYield","Rf","unstable_requestPaint","Sf","Tf","unstable_getCurrentPriorityLevel","Uf","unstable_ImmediatePriority","Vf","Wf","Xf","unstable_LowPriority","Yf","unstable_IdlePriority","Zf","$f","ag","bg","cg","dg","eg","fg","gg","hg","ig","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","childLanes","tg","dependencies","firstContext","lanes","ug","vg","observedBits","responders","wg","xg","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","effects","yg","zg","eventTime","lane","payload","Ag","Bg","Cg","Dg","Eg","Fg","Gg","Kg","_reactInternals","Hg","Ig","Jg","Lg","shouldComponentUpdate","Mg","contextType","Ng","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","Og","getDerivedStateFromProps","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","Pg","Qg","_stringRef","Rg","Sg","lastEffect","nextEffect","firstEffect","Tg","Ug","elementType","Vg","implementation","Wg","Xg","Yg","Zg","$g","documentElement","tagName","ih","memoizedProps","revealOrder","jh","kh","lh","mh","nh","oh","pendingProps","qh","uh","_workInProgressVersionPrimary","vh","Fh","Gh","Hh","baseQueue","Ih","Jh","lastRenderedReducer","action","eagerReducer","eagerState","lastRenderedState","dispatch","Lh","Mh","_getVersion","_source","mutableReadLanes","Nh","U","getSnapshot","subscribe","setSnapshot","Oh","Ph","Qh","Rh","destroy","deps","Sh","Th","Uh","Vh","Wh","Xh","Yh","Zh","$h","ai","bi","ci","di","readContext","useDeferredValue","useTransition","useMutableSource","useOpaqueIdentifier","unstable_isNewReconciler","uf","ei","fi","gi","ii","ji","ki","li","mi","baseLanes","ni","oi","pi","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","qi","getDerivedStateFromError","ri","pendingContext","Bi","Di","Ei","si","retryLane","ti","fallback","unstable_avoidThisFallback","ui","unstable_expectedLoadTime","vi","wi","isBackwards","rendering","renderingStartTime","tailMode","Ai","Fi","Gi","wasMultiple","multiple","onClick","onclick","createElementNS","createTextNode","V","Hi","Ii","Ji","Ki","Li","Mi","Ni","Oi","WeakMap","Pi","element","Qi","Ri","Si","componentDidCatch","Ti","componentStack","Ui","WeakSet","Vi","Wi","Xi","__reactInternalSnapshotBeforeUpdate","Yi","Zi","$i","focus","aj","display","bj","onCommitFiberUnmount","componentWillUnmount","cj","dj","ej","fj","gj","hj","insertBefore","_reactRootContainer","ij","jj","kj","lj","mj","nj","oj","pj","rj","sj","tj","uj","vj","wj","ck","xj","yj","zj","Aj","Bj","Cj","Dj","Ej","Fj","Gj","Hj","Ij","Jj","Sc","Kj","Lj","Mj","callbackNode","expirationTimes","callbackPriority","Tc","Nj","Oj","Pj","Qj","Rj","Sj","Tj","finishedWork","finishedLanes","Uj","timeoutHandle","Wj","Xj","pingCache","Yj","Zj","ak","bk","dk","rangeCount","focusedElem","selectionRange","ek","extend","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","onCommitFiberRoot","fk","gk","ik","pendingChildren","jk","mutableSourceEagerHydrationData","kk","lk","mk","nk","qk","hydrationOptions","mutableSources","_internalRoot","rk","tk","hasAttribute","uk","hk","unstable_observedBits","unmount","querySelectorAll","Vj","vk","wk","findFiberByHostInstance","bundleType","rendererPackageName","xk","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","yk","isDisabled","supportsFiber","inject","createPortal","findDOMNode","flushSync","unmountComponentAtNode","unstable_batchedUpdates","unstable_createPortal","unstable_renderSubtreeIntoContainer","performance","MessageChannel","unstable_forceFrameRate","cancelAnimationFrame","requestAnimationFrame","port2","port1","onmessage","postMessage","sortIndex","expirationTime","priorityLevel","unstable_Profiling","unstable_continueExecution","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","delay","unstable_wrapCallback","runtime","Op","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","innerFn","outerFn","tryLocsList","protoGenerator","Generator","Context","_invoke","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","doneResult","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","tryCatch","GenStateSuspendedYield","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","invoke","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","resultName","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iterable","iteratorMethod","isGeneratorFunction","genFun","mark","awrap","async","reverse","skipTempReset","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","globalThis","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","NaN","rt","_Buffer","ALPHABET","BASE_MAP","BASE","LEADER","FACTOR","iFACTOR","decodeUnsafe","psz","zeroes","b256","it3","it4","vch","pbegin","pend","b58","it1","it2","copyProps","SafeBuffer","iterableToArrayLimit","isNativeFunction","_wrapNativeSuper","_construct","inRange","ToDictionary","Stream","tokens","endOfStream","prepend","token","finished","decoderError","opt_code_point","DEFAULT_ENCODING","_streaming","_BOMseen","_decoder","_fatal","_ignoreBOM","_encoder","_options","UTF8Decoder","utf8_code_point","utf8_bytes_seen","utf8_bytes_needed","utf8_lower_boundary","utf8_upper_boundary","handler","stream","bite","code_point","UTF8Encoder","temp","input_stream","code_points","cp","codePointsToString","opt_string","stringToCodePoints","WebSocketBrowserImpl","_createClass2","_EventEmitter","protocols","socket","WebSocket","onopen","onclose","optionsOrCallback","close","_regenerator","_asyncToGenerator2","_typeof2","_eventemitter","_circularJson","__rest","CommonClient","webSocketFactory","_a","_a$autoconnect","_a$reconnect","_a$reconnect_interval","_a$max_reconnects","rest_options","rpc_id","ready","current_reconnects","_connect","ws_opts","_this2","_login","_callee","resp","_x","_listMethods","_callee2","_context2","_this3","_callee3","_context3","_x2","_callee4","_context4","_x3","_this4","_ref2","specialChar","safeSpecialChar","escapedSafeSpecialChar","specialCharRG","safeSpecialCharRG","safeStartWithSpecialCharRG","$String","regenerate","retrieve","regenerateArray","retrieveFromPath","regenerateObject","CircularJSON","doNotResolve","doNotIgnore","all","mapp","lvl","generateReplacer","generateReviver","cond","isUint8Array","numbers","isCompressed","toTypeString","getAssertedOutput","secp256k1","contextRandomize","privateKeyVerify","seckey","privateKeyNegate","privateKeyTweakAdd","tweak","privateKeyTweakMul","publicKeyVerify","compressed","publicKeyConvert","publicKeyNegate","publicKeyCombine","pubkeys","publicKeyTweakAdd","publicKeyTweakMul","signatureNormalize","signatureExport","outputlen","signatureImport","msg32","noncefn","ecdsaVerify","ecdsaRecover","ecdh","hashfn","xbuf","ybuf","EC","ecparams","loadPublicKey","pub","loadCompressedPublicKey","loadUncompressedPublicKey","savePublicKey","bn","negate","tweaked","keyFromPrivate","getPublic","pairs","sigR","sigS","lenR","posR","lenS","posS","_noncefn","counter","canonical","pers","recoveryParam","sigObj","sigr","sigs","recoverPubKey","scalar","elliptic","eddsa","Base","ShortCurve","tinv","zeroA","threeA","endo","_getEndomorphism","_endoWnafT1","_endoWnafT2","Point","isRed","inf","JPoint","zOne","betas","_getEndoRoots","lambdas","vec","_getEndoBasis","ntinv","prevR","aprxSqrt","y1","y2","len1","_endoSplit","v2","p2","q1","q2","ax","rhs","_endoWnafMulAdd","npoints","ncoeffs","fromJSON","endoMul","obj2point","nx","ny","ys1","dyinv","mulAdd","jmulAdd","_precompute","zinv","zinv2","ay","pz2","z2","nz","jx","jy","jz","jz4","jyd","jx2","jyd2","jyd4","dny","_zeroDbl","_threeDbl","_dbl","xx","yy","yyyy","yyyy8","gamma","alpha","beta4","beta8","ggamma8","jy2","jxd4","jyd8","trpl","zz","mm","yyu4","kbase","z3","pz3","eqXToP","zs","MontCurve","i4","a24","diffAdd","jumlAdd","other","EdwardsCurve","twisted","mOneA","oneC","_mulA","_mulC","lhs","pointFromY","_extDbl","nt","_projDbl","_extAdd","_projAdd","HmacDRBG","KeyPair","Signature","priv","fromPrivate","keyFromPublic","fromPublic","genKeyPair","drbg","persEnc","entropy","entropyEnc","ns2","_truncateToN","truncOnly","bkey","getPrivate","ns1","kp","kpX","sinv","isYOdd","isSecondKey","rInv","getKeyRecoveryParam","Qprime","predResist","minEntropy","_reseed","reseedInterval","nonceEnc","_hmac","kmac","reseed","addEnc","_importPrivate","privEnc","_importPublic","pubEnc","derive","_importDER","Position","place","getLength","octetLen","rmPadding","constructLength","octets","slen","toDER","backHalf","EDDSA","pointClass","encodingLength","secret","keyFromSecret","hashInt","messagePrefix","Rencoded","encodePoint","s_","pubBytes","makeSignature","SG","fromSecret","lastIx","normed","xIsOdd","encodeInt","decodeInt","isPoint","_secret","_pub","_pubBytes","privBytes","getSecret","_R","_S","_Rencoded","_Sencoded","Sencoded","SyntaxError","column","peg$subclass","peg$result","peg$FAILED","peg$startRuleFunctions","peg$parsestart","peg$startRuleFunction","peg$c1","peg$c2","peg$c3","peg$c4","peg$c5","peg$c6","peg$c7","peg$c8","peg$c9","peg$c10","peg$c11","addNode","peg$c12","peg$c13","peg$c14","peg$c15","peg$c16","peg$c17","peg$c18","peg$c19","peg$c20","peg$c21","peg$c22","peg$c23","peg$c24","peg$c25","peg$c26","peg$c27","peg$c28","peg$c29","peg$c30","peg$c31","peg$c32","peg$c33","peg$c34","peg$c35","peg$c36","peg$c37","peg$c38","peg$c39","peg$c40","peg$c41","peg$c42","parseFloat","peg$c43","peg$c44","peg$c45","peg$c46","digits","peg$c47","peg$c48","peg$c49","peg$c50","peg$c51","peg$c52","peg$c53","peg$c54","peg$c55","peg$c56","peg$c57","peg$c58","peg$c59","peg$c60","peg$c61","peg$c62","peg$c63","peg$c64","peg$c65","peg$c66","peg$c67","peg$c68","peg$c69","peg$c70","peg$c71","peg$c72","peg$c73","peg$c74","peg$c75","peg$c76","peg$c77","peg$c78","peg$c79","peg$c80","peg$c81","peg$c82","peg$c83","peg$c84","peg$c85","peg$c86","peg$c87","peg$c88","peg$c89","peg$c90","peg$c91","peg$c92","peg$c93","peg$c94","peg$c95","peg$c96","peg$c97","peg$c98","peg$c99","peg$c100","peg$c101","peg$c102","peg$c103","peg$c104","peg$c105","peg$c106","peg$c107","peg$c108","peg$c109","peg$c110","peg$c111","peg$c112","peg$c113","peg$c114","peg$c115","peg$c116","peg$c117","peg$c118","peg$c119","peg$c120","convertCodePoint","peg$c121","peg$c122","peg$currPos","peg$reportedPos","peg$cachedPos","peg$cachedPosDetails","seenCR","peg$maxFailPos","peg$maxFailExpected","peg$silentFails","peg$cache","startRule","peg$computePosDetails","startPos","endPos","advance","peg$fail","peg$buildException","posDetails","cleanupExpected","expectedDescs","stringEscape","buildMessage","nextPos","peg$parseline","s3","s4","s5","s6","peg$parseS","peg$parseexpression","peg$parsecomment","peg$parseNL","peg$parseEOF","peg$parsepath","peg$parsetablearray","peg$parseassignment","peg$parsetable_key","s7","peg$parsedot_ended_table_key_part","peg$parsetable_key_part","peg$parsekey","peg$parsequoted_key","peg$parsevalue","peg$parseASCII_BASIC","peg$parsedouble_quoted_single_line_string","peg$parsesingle_quoted_single_line_string","peg$parsestring","peg$parsedatetime","peg$parsefloat","peg$parseinteger","peg$parseboolean","peg$parsearray","peg$parseinline_table","peg$parsedouble_quoted_multiline_string","peg$parsesingle_quoted_multiline_string","peg$parsemultiline_string_char","peg$parsestring_char","peg$parsemultiline_literal_char","peg$parseliteral_char","peg$parseESCAPED","peg$parsemultiline_string_delim","peg$parseNLS","peg$parsefloat_text","peg$parseinteger_text","peg$parseDIGITS","peg$parseDIGIT_OR_UNDER","peg$parsearray_sep","peg$parsearray_value","peg$parsearray_value_list","peg$parseinline_table_assignment","s9","s10","peg$parsesecfragment","peg$parsedate","s11","peg$parsetime","peg$parsetime_with_offset","s12","s13","s14","s15","peg$parseHEX","peg$parseESCAPED_UNICODE","genError","ex","fromCodePoint","highSurrogate","lowSurrogate","MAX_SIZE","codeUnits","assignedPaths","valueAssignments","currentPath","setPath","addTableArray","fullPath","reduceValueNode","pathAssigned","firstType","reduceArrayWithTypeChecking","reduceInlineTableNode","quotedPath","quoteDottedString","deepRef","newObj","traversed","traversedPath","normalizeArray","allowAboveRoot","up","xs","resolvedPath","resolvedAbsolute","isAbsolute","trailingSlash","relative","fromParts","toParts","samePartsLength","outputParts","sep","dirname","hasRoot","matchedSlash","basename","extname","startDot","startPart","preDotState","jsx","jsxs"],"mappings":"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,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,kEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,sEAINz4B,IAAK,CACHyS,IAAK,EACLgmB,OAAQ,CACN,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,iEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,mEACA,oEAEF,CACE,kEACA,oEAEF,CACE,mEACA,mEAEF,CACE,mEACA,oEAE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","file":"static/js/2.83f6542d.chunk.js","sourcesContent":["import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","import { Struct, Infer, Result, Context, Describe } from './struct'\nimport { Failure } from './error'\n\n/**\n * Check if a value is an iterator.\n */\n\nfunction isIterable(x: unknown): x is Iterable {\n return isObject(x) && typeof x[Symbol.iterator] === 'function'\n}\n\n/**\n * Check if a value is a plain object.\n */\n\nexport function isObject(x: unknown): x is object {\n return typeof x === 'object' && x != null\n}\n\n/**\n * Check if a value is a plain object.\n */\n\nexport function isPlainObject(x: unknown): x is { [key: string]: any } {\n if (Object.prototype.toString.call(x) !== '[object Object]') {\n return false\n }\n\n const prototype = Object.getPrototypeOf(x)\n return prototype === null || prototype === Object.prototype\n}\n\n/**\n * Return a value as a printable string.\n */\n\nexport function print(value: any): string {\n return typeof value === 'string' ? JSON.stringify(value) : `${value}`\n}\n\n/**\n * Shifts (removes and returns) the first value from the `input` iterator.\n * Like `Array.prototype.shift()` but for an `Iterator`.\n */\n\nexport function shiftIterator(input: Iterator): T | undefined {\n const { done, value } = input.next()\n return done ? undefined : value\n}\n\n/**\n * Convert a single validation result to a failure.\n */\n\nexport function toFailure(\n result: string | boolean | Partial,\n context: Context,\n struct: Struct,\n value: any\n): Failure | undefined {\n if (result === true) {\n return\n } else if (result === false) {\n result = {}\n } else if (typeof result === 'string') {\n result = { message: result }\n }\n\n const { path, branch } = context\n const { type } = struct\n const {\n refinement,\n message = `Expected a value of type \\`${type}\\`${\n refinement ? ` with refinement \\`${refinement}\\`` : ''\n }, but received: \\`${print(value)}\\``,\n } = result\n\n return {\n value,\n type,\n refinement,\n key: path[path.length - 1],\n path,\n branch,\n ...result,\n message,\n }\n}\n\n/**\n * Convert a validation result to an iterable of failures.\n */\n\nexport function* toFailures(\n result: Result,\n context: Context,\n struct: Struct,\n value: any\n): IterableIterator {\n if (!isIterable(result)) {\n result = [result]\n }\n\n for (const r of result) {\n const failure = toFailure(r, context, struct, value)\n\n if (failure) {\n yield failure\n }\n }\n}\n\n/**\n * Check a value against a struct, traversing deeply into nested values, and\n * returning an iterator of failures or success.\n */\n\nexport function* run(\n value: unknown,\n struct: Struct,\n options: {\n path?: any[]\n branch?: any[]\n coerce?: boolean\n mask?: boolean\n } = {}\n): IterableIterator<[Failure, undefined] | [undefined, T]> {\n const { path = [], branch = [value], coerce = false, mask = false } = options\n const ctx: Context = { path, branch }\n\n if (coerce) {\n value = struct.coercer(value, ctx)\n\n if (\n mask &&\n struct.type !== 'type' &&\n isObject(struct.schema) &&\n isObject(value) &&\n !Array.isArray(value)\n ) {\n for (const key in value) {\n if (struct.schema[key] === undefined) {\n delete value[key]\n }\n }\n }\n }\n\n let valid = true\n\n for (const failure of struct.validator(value, ctx)) {\n valid = false\n yield [failure, undefined]\n }\n\n for (let [k, v, s] of struct.entries(value, ctx)) {\n const ts = run(v, s as Struct, {\n path: k === undefined ? path : [...path, k],\n branch: k === undefined ? branch : [...branch, v],\n coerce,\n mask,\n })\n\n for (const t of ts) {\n if (t[0]) {\n valid = false\n yield [t[0], undefined]\n } else if (coerce) {\n v = t[1]\n\n if (k === undefined) {\n value = v\n } else if (value instanceof Map) {\n value.set(k, v)\n } else if (value instanceof Set) {\n value.add(v)\n } else if (isObject(value)) {\n value[k] = v\n }\n }\n }\n }\n\n if (valid) {\n for (const failure of struct.refiner(value as T, ctx)) {\n valid = false\n yield [failure, undefined]\n }\n }\n\n if (valid) {\n yield [undefined, value as T]\n }\n}\n\n/**\n * Assign properties from one type to another, overwriting existing.\n */\n\nexport type Assign = Simplify>\n\n/**\n * A schema for enum structs.\n */\n\nexport type EnumSchema = { [K in T]: K }\n\n/**\n * Check if a type is an exact match.\n */\n\nexport type IsMatch = T extends G ? (G extends T ? T : never) : never\n\n/**\n * Check if a type is a record type.\n */\n\nexport type IsRecord = T extends object\n ? string extends keyof T\n ? T\n : never\n : never\n/**\n * Check if a type is a tuple.\n */\n\nexport type IsTuple = T extends [any]\n ? T\n : T extends [any, any]\n ? T\n : T extends [any, any, any]\n ? T\n : T extends [any, any, any, any]\n ? T\n : T extends [any, any, any, any, any]\n ? T\n : never\n\n/**\n * Check if a type is a union.\n */\n\nexport type IsUnion = (\n T extends any ? (U extends T ? false : true) : false\n) extends false\n ? never\n : T\n\n/**\n * A schema for object structs.\n */\n\nexport type ObjectSchema = Record>\n\n/**\n * Infer a type from an object struct schema.\n */\n\nexport type ObjectType = Simplify<\n Optionalize<{ [K in keyof S]: Infer }>\n>\n\n/**\n * Omit properties from a type that extend from a specific type.\n */\n\nexport type OmitBy = Omit<\n T,\n { [K in keyof T]: V extends Extract ? K : never }[keyof T]\n>\n\n/**\n * Normalize properties of a type that allow `undefined` to make them optional.\n */\n\nexport type Optionalize = OmitBy &\n Partial>\n\n/**\n * Transform an object schema type to represent a partial.\n */\n\nexport type PartialObjectSchema = {\n [K in keyof S]: Struct | undefined>\n}\n\n/**\n * Pick properties from a type that extend from a specific type.\n */\n\nexport type PickBy = Pick<\n T,\n { [K in keyof T]: V extends Extract ? K : never }[keyof T]\n>\n\n/**\n * Simplifies a type definition to its most basic representation.\n */\n\nexport type Simplify = T extends any[] | Date\n ? T\n : { [K in keyof T]: T[K] } & {}\n\nexport type If = B extends true ? Then : Else\n\n/**\n * A schema for any type of struct.\n */\n\nexport type StructSchema = [T] extends [string]\n ? [T] extends [IsMatch]\n ? null\n : [T] extends [IsUnion]\n ? EnumSchema\n : T\n : [T] extends [number]\n ? [T] extends [IsMatch]\n ? null\n : [T] extends [IsUnion]\n ? EnumSchema\n : T\n : [T] extends [boolean]\n ? [T] extends [IsMatch]\n ? null\n : T\n : T extends\n | bigint\n | symbol\n | undefined\n | null\n | Function\n | Date\n | Error\n | RegExp\n | Map\n | WeakMap\n | Set\n | WeakSet\n | Promise\n ? null\n : T extends Array\n ? T extends IsTuple\n ? null\n : Struct\n : T extends object\n ? T extends IsRecord\n ? null\n : { [K in keyof T]: Describe }\n : null\n\n/**\n * A schema for tuple structs.\n */\n\nexport type TupleSchema = { [K in keyof T]: Struct }\n","/**\n * A `StructFailure` represents a single specific failure in validation.\n */\n\nexport type Failure = {\n value: any\n key: any\n type: string\n refinement: string | undefined\n message: string\n branch: Array\n path: Array\n}\n\n/**\n * `StructError` objects are thrown (or returned) when validation fails.\n *\n * Validation logic is design to exit early for maximum performance. The error\n * represents the first error encountered during validation. For more detail,\n * the `error.failures` property is a generator function that can be run to\n * continue validation and receive all the failures in the data.\n */\n\nexport class StructError extends TypeError {\n value: any\n key!: any\n type!: string\n refinement!: string | undefined\n path!: Array\n branch!: Array\n failures: () => Array;\n [x: string]: any\n\n constructor(failure: Failure, failures: () => Generator) {\n let cached: Array | undefined\n const { message, ...rest } = failure\n const { path } = failure\n const msg =\n path.length === 0 ? message : `At path: ${path.join('.')} -- ${message}`\n super(msg)\n Object.assign(this, rest)\n this.name = this.constructor.name\n this.failures = () => {\n return (cached ??= [failure, ...failures()])\n }\n }\n}\n","import { toFailures, shiftIterator, StructSchema, run } from './utils'\nimport { StructError, Failure } from './error'\n\n/**\n * `Struct` objects encapsulate the validation logic for a specific type of\n * values. Once constructed, you use the `assert`, `is` or `validate` helpers to\n * validate unknown input data against the struct.\n */\n\nexport class Struct {\n readonly TYPE!: T\n type: string\n schema: S\n coercer: (value: unknown, context: Context) => unknown\n validator: (value: unknown, context: Context) => Iterable\n refiner: (value: T, context: Context) => Iterable\n entries: (\n value: unknown,\n context: Context\n ) => Iterable<[string | number, unknown, Struct | Struct]>\n\n constructor(props: {\n type: string\n schema: S\n coercer?: Coercer\n validator?: Validator\n refiner?: Refiner\n entries?: Struct['entries']\n }) {\n const {\n type,\n schema,\n validator,\n refiner,\n coercer = (value: unknown) => value,\n entries = function* () {},\n } = props\n\n this.type = type\n this.schema = schema\n this.entries = entries\n this.coercer = coercer\n\n if (validator) {\n this.validator = (value, context) => {\n const result = validator(value, context)\n return toFailures(result, context, this, value)\n }\n } else {\n this.validator = () => []\n }\n\n if (refiner) {\n this.refiner = (value, context) => {\n const result = refiner(value, context)\n return toFailures(result, context, this, value)\n }\n } else {\n this.refiner = () => []\n }\n }\n\n /**\n * Assert that a value passes the struct's validation, throwing if it doesn't.\n */\n\n assert(value: unknown): asserts value is T {\n return assert(value, this)\n }\n\n /**\n * Create a value with the struct's coercion logic, then validate it.\n */\n\n create(value: unknown): T {\n return create(value, this)\n }\n\n /**\n * Check if a value passes the struct's validation.\n */\n\n is(value: unknown): value is T {\n return is(value, this)\n }\n\n /**\n * Mask a value, coercing and validating it, but returning only the subset of\n * properties defined by the struct's schema.\n */\n\n mask(value: unknown): T {\n return mask(value, this)\n }\n\n /**\n * Validate a value with the struct's validation logic, returning a tuple\n * representing the result.\n *\n * You may optionally pass `true` for the `withCoercion` argument to coerce\n * the value before attempting to validate it. If you do, the result will\n * contain the coerced result when successful.\n */\n\n validate(\n value: unknown,\n options: {\n coerce?: boolean\n } = {}\n ): [StructError, undefined] | [undefined, T] {\n return validate(value, this, options)\n }\n}\n\n/**\n * Assert that a value passes a struct, throwing if it doesn't.\n */\n\nexport function assert(\n value: unknown,\n struct: Struct\n): asserts value is T {\n const result = validate(value, struct)\n\n if (result[0]) {\n throw result[0]\n }\n}\n\n/**\n * Create a value with the coercion logic of struct and validate it.\n */\n\nexport function create(value: unknown, struct: Struct): T {\n const result = validate(value, struct, { coerce: true })\n\n if (result[0]) {\n throw result[0]\n } else {\n return result[1]\n }\n}\n\n/**\n * Mask a value, returning only the subset of properties defined by a struct.\n */\n\nexport function mask(value: unknown, struct: Struct): T {\n const result = validate(value, struct, { coerce: true, mask: true })\n\n if (result[0]) {\n throw result[0]\n } else {\n return result[1]\n }\n}\n\n/**\n * Check if a value passes a struct.\n */\n\nexport function is(value: unknown, struct: Struct): value is T {\n const result = validate(value, struct)\n return !result[0]\n}\n\n/**\n * Validate a value against a struct, returning an error if invalid, or the\n * value (with potential coercion) if valid.\n */\n\nexport function validate(\n value: unknown,\n struct: Struct,\n options: {\n coerce?: boolean\n mask?: boolean\n } = {}\n): [StructError, undefined] | [undefined, T] {\n const tuples = run(value, struct, options)\n const tuple = shiftIterator(tuples)!\n\n if (tuple[0]) {\n const error = new StructError(tuple[0], function* () {\n for (const t of tuples) {\n if (t[0]) {\n yield t[0]\n }\n }\n })\n\n return [error, undefined]\n } else {\n const v = tuple[1]\n return [undefined, v]\n }\n}\n\n/**\n * A `Context` contains information about the current location of the\n * validation inside the initial input value.\n */\n\nexport type Context = {\n branch: Array\n path: Array\n}\n\n/**\n * A type utility to extract the type from a `Struct` class.\n */\n\nexport type Infer> = T['TYPE']\n\n/**\n * A type utility to describe that a struct represents a TypeScript type.\n */\n\nexport type Describe = Struct>\n\n/**\n * A `Result` is returned from validation functions.\n */\n\nexport type Result =\n | boolean\n | string\n | Partial\n | Iterable>\n\n/**\n * A `Coercer` takes an unknown value and optionally coerces it.\n */\n\nexport type Coercer = (value: T, context: Context) => unknown\n\n/**\n * A `Validator` takes an unknown value and validates it.\n */\n\nexport type Validator = (value: unknown, context: Context) => Result\n\n/**\n * A `Refiner` takes a value of a known type and validates it against a further\n * constraint.\n */\n\nexport type Refiner = (value: T, context: Context) => Result\n","import { Struct, Context, Validator } from '../struct'\nimport { object, optional } from './types'\nimport { ObjectSchema, Assign, ObjectType, PartialObjectSchema } from '../utils'\n\n/**\n * Create a new struct that combines the properties properties from multiple\n * object structs.\n *\n * Like JavaScript's `Object.assign` utility.\n */\n\nexport function assign(\n A: Struct, A>,\n B: Struct, B>\n): Struct>, Assign>\nexport function assign<\n A extends ObjectSchema,\n B extends ObjectSchema,\n C extends ObjectSchema\n>(\n A: Struct, A>,\n B: Struct, B>,\n C: Struct, C>\n): Struct, C>>, Assign, C>>\nexport function assign<\n A extends ObjectSchema,\n B extends ObjectSchema,\n C extends ObjectSchema,\n D extends ObjectSchema\n>(\n A: Struct, A>,\n B: Struct, B>,\n C: Struct, C>,\n D: Struct, D>\n): Struct<\n ObjectType, C>, D>>,\n Assign, C>, D>\n>\nexport function assign<\n A extends ObjectSchema,\n B extends ObjectSchema,\n C extends ObjectSchema,\n D extends ObjectSchema,\n E extends ObjectSchema\n>(\n A: Struct, A>,\n B: Struct, B>,\n C: Struct, C>,\n D: Struct, D>,\n E: Struct, E>\n): Struct<\n ObjectType, C>, D>, E>>,\n Assign, C>, D>, E>\n>\nexport function assign(...Structs: Struct[]): any {\n const schemas = Structs.map((s) => s.schema)\n const schema = Object.assign({}, ...schemas)\n return object(schema)\n}\n\n/**\n * Define a new struct type with a custom validation function.\n */\n\nexport function define(name: string, validator: Validator): Struct {\n return new Struct({ type: name, schema: null, validator })\n}\n\n/**\n * Create a new struct based on an existing struct, but the value is allowed to\n * be `undefined`. `log` will be called if the value is not `undefined`.\n */\n\nexport function deprecated(\n struct: Struct,\n log: (value: unknown, ctx: Context) => void\n): Struct {\n return new Struct({\n ...struct,\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx),\n validator(value, ctx) {\n if (value === undefined) {\n return true\n } else {\n log(value, ctx)\n return struct.validator(value, ctx)\n }\n },\n })\n}\n\n/**\n * Create a struct with dynamic validation logic.\n *\n * The callback will receive the value currently being validated, and must\n * return a struct object to validate it with. This can be useful to model\n * validation logic that changes based on its input.\n */\n\nexport function dynamic(\n fn: (value: unknown, ctx: Context) => Struct\n): Struct {\n return new Struct({\n type: 'dynamic',\n schema: null,\n *entries(value, ctx) {\n const struct = fn(value, ctx)\n yield* struct.entries(value, ctx)\n },\n validator(value, ctx) {\n const struct = fn(value, ctx)\n return struct.validator(value, ctx)\n },\n coercer(value, ctx) {\n const struct = fn(value, ctx)\n return struct.coercer(value, ctx)\n },\n })\n}\n\n/**\n * Create a struct with lazily evaluated validation logic.\n *\n * The first time validation is run with the struct, the callback will be called\n * and must return a struct object to use. This is useful for cases where you\n * want to have self-referential structs for nested data structures to avoid a\n * circular definition problem.\n */\n\nexport function lazy(fn: () => Struct): Struct {\n let struct: Struct | undefined\n return new Struct({\n type: 'lazy',\n schema: null,\n *entries(value, ctx) {\n struct ??= fn()\n yield* struct.entries(value, ctx)\n },\n validator(value, ctx) {\n struct ??= fn()\n return struct.validator(value, ctx)\n },\n coercer(value, ctx) {\n struct ??= fn()\n return struct.coercer(value, ctx)\n },\n })\n}\n\n/**\n * Create a new struct based on an existing object struct, but excluding\n * specific properties.\n *\n * Like TypeScript's `Omit` utility.\n */\n\nexport function omit(\n struct: Struct, S>,\n keys: K[]\n): Struct>, Omit> {\n const { schema } = struct\n const subschema: any = { ...schema }\n\n for (const key of keys) {\n delete subschema[key]\n }\n\n return object(subschema as Omit)\n}\n\n/**\n * Create a new struct based on an existing object struct, but with all of its\n * properties allowed to be `undefined`.\n *\n * Like TypeScript's `Partial` utility.\n */\n\nexport function partial(\n struct: Struct, S> | S\n): Struct>, PartialObjectSchema> {\n const schema: any =\n struct instanceof Struct ? { ...struct.schema } : { ...struct }\n\n for (const key in schema) {\n schema[key] = optional(schema[key])\n }\n\n return object(schema) as any\n}\n\n/**\n * Create a new struct based on an existing object struct, but only including\n * specific properties.\n *\n * Like TypeScript's `Pick` utility.\n */\n\nexport function pick(\n struct: Struct, S>,\n keys: K[]\n): Struct>, Pick> {\n const { schema } = struct\n const subschema: any = {}\n\n for (const key of keys) {\n subschema[key] = schema[key]\n }\n\n return object(subschema as Pick)\n}\n\n/**\n * Define a new struct type with a custom validation function.\n *\n * @deprecated This function has been renamed to `define`.\n */\n\nexport function struct(name: string, validator: Validator): Struct {\n console.warn(\n 'superstruct@0.11 - The `struct` helper has been renamed to `define`.'\n )\n\n return define(name, validator)\n}\n","import { Infer, Struct } from '../struct'\nimport { define } from './utilities'\nimport {\n TupleSchema,\n ObjectSchema,\n ObjectType,\n print,\n run,\n isObject,\n} from '../utils'\n\n/**\n * Ensure that any value passes validation.\n */\n\nexport function any(): Struct {\n return define('any', () => true)\n}\n\n/**\n * Ensure that a value is an array and that its elements are of a specific type.\n *\n * Note: If you omit the element struct, the arrays elements will not be\n * iterated at all. This can be helpful for cases where performance is critical,\n * and it is preferred to using `array(any())`.\n */\n\nexport function array>(Element: T): Struct[], T>\nexport function array(): Struct\nexport function array>(Element?: T): any {\n return new Struct({\n type: 'array',\n schema: Element,\n *entries(value) {\n if (Element && Array.isArray(value)) {\n for (const [i, v] of value.entries()) {\n yield [i, v, Element]\n }\n }\n },\n coercer(value) {\n return Array.isArray(value) ? value.slice() : value\n },\n validator(value) {\n return (\n Array.isArray(value) ||\n `Expected an array value, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value is a boolean.\n */\n\nexport function boolean(): Struct {\n return define('boolean', (value) => {\n return typeof value === 'boolean'\n })\n}\n\n/**\n * Ensure that a value is a valid `Date`.\n *\n * Note: this also ensures that the value is *not* an invalid `Date` object,\n * which can occur when parsing a date fails but still returns a `Date`.\n */\n\nexport function date(): Struct {\n return define('date', (value) => {\n return (\n (value instanceof Date && !isNaN(value.getTime())) ||\n `Expected a valid \\`Date\\` object, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value is one of a set of potential values.\n *\n * Note: after creating the struct, you can access the definition of the\n * potential values as `struct.schema`.\n */\n\nexport function enums(\n values: readonly T[]\n): Struct\nexport function enums(\n values: readonly T[]\n): Struct\nexport function enums(values: readonly T[]): any {\n const schema: any = {}\n const description = values.map((v) => print(v)).join()\n\n for (const key of values) {\n schema[key] = key\n }\n\n return new Struct({\n type: 'enums',\n schema,\n validator(value) {\n return (\n values.includes(value as any) ||\n `Expected one of \\`${description}\\`, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value is a function.\n */\n\nexport function func(): Struct {\n return define('func', (value) => {\n return (\n typeof value === 'function' ||\n `Expected a function, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value is an instance of a specific class.\n */\n\nexport function instance(\n Class: T\n): Struct, null> {\n return define('instance', (value) => {\n return (\n value instanceof Class ||\n `Expected a \\`${Class.name}\\` instance, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value is an integer.\n */\n\nexport function integer(): Struct {\n return define('integer', (value) => {\n return (\n (typeof value === 'number' && !isNaN(value) && Number.isInteger(value)) ||\n `Expected an integer, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value matches all of a set of types.\n */\n\nexport function intersection(Structs: TupleSchema<[A]>): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P]>\n): Struct\nexport function intersection(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q]>\n): Struct<\n A & B & C & D & E & F & G & H & I & J & K & L & M & N & O & P & Q,\n null\n>\nexport function intersection(Structs: Array>): any {\n return new Struct({\n type: 'intersection',\n schema: null,\n *entries(value, ctx) {\n for (const S of Structs) {\n yield* S.entries(value, ctx)\n }\n },\n *validator(value, ctx) {\n for (const S of Structs) {\n yield* S.validator(value, ctx)\n }\n },\n *refiner(value, ctx) {\n for (const S of Structs) {\n yield* S.refiner(value, ctx)\n }\n },\n })\n}\n\n/**\n * Ensure that a value is an exact value, using `===` for comparison.\n */\n\nexport function literal(constant: T): Struct\nexport function literal(constant: T): Struct\nexport function literal(constant: T): Struct\nexport function literal(constant: T): Struct\nexport function literal(constant: T): any {\n const description = print(constant)\n const t = typeof constant\n return new Struct({\n type: 'literal',\n schema:\n t === 'string' || t === 'number' || t === 'boolean' ? constant : null,\n validator(value) {\n return (\n value === constant ||\n `Expected the literal \\`${description}\\`, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value is a `Map` object, and that its keys and values are of\n * specific types.\n */\n\nexport function map(): Struct, null>\nexport function map(\n Key: Struct,\n Value: Struct\n): Struct, null>\nexport function map(Key?: Struct, Value?: Struct): any {\n return new Struct({\n type: 'map',\n schema: null,\n *entries(value) {\n if (Key && Value && value instanceof Map) {\n for (const [k, v] of value.entries()) {\n yield [k as string, k, Key]\n yield [k as string, v, Value]\n }\n }\n },\n coercer(value) {\n return value instanceof Map ? new Map(value) : value\n },\n validator(value) {\n return (\n value instanceof Map ||\n `Expected a \\`Map\\` object, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that no value ever passes validation.\n */\n\nexport function never(): Struct {\n return define('never', () => false)\n}\n\n/**\n * Augment an existing struct to allow `null` values.\n */\n\nexport function nullable(struct: Struct): Struct {\n return new Struct({\n ...struct,\n validator: (value, ctx) => value === null || struct.validator(value, ctx),\n refiner: (value, ctx) => value === null || struct.refiner(value, ctx),\n })\n}\n\n/**\n * Ensure that a value is a number.\n */\n\nexport function number(): Struct {\n return define('number', (value) => {\n return (\n (typeof value === 'number' && !isNaN(value)) ||\n `Expected a number, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value is an object, that is has a known set of properties,\n * and that its properties are of specific types.\n *\n * Note: Unrecognized properties will fail validation.\n */\n\nexport function object(): Struct, null>\nexport function object(\n schema: S\n): Struct, S>\nexport function object(schema?: S): any {\n const knowns = schema ? Object.keys(schema) : []\n const Never = never()\n return new Struct({\n type: 'object',\n schema: schema ? schema : null,\n *entries(value) {\n if (schema && isObject(value)) {\n const unknowns = new Set(Object.keys(value))\n\n for (const key of knowns) {\n unknowns.delete(key)\n yield [key, value[key], schema[key]]\n }\n\n for (const key of unknowns) {\n yield [key, value[key], Never]\n }\n }\n },\n validator(value) {\n return (\n isObject(value) || `Expected an object, but received: ${print(value)}`\n )\n },\n coercer(value) {\n return isObject(value) ? { ...value } : value\n },\n })\n}\n\n/**\n * Augment a struct to allow `undefined` values.\n */\n\nexport function optional(struct: Struct): Struct {\n return new Struct({\n ...struct,\n validator: (value, ctx) =>\n value === undefined || struct.validator(value, ctx),\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx),\n })\n}\n\n/**\n * Ensure that a value is an object with keys and values of specific types, but\n * without ensuring any specific shape of properties.\n *\n * Like TypeScript's `Record` utility.\n */\n\nexport function record(\n Key: Struct,\n Value: Struct\n): Struct, null> {\n return new Struct({\n type: 'record',\n schema: null,\n *entries(value) {\n if (isObject(value)) {\n for (const k in value) {\n const v = value[k]\n yield [k, k, Key]\n yield [k, v, Value]\n }\n }\n },\n validator(value) {\n return (\n isObject(value) || `Expected an object, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value is a `RegExp`.\n *\n * Note: this does not test the value against the regular expression! For that\n * you need to use the `pattern()` refinement.\n */\n\nexport function regexp(): Struct {\n return define('regexp', (value) => {\n return value instanceof RegExp\n })\n}\n\n/**\n * Ensure that a value is a `Set` object, and that its elements are of a\n * specific type.\n */\n\nexport function set(): Struct, null>\nexport function set(Element: Struct): Struct, null>\nexport function set(Element?: Struct): any {\n return new Struct({\n type: 'set',\n schema: null,\n *entries(value) {\n if (Element && value instanceof Set) {\n for (const v of value) {\n yield [v as string, v, Element]\n }\n }\n },\n coercer(value) {\n return value instanceof Set ? new Set(value) : value\n },\n validator(value) {\n return (\n value instanceof Set ||\n `Expected a \\`Set\\` object, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value is a string.\n */\n\nexport function string(): Struct {\n return define('string', (value) => {\n return (\n typeof value === 'string' ||\n `Expected a string, but received: ${print(value)}`\n )\n })\n}\n\n/**\n * Ensure that a value is a tuple of a specific length, and that each of its\n * elements is of a specific type.\n */\n\nexport function tuple(Structs: TupleSchema<[A]>): Struct<[A], null>\nexport function tuple(Structs: TupleSchema<[A, B]>): Struct<[A, B], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C]>\n): Struct<[A, B, C], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D]>\n): Struct<[A, B, C, D], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E]>\n): Struct<[A, B, C, D, E], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F]>\n): Struct<[A, B, C, D, E, F], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G]>\n): Struct<[A, B, C, D, E, F, G], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H]>\n): Struct<[A, B, C, D, E, F, G, H], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I]>\n): Struct<[A, B, C, D, E, F, G, H, I], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J]>\n): Struct<[A, B, C, D, E, F, G, H, I, J], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L, M], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L, M, N], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P], null>\nexport function tuple(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q]>\n): Struct<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q], null>\nexport function tuple(Elements: Struct[]): any {\n const Never = never()\n\n return new Struct({\n type: 'tuple',\n schema: null,\n *entries(value) {\n if (Array.isArray(value)) {\n const length = Math.max(Elements.length, value.length)\n\n for (let i = 0; i < length; i++) {\n yield [i, value[i], Elements[i] || Never]\n }\n }\n },\n validator(value) {\n return (\n Array.isArray(value) ||\n `Expected an array, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value has a set of known properties of specific types.\n *\n * Note: Unrecognized properties are allowed and untouched. This is similar to\n * how TypeScript's structural typing works.\n */\n\nexport function type(\n schema: S\n): Struct, S> {\n const keys = Object.keys(schema)\n return new Struct({\n type: 'type',\n schema,\n *entries(value) {\n if (isObject(value)) {\n for (const k of keys) {\n yield [k, value[k], schema[k]]\n }\n }\n },\n validator(value) {\n return (\n isObject(value) || `Expected an object, but received: ${print(value)}`\n )\n },\n })\n}\n\n/**\n * Ensure that a value matches one of a set of types.\n */\n\nexport function union(Structs: TupleSchema<[A]>): Struct\nexport function union(Structs: TupleSchema<[A, B]>): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P]>\n): Struct\nexport function union(\n Structs: TupleSchema<[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q]>\n): Struct<\n A | B | C | D | E | F | G | H | I | J | K | L | M | N | O | P | Q,\n null\n>\nexport function union(Structs: Struct[]): any {\n const description = Structs.map((s) => s.type).join(' | ')\n return new Struct({\n type: 'union',\n schema: null,\n validator(value, ctx) {\n const failures = []\n\n for (const S of Structs) {\n const [...tuples] = run(value, S, ctx)\n const [first] = tuples\n\n if (!first[0]) {\n return []\n } else {\n for (const [failure] of tuples) {\n if (failure) {\n failures.push(failure)\n }\n }\n }\n }\n\n return [\n `Expected the value to satisfy a union of \\`${description}\\`, but received: ${print(\n value\n )}`,\n ...failures,\n ]\n },\n })\n}\n\n/**\n * Ensure that any value passes validation, without widening its type to `any`.\n */\n\nexport function unknown(): Struct {\n return define('unknown', () => true)\n}\n","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}","import { Struct, is, Coercer } from '../struct'\nimport { isPlainObject } from '../utils'\nimport { string, unknown } from './types'\n\n/**\n * Augment a `Struct` to add an additional coercion step to its input.\n *\n * This allows you to transform input data before validating it, to increase the\n * likelihood that it passes validation—for example for default values, parsing\n * different formats, etc.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\n\nexport function coerce(\n struct: Struct,\n condition: Struct,\n coercer: Coercer\n): Struct {\n return new Struct({\n ...struct,\n coercer: (value, ctx) => {\n return is(value, condition)\n ? struct.coercer(coercer(value, ctx), ctx)\n : struct.coercer(value, ctx)\n },\n })\n}\n\n/**\n * Augment a struct to replace `undefined` values with a default.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\n\nexport function defaulted(\n struct: Struct,\n fallback: any,\n options: {\n strict?: boolean\n } = {}\n): Struct {\n return coerce(struct, unknown(), (x) => {\n const f = typeof fallback === 'function' ? fallback() : fallback\n\n if (x === undefined) {\n return f\n }\n\n if (!options.strict && isPlainObject(x) && isPlainObject(f)) {\n const ret = { ...x }\n let changed = false\n\n for (const key in f) {\n if (ret[key] === undefined) {\n ret[key] = f[key]\n changed = true\n }\n }\n\n if (changed) {\n return ret\n }\n }\n\n return x\n })\n}\n\n/**\n * Augment a struct to trim string inputs.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\n\nexport function trimmed(struct: Struct): Struct {\n return coerce(struct, string(), (x) => x.trim())\n}\n","module.exports = require(\"regenerator-runtime\");\n","/* The MIT License (MIT)\n *\n * Copyright 2015-2018 Peter A. Bigot\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * Support for translating between Uint8Array instances and JavaScript\n * native types.\n *\n * {@link module:Layout~Layout|Layout} is the basis of a class\n * hierarchy that associates property names with sequences of encoded\n * bytes.\n *\n * Layouts are supported for these scalar (numeric) types:\n * * {@link module:Layout~UInt|Unsigned integers in little-endian\n * format} with {@link module:Layout.u8|8-bit}, {@link\n * module:Layout.u16|16-bit}, {@link module:Layout.u24|24-bit},\n * {@link module:Layout.u32|32-bit}, {@link\n * module:Layout.u40|40-bit}, and {@link module:Layout.u48|48-bit}\n * representation ranges;\n * * {@link module:Layout~UIntBE|Unsigned integers in big-endian\n * format} with {@link module:Layout.u16be|16-bit}, {@link\n * module:Layout.u24be|24-bit}, {@link module:Layout.u32be|32-bit},\n * {@link module:Layout.u40be|40-bit}, and {@link\n * module:Layout.u48be|48-bit} representation ranges;\n * * {@link module:Layout~Int|Signed integers in little-endian\n * format} with {@link module:Layout.s8|8-bit}, {@link\n * module:Layout.s16|16-bit}, {@link module:Layout.s24|24-bit},\n * {@link module:Layout.s32|32-bit}, {@link\n * module:Layout.s40|40-bit}, and {@link module:Layout.s48|48-bit}\n * representation ranges;\n * * {@link module:Layout~IntBE|Signed integers in big-endian format}\n * with {@link module:Layout.s16be|16-bit}, {@link\n * module:Layout.s24be|24-bit}, {@link module:Layout.s32be|32-bit},\n * {@link module:Layout.s40be|40-bit}, and {@link\n * module:Layout.s48be|48-bit} representation ranges;\n * * 64-bit integral values that decode to an exact (if magnitude is\n * less than 2^53) or nearby integral Number in {@link\n * module:Layout.nu64|unsigned little-endian}, {@link\n * module:Layout.nu64be|unsigned big-endian}, {@link\n * module:Layout.ns64|signed little-endian}, and {@link\n * module:Layout.ns64be|unsigned big-endian} encodings;\n * * 32-bit floating point values with {@link\n * module:Layout.f32|little-endian} and {@link\n * module:Layout.f32be|big-endian} representations;\n * * 64-bit floating point values with {@link\n * module:Layout.f64|little-endian} and {@link\n * module:Layout.f64be|big-endian} representations;\n * * {@link module:Layout.const|Constants} that take no space in the\n * encoded expression.\n *\n * and for these aggregate types:\n * * {@link module:Layout.seq|Sequence}s of instances of a {@link\n * module:Layout~Layout|Layout}, with JavaScript representation as\n * an Array and constant or data-dependent {@link\n * module:Layout~Sequence#count|length};\n * * {@link module:Layout.struct|Structure}s that aggregate a\n * heterogeneous sequence of {@link module:Layout~Layout|Layout}\n * instances, with JavaScript representation as an Object;\n * * {@link module:Layout.union|Union}s that support multiple {@link\n * module:Layout~VariantLayout|variant layouts} over a fixed\n * (padded) or variable (not padded) span of bytes, using an\n * unsigned integer at the start of the data or a separate {@link\n * module:Layout.unionLayoutDiscriminator|layout element} to\n * determine which layout to use when interpreting the buffer\n * contents;\n * * {@link module:Layout.bits|BitStructure}s that contain a sequence\n * of individual {@link\n * module:Layout~BitStructure#addField|BitField}s packed into an 8,\n * 16, 24, or 32-bit unsigned integer starting at the least- or\n * most-significant bit;\n * * {@link module:Layout.cstr|C strings} of varying length;\n * * {@link module:Layout.blob|Blobs} of fixed- or variable-{@link\n * module:Layout~Blob#length|length} raw data.\n *\n * All {@link module:Layout~Layout|Layout} instances are immutable\n * after construction, to prevent internal state from becoming\n * inconsistent.\n *\n * @local Layout\n * @local ExternalLayout\n * @local GreedyCount\n * @local OffsetLayout\n * @local UInt\n * @local UIntBE\n * @local Int\n * @local IntBE\n * @local NearUInt64\n * @local NearUInt64BE\n * @local NearInt64\n * @local NearInt64BE\n * @local Float\n * @local FloatBE\n * @local Double\n * @local DoubleBE\n * @local Sequence\n * @local Structure\n * @local UnionDiscriminator\n * @local UnionLayoutDiscriminator\n * @local Union\n * @local VariantLayout\n * @local BitStructure\n * @local BitField\n * @local Boolean\n * @local Blob\n * @local CString\n * @local Constant\n * @local bindConstructorLayout\n * @module Layout\n * @license MIT\n * @author Peter A. Bigot\n * @see {@link https://github.com/pabigot/buffer-layout|buffer-layout on GitHub}\n */\n'use strict';\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nexports.__esModule = true;\nexports.s16 = exports.s8 = exports.nu64be = exports.u48be = exports.u40be = exports.u32be = exports.u24be = exports.u16be = exports.nu64 = exports.u48 = exports.u40 = exports.u32 = exports.u24 = exports.u16 = exports.u8 = exports.offset = exports.greedy = exports.Constant = exports.UTF8 = exports.CString = exports.Blob = exports.Boolean = exports.BitField = exports.BitStructure = exports.VariantLayout = exports.Union = exports.UnionLayoutDiscriminator = exports.UnionDiscriminator = exports.Structure = exports.Sequence = exports.DoubleBE = exports.Double = exports.FloatBE = exports.Float = exports.NearInt64BE = exports.NearInt64 = exports.NearUInt64BE = exports.NearUInt64 = exports.IntBE = exports.Int = exports.UIntBE = exports.UInt = exports.OffsetLayout = exports.GreedyCount = exports.ExternalLayout = exports.bindConstructorLayout = exports.nameWithProperty = exports.Layout = exports.uint8ArrayToBuffer = exports.checkUint8Array = void 0;\nexports.constant = exports.utf8 = exports.cstr = exports.blob = exports.unionLayoutDiscriminator = exports.union = exports.seq = exports.bits = exports.struct = exports.f64be = exports.f64 = exports.f32be = exports.f32 = exports.ns64be = exports.s48be = exports.s40be = exports.s32be = exports.s24be = exports.s16be = exports.ns64 = exports.s48 = exports.s40 = exports.s32 = exports.s24 = void 0;\nvar buffer_1 = require(\"buffer\");\n/* Check if a value is a Uint8Array.\n *\n * @ignore */\nfunction checkUint8Array(b) {\n if (!(b instanceof Uint8Array)) {\n throw new TypeError('b must be a Uint8Array');\n }\n}\nexports.checkUint8Array = checkUint8Array;\n/* Create a Buffer instance from a Uint8Array.\n *\n * @ignore */\nfunction uint8ArrayToBuffer(b) {\n checkUint8Array(b);\n return buffer_1.Buffer.from(b.buffer, b.byteOffset, b.length);\n}\nexports.uint8ArrayToBuffer = uint8ArrayToBuffer;\n/**\n * Base class for layout objects.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support the {@link\n * Layout#encode|encode} or {@link Layout#decode|decode} functions.\n *\n * @param {Number} span - Initializer for {@link Layout#span|span}. The\n * parameter must be an integer; a negative value signifies that the\n * span is {@link Layout#getSpan|value-specific}.\n *\n * @param {string} [property] - Initializer for {@link\n * Layout#property|property}.\n *\n * @abstract\n */\nvar Layout = /** @class */ (function () {\n function Layout(span, property) {\n if (!Number.isInteger(span)) {\n throw new TypeError('span must be an integer');\n }\n /** The span of the layout in bytes.\n *\n * Positive values are generally expected.\n *\n * Zero will only appear in {@link Constant}s and in {@link\n * Sequence}s where the {@link Sequence#count|count} is zero.\n *\n * A negative value indicates that the span is value-specific, and\n * must be obtained using {@link Layout#getSpan|getSpan}. */\n this.span = span;\n /** The property name used when this layout is represented in an\n * Object.\n *\n * Used only for layouts that {@link Layout#decode|decode} to Object\n * instances. If left undefined the span of the unnamed layout will\n * be treated as padding: it will not be mutated by {@link\n * Layout#encode|encode} nor represented as a property in the\n * decoded Object. */\n this.property = property;\n }\n /** Function to create an Object into which decoded properties will\n * be written.\n *\n * Used only for layouts that {@link Layout#decode|decode} to Object\n * instances, which means:\n * * {@link Structure}\n * * {@link Union}\n * * {@link VariantLayout}\n * * {@link BitStructure}\n *\n * If left undefined the JavaScript representation of these layouts\n * will be Object instances.\n *\n * See {@link bindConstructorLayout}.\n */\n Layout.prototype.makeDestinationObject = function () {\n return {};\n };\n /**\n * Decode from a Uint8Array into a JavaScript value.\n *\n * @param {Uint8Array} b - the buffer from which encoded data is read.\n *\n * @param {Number} [offset] - the offset at which the encoded data\n * starts. If absent a zero offset is inferred.\n *\n * @returns {(Number|Array|Object)} - the value of the decoded data.\n *\n * @abstract\n */\n Layout.prototype.decode = function (b, offset) {\n throw new Error('Layout is abstract');\n };\n /**\n * Encode a JavaScript value into a Uint8Array.\n *\n * @param {(Number|Array|Object)} src - the value to be encoded into\n * the buffer. The type accepted depends on the (sub-)type of {@link\n * Layout}.\n *\n * @param {Uint8Array} b - the buffer into which encoded data will be\n * written.\n *\n * @param {Number} [offset] - the offset at which the encoded data\n * starts. If absent a zero offset is inferred.\n *\n * @returns {Number} - the number of bytes encoded, including the\n * space skipped for internal padding, but excluding data such as\n * {@link Sequence#count|lengths} when stored {@link\n * ExternalLayout|externally}. This is the adjustment to `offset`\n * producing the offset where data for the next layout would be\n * written.\n *\n * @abstract\n */\n Layout.prototype.encode = function (src, b, offset) {\n throw new Error('Layout is abstract');\n };\n /**\n * Calculate the span of a specific instance of a layout.\n *\n * @param {Uint8Array} b - the buffer that contains an encoded instance.\n *\n * @param {Number} [offset] - the offset at which the encoded instance\n * starts. If absent a zero offset is inferred.\n *\n * @return {Number} - the number of bytes covered by the layout\n * instance. If this method is not overridden in a subclass the\n * definition-time constant {@link Layout#span|span} will be\n * returned.\n *\n * @throws {RangeError} - if the length of the value cannot be\n * determined.\n */\n Layout.prototype.getSpan = function (b, offset) {\n if (0 > this.span) {\n throw new RangeError('indeterminate span');\n }\n return this.span;\n };\n /**\n * Replicate the layout using a new property.\n *\n * This function must be used to get a structurally-equivalent layout\n * with a different name since all {@link Layout} instances are\n * immutable.\n *\n * **NOTE** This is a shallow copy. All fields except {@link\n * Layout#property|property} are strictly equal to the origin layout.\n *\n * @param {String} property - the value for {@link\n * Layout#property|property} in the replica.\n *\n * @returns {Layout} - the copy with {@link Layout#property|property}\n * set to `property`.\n */\n Layout.prototype.replicate = function (property) {\n var rv = Object.create(this.constructor.prototype);\n Object.assign(rv, this);\n rv.property = property;\n return rv;\n };\n /**\n * Create an object from layout properties and an array of values.\n *\n * **NOTE** This function returns `undefined` if invoked on a layout\n * that does not return its value as an Object. Objects are\n * returned for things that are a {@link Structure}, which includes\n * {@link VariantLayout|variant layouts} if they are structures, and\n * excludes {@link Union}s. If you want this feature for a union\n * you must use {@link Union.getVariant|getVariant} to select the\n * desired layout.\n *\n * @param {Array} values - an array of values that correspond to the\n * default order for properties. As with {@link Layout#decode|decode}\n * layout elements that have no property name are skipped when\n * iterating over the array values. Only the top-level properties are\n * assigned; arguments are not assigned to properties of contained\n * layouts. Any unused values are ignored.\n *\n * @return {(Object|undefined)}\n */\n Layout.prototype.fromArray = function (values) {\n return undefined;\n };\n return Layout;\n}());\nexports.Layout = Layout;\n/* Provide text that carries a name (such as for a function that will\n * be throwing an error) annotated with the property of a given layout\n * (such as one for which the value was unacceptable).\n *\n * @ignore */\nfunction nameWithProperty(name, lo) {\n if (lo.property) {\n return name + '[' + lo.property + ']';\n }\n return name;\n}\nexports.nameWithProperty = nameWithProperty;\n/**\n * Augment a class so that instances can be encoded/decoded using a\n * given layout.\n *\n * Calling this function couples `Class` with `layout` in several ways:\n *\n * * `Class.layout_` becomes a static member property equal to `layout`;\n * * `layout.boundConstructor_` becomes a static member property equal\n * to `Class`;\n * * The {@link Layout#makeDestinationObject|makeDestinationObject()}\n * property of `layout` is set to a function that returns a `new\n * Class()`;\n * * `Class.decode(b, offset)` becomes a static member function that\n * delegates to {@link Layout#decode|layout.decode}. The\n * synthesized function may be captured and extended.\n * * `Class.prototype.encode(b, offset)` provides an instance member\n * function that delegates to {@link Layout#encode|layout.encode}\n * with `src` set to `this`. The synthesized function may be\n * captured and extended, but when the extension is invoked `this`\n * must be explicitly bound to the instance.\n *\n * @param {class} Class - a JavaScript class with a nullary\n * constructor.\n *\n * @param {Layout} layout - the {@link Layout} instance used to encode\n * instances of `Class`.\n */\nfunction bindConstructorLayout(Class, layout) {\n if ('function' !== typeof Class) {\n throw new TypeError('Class must be constructor');\n }\n if (Object.prototype.hasOwnProperty.call(Class, 'layout_')) {\n throw new Error('Class is already bound to a layout');\n }\n if (!(layout && (layout instanceof Layout))) {\n throw new TypeError('layout must be a Layout');\n }\n if (Object.prototype.hasOwnProperty.call(layout, 'boundConstructor_')) {\n throw new Error('layout is already bound to a constructor');\n }\n Class.layout_ = layout;\n layout.boundConstructor_ = Class;\n layout.makeDestinationObject = (function () { return new Class(); });\n Object.defineProperty(Class.prototype, 'encode', {\n value: function (b, offset) {\n return layout.encode(this, b, offset);\n },\n writable: true\n });\n Object.defineProperty(Class, 'decode', {\n value: function (b, offset) {\n return layout.decode(b, offset);\n },\n writable: true\n });\n}\nexports.bindConstructorLayout = bindConstructorLayout;\n/**\n * An object that behaves like a layout but does not consume space\n * within its containing layout.\n *\n * This is primarily used to obtain metadata about a member, such as a\n * {@link OffsetLayout} that can provide data about a {@link\n * Layout#getSpan|value-specific span}.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support {@link\n * ExternalLayout#isCount|isCount} or other {@link Layout} functions.\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @abstract\n * @augments {Layout}\n */\nvar ExternalLayout = /** @class */ (function (_super) {\n __extends(ExternalLayout, _super);\n function ExternalLayout() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * Return `true` iff the external layout decodes to an unsigned\n * integer layout.\n *\n * In that case it can be used as the source of {@link\n * Sequence#count|Sequence counts}, {@link Blob#length|Blob lengths},\n * or as {@link UnionLayoutDiscriminator#layout|external union\n * discriminators}.\n *\n * @abstract\n */\n ExternalLayout.prototype.isCount = function () {\n throw new Error('ExternalLayout is abstract');\n };\n return ExternalLayout;\n}(Layout));\nexports.ExternalLayout = ExternalLayout;\n/**\n * An {@link ExternalLayout} that determines its {@link\n * Layout#decode|value} based on offset into and length of the buffer\n * on which it is invoked.\n *\n * *Factory*: {@link module:Layout.greedy|greedy}\n *\n * @param {Number} [elementSpan] - initializer for {@link\n * GreedyCount#elementSpan|elementSpan}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {ExternalLayout}\n */\nvar GreedyCount = /** @class */ (function (_super) {\n __extends(GreedyCount, _super);\n function GreedyCount(elementSpan, property) {\n var _this = this;\n if (undefined === elementSpan) {\n elementSpan = 1;\n }\n if ((!Number.isInteger(elementSpan)) || (0 >= elementSpan)) {\n throw new TypeError('elementSpan must be a (positive) integer');\n }\n _this = _super.call(this, -1, property) || this;\n /** The layout for individual elements of the sequence. The value\n * must be a positive integer. If not provided, the value will be\n * 1. */\n _this.elementSpan = elementSpan;\n return _this;\n }\n /** @override */\n GreedyCount.prototype.isCount = function () {\n return true;\n };\n /** @override */\n GreedyCount.prototype.decode = function (b, offset) {\n checkUint8Array(b);\n if (undefined === offset) {\n offset = 0;\n }\n var rem = b.length - offset;\n return Math.floor(rem / this.elementSpan);\n };\n /** @override */\n GreedyCount.prototype.encode = function (src, b, offset) {\n return 0;\n };\n return GreedyCount;\n}(ExternalLayout));\nexports.GreedyCount = GreedyCount;\n/**\n * An {@link ExternalLayout} that supports accessing a {@link Layout}\n * at a fixed offset from the start of another Layout. The offset may\n * be before, within, or after the base layout.\n *\n * *Factory*: {@link module:Layout.offset|offset}\n *\n * @param {Layout} layout - initializer for {@link\n * OffsetLayout#layout|layout}, modulo `property`.\n *\n * @param {Number} [offset] - Initializes {@link\n * OffsetLayout#offset|offset}. Defaults to zero.\n *\n * @param {string} [property] - Optional new property name for a\n * {@link Layout#replicate| replica} of `layout` to be used as {@link\n * OffsetLayout#layout|layout}. If not provided the `layout` is used\n * unchanged.\n *\n * @augments {Layout}\n */\nvar OffsetLayout = /** @class */ (function (_super) {\n __extends(OffsetLayout, _super);\n function OffsetLayout(layout, offset, property) {\n var _this = this;\n if (!(layout instanceof Layout)) {\n throw new TypeError('layout must be a Layout');\n }\n if (undefined === offset) {\n offset = 0;\n }\n else if (!Number.isInteger(offset)) {\n throw new TypeError('offset must be integer or undefined');\n }\n _this = _super.call(this, layout.span, property || layout.property) || this;\n /** The subordinated layout. */\n _this.layout = layout;\n /** The location of {@link OffsetLayout#layout} relative to the\n * start of another layout.\n *\n * The value may be positive or negative, but an error will thrown\n * if at the point of use it goes outside the span of the Uint8Array\n * being accessed. */\n _this.offset = offset;\n return _this;\n }\n /** @override */\n OffsetLayout.prototype.isCount = function () {\n return ((this.layout instanceof UInt)\n || (this.layout instanceof UIntBE));\n };\n /** @override */\n OffsetLayout.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return this.layout.decode(b, offset + this.offset);\n };\n /** @override */\n OffsetLayout.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return this.layout.encode(src, b, offset + this.offset);\n };\n return OffsetLayout;\n}(ExternalLayout));\nexports.OffsetLayout = OffsetLayout;\n/**\n * Represent an unsigned integer in little-endian format.\n *\n * *Factory*: {@link module:Layout.u8|u8}, {@link\n * module:Layout.u16|u16}, {@link module:Layout.u24|u24}, {@link\n * module:Layout.u32|u32}, {@link module:Layout.u40|u40}, {@link\n * module:Layout.u48|u48}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar UInt = /** @class */ (function (_super) {\n __extends(UInt, _super);\n function UInt(span, property) {\n var _this = _super.call(this, span, property) || this;\n if (6 < _this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n return _this;\n }\n /** @override */\n UInt.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readUIntLE(offset, this.span);\n };\n /** @override */\n UInt.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeUIntLE(src, offset, this.span);\n return this.span;\n };\n return UInt;\n}(Layout));\nexports.UInt = UInt;\n/**\n * Represent an unsigned integer in big-endian format.\n *\n * *Factory*: {@link module:Layout.u8be|u8be}, {@link\n * module:Layout.u16be|u16be}, {@link module:Layout.u24be|u24be},\n * {@link module:Layout.u32be|u32be}, {@link\n * module:Layout.u40be|u40be}, {@link module:Layout.u48be|u48be}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar UIntBE = /** @class */ (function (_super) {\n __extends(UIntBE, _super);\n function UIntBE(span, property) {\n var _this = _super.call(this, span, property) || this;\n if (6 < _this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n return _this;\n }\n /** @override */\n UIntBE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readUIntBE(offset, this.span);\n };\n /** @override */\n UIntBE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeUIntBE(src, offset, this.span);\n return this.span;\n };\n return UIntBE;\n}(Layout));\nexports.UIntBE = UIntBE;\n/**\n * Represent a signed integer in little-endian format.\n *\n * *Factory*: {@link module:Layout.s8|s8}, {@link\n * module:Layout.s16|s16}, {@link module:Layout.s24|s24}, {@link\n * module:Layout.s32|s32}, {@link module:Layout.s40|s40}, {@link\n * module:Layout.s48|s48}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Int = /** @class */ (function (_super) {\n __extends(Int, _super);\n function Int(span, property) {\n var _this = _super.call(this, span, property) || this;\n if (6 < _this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n return _this;\n }\n /** @override */\n Int.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readIntLE(offset, this.span);\n };\n /** @override */\n Int.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeIntLE(src, offset, this.span);\n return this.span;\n };\n return Int;\n}(Layout));\nexports.Int = Int;\n/**\n * Represent a signed integer in big-endian format.\n *\n * *Factory*: {@link module:Layout.s8be|s8be}, {@link\n * module:Layout.s16be|s16be}, {@link module:Layout.s24be|s24be},\n * {@link module:Layout.s32be|s32be}, {@link\n * module:Layout.s40be|s40be}, {@link module:Layout.s48be|s48be}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar IntBE = /** @class */ (function (_super) {\n __extends(IntBE, _super);\n function IntBE(span, property) {\n var _this = _super.call(this, span, property) || this;\n if (6 < _this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n return _this;\n }\n /** @override */\n IntBE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readIntBE(offset, this.span);\n };\n /** @override */\n IntBE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeIntBE(src, offset, this.span);\n return this.span;\n };\n return IntBE;\n}(Layout));\nexports.IntBE = IntBE;\nvar V2E32 = Math.pow(2, 32);\n/* True modulus high and low 32-bit words, where low word is always\n * non-negative. */\nfunction divmodInt64(src) {\n var hi32 = Math.floor(src / V2E32);\n var lo32 = src - (hi32 * V2E32);\n return { hi32: hi32, lo32: lo32 };\n}\n/* Reconstruct Number from quotient and non-negative remainder */\nfunction roundedInt64(hi32, lo32) {\n return hi32 * V2E32 + lo32;\n}\n/**\n * Represent an unsigned 64-bit integer in little-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.nu64|nu64}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nvar NearUInt64 = /** @class */ (function (_super) {\n __extends(NearUInt64, _super);\n function NearUInt64(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n NearUInt64.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var buffer = uint8ArrayToBuffer(b);\n var lo32 = buffer.readUInt32LE(offset);\n var hi32 = buffer.readUInt32LE(offset + 4);\n return roundedInt64(hi32, lo32);\n };\n /** @override */\n NearUInt64.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var split = divmodInt64(src);\n var buffer = uint8ArrayToBuffer(b);\n buffer.writeUInt32LE(split.lo32, offset);\n buffer.writeUInt32LE(split.hi32, offset + 4);\n return 8;\n };\n return NearUInt64;\n}(Layout));\nexports.NearUInt64 = NearUInt64;\n/**\n * Represent an unsigned 64-bit integer in big-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.nu64be|nu64be}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nvar NearUInt64BE = /** @class */ (function (_super) {\n __extends(NearUInt64BE, _super);\n function NearUInt64BE(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n NearUInt64BE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var buffer = uint8ArrayToBuffer(b);\n var hi32 = buffer.readUInt32BE(offset);\n var lo32 = buffer.readUInt32BE(offset + 4);\n return roundedInt64(hi32, lo32);\n };\n /** @override */\n NearUInt64BE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var split = divmodInt64(src);\n var buffer = uint8ArrayToBuffer(b);\n buffer.writeUInt32BE(split.hi32, offset);\n buffer.writeUInt32BE(split.lo32, offset + 4);\n return 8;\n };\n return NearUInt64BE;\n}(Layout));\nexports.NearUInt64BE = NearUInt64BE;\n/**\n * Represent a signed 64-bit integer in little-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.ns64|ns64}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nvar NearInt64 = /** @class */ (function (_super) {\n __extends(NearInt64, _super);\n function NearInt64(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n NearInt64.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var buffer = uint8ArrayToBuffer(b);\n var lo32 = buffer.readUInt32LE(offset);\n var hi32 = buffer.readInt32LE(offset + 4);\n return roundedInt64(hi32, lo32);\n };\n /** @override */\n NearInt64.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var split = divmodInt64(src);\n var buffer = uint8ArrayToBuffer(b);\n buffer.writeUInt32LE(split.lo32, offset);\n buffer.writeInt32LE(split.hi32, offset + 4);\n return 8;\n };\n return NearInt64;\n}(Layout));\nexports.NearInt64 = NearInt64;\n/**\n * Represent a signed 64-bit integer in big-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.ns64be|ns64be}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nvar NearInt64BE = /** @class */ (function (_super) {\n __extends(NearInt64BE, _super);\n function NearInt64BE(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n NearInt64BE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var buffer = uint8ArrayToBuffer(b);\n var hi32 = buffer.readInt32BE(offset);\n var lo32 = buffer.readUInt32BE(offset + 4);\n return roundedInt64(hi32, lo32);\n };\n /** @override */\n NearInt64BE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var split = divmodInt64(src);\n var buffer = uint8ArrayToBuffer(b);\n buffer.writeInt32BE(split.hi32, offset);\n buffer.writeUInt32BE(split.lo32, offset + 4);\n return 8;\n };\n return NearInt64BE;\n}(Layout));\nexports.NearInt64BE = NearInt64BE;\n/**\n * Represent a 32-bit floating point number in little-endian format.\n *\n * *Factory*: {@link module:Layout.f32|f32}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Float = /** @class */ (function (_super) {\n __extends(Float, _super);\n function Float(property) {\n return _super.call(this, 4, property) || this;\n }\n /** @override */\n Float.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readFloatLE(offset);\n };\n /** @override */\n Float.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeFloatLE(src, offset);\n return 4;\n };\n return Float;\n}(Layout));\nexports.Float = Float;\n/**\n * Represent a 32-bit floating point number in big-endian format.\n *\n * *Factory*: {@link module:Layout.f32be|f32be}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar FloatBE = /** @class */ (function (_super) {\n __extends(FloatBE, _super);\n function FloatBE(property) {\n return _super.call(this, 4, property) || this;\n }\n /** @override */\n FloatBE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readFloatBE(offset);\n };\n /** @override */\n FloatBE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeFloatBE(src, offset);\n return 4;\n };\n return FloatBE;\n}(Layout));\nexports.FloatBE = FloatBE;\n/**\n * Represent a 64-bit floating point number in little-endian format.\n *\n * *Factory*: {@link module:Layout.f64|f64}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Double = /** @class */ (function (_super) {\n __extends(Double, _super);\n function Double(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n Double.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readDoubleLE(offset);\n };\n /** @override */\n Double.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeDoubleLE(src, offset);\n return 8;\n };\n return Double;\n}(Layout));\nexports.Double = Double;\n/**\n * Represent a 64-bit floating point number in big-endian format.\n *\n * *Factory*: {@link module:Layout.f64be|f64be}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar DoubleBE = /** @class */ (function (_super) {\n __extends(DoubleBE, _super);\n function DoubleBE(property) {\n return _super.call(this, 8, property) || this;\n }\n /** @override */\n DoubleBE.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return uint8ArrayToBuffer(b).readDoubleBE(offset);\n };\n /** @override */\n DoubleBE.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n uint8ArrayToBuffer(b).writeDoubleBE(src, offset);\n return 8;\n };\n return DoubleBE;\n}(Layout));\nexports.DoubleBE = DoubleBE;\n/**\n * Represent a contiguous sequence of a specific layout as an Array.\n *\n * *Factory*: {@link module:Layout.seq|seq}\n *\n * @param {Layout} elementLayout - initializer for {@link\n * Sequence#elementLayout|elementLayout}.\n *\n * @param {(Number|ExternalLayout)} count - initializer for {@link\n * Sequence#count|count}. The parameter must be either a positive\n * integer or an instance of {@link ExternalLayout}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Sequence = /** @class */ (function (_super) {\n __extends(Sequence, _super);\n function Sequence(elementLayout, count, property) {\n var _this = this;\n if (!(elementLayout instanceof Layout)) {\n throw new TypeError('elementLayout must be a Layout');\n }\n if (!(((count instanceof ExternalLayout) && count.isCount())\n || (Number.isInteger(count) && (0 <= count)))) {\n throw new TypeError('count must be non-negative integer '\n + 'or an unsigned integer ExternalLayout');\n }\n var span = -1;\n if ((!(count instanceof ExternalLayout))\n && (0 < elementLayout.span)) {\n span = count * elementLayout.span;\n }\n _this = _super.call(this, span, property) || this;\n /** The layout for individual elements of the sequence. */\n _this.elementLayout = elementLayout;\n /** The number of elements in the sequence.\n *\n * This will be either a non-negative integer or an instance of\n * {@link ExternalLayout} for which {@link\n * ExternalLayout#isCount|isCount()} is `true`. */\n _this.count = count;\n return _this;\n }\n /** @override */\n Sequence.prototype.getSpan = function (b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n var span = 0;\n var count = this.count;\n if (count instanceof ExternalLayout) {\n count = count.decode(b, offset);\n }\n if (0 < this.elementLayout.span) {\n span = count * this.elementLayout.span;\n }\n else {\n var idx = 0;\n while (idx < count) {\n span += this.elementLayout.getSpan(b, offset + span);\n ++idx;\n }\n }\n return span;\n };\n /** @override */\n Sequence.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var rv = [];\n var i = 0;\n var count = this.count;\n if (count instanceof ExternalLayout) {\n count = count.decode(b, offset);\n }\n while (i < count) {\n rv.push(this.elementLayout.decode(b, offset));\n offset += this.elementLayout.getSpan(b, offset);\n i += 1;\n }\n return rv;\n };\n /** Implement {@link Layout#encode|encode} for {@link Sequence}.\n *\n * **NOTE** If `src` is shorter than {@link Sequence#count|count} then\n * the unused space in the buffer is left unchanged. If `src` is\n * longer than {@link Sequence#count|count} the unneeded elements are\n * ignored.\n *\n * **NOTE** If {@link Layout#count|count} is an instance of {@link\n * ExternalLayout} then the length of `src` will be encoded as the\n * count after `src` is encoded. */\n Sequence.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var elo = this.elementLayout;\n var span = src.reduce(function (span, v) {\n return span + elo.encode(v, b, offset + span);\n }, 0);\n if (this.count instanceof ExternalLayout) {\n this.count.encode(src.length, b, offset);\n }\n return span;\n };\n return Sequence;\n}(Layout));\nexports.Sequence = Sequence;\n/**\n * Represent a contiguous sequence of arbitrary layout elements as an\n * Object.\n *\n * *Factory*: {@link module:Layout.struct|struct}\n *\n * **NOTE** The {@link Layout#span|span} of the structure is variable\n * if any layout in {@link Structure#fields|fields} has a variable\n * span. When {@link Layout#encode|encoding} we must have a value for\n * all variable-length fields, or we wouldn't be able to figure out\n * how much space to use for storage. We can only identify the value\n * for a field when it has a {@link Layout#property|property}. As\n * such, although a structure may contain both unnamed fields and\n * variable-length fields, it cannot contain an unnamed\n * variable-length field.\n *\n * @param {Layout[]} fields - initializer for {@link\n * Structure#fields|fields}. An error is raised if this contains a\n * variable-length field for which a {@link Layout#property|property}\n * is not defined.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @param {Boolean} [decodePrefixes] - initializer for {@link\n * Structure#decodePrefixes|property}.\n *\n * @throws {Error} - if `fields` contains an unnamed variable-length\n * layout.\n *\n * @augments {Layout}\n */\nvar Structure = /** @class */ (function (_super) {\n __extends(Structure, _super);\n function Structure(fields, property, decodePrefixes) {\n var _this = this;\n if (!(Array.isArray(fields)\n && fields.reduce(function (acc, v) { return acc && (v instanceof Layout); }, true))) {\n throw new TypeError('fields must be array of Layout instances');\n }\n if (('boolean' === typeof property)\n && (undefined === decodePrefixes)) {\n decodePrefixes = property;\n property = undefined;\n }\n /* Verify absence of unnamed variable-length fields. */\n for (var _i = 0, fields_1 = fields; _i < fields_1.length; _i++) {\n var fd = fields_1[_i];\n if ((0 > fd.span)\n && (undefined === fd.property)) {\n throw new Error('fields cannot contain unnamed variable-length layout');\n }\n }\n var span = -1;\n try {\n span = fields.reduce(function (span, fd) { return span + fd.getSpan(); }, 0);\n }\n catch (e) {\n // ignore error\n }\n _this = _super.call(this, span, property) || this;\n /** The sequence of {@link Layout} values that comprise the\n * structure.\n *\n * The individual elements need not be the same type, and may be\n * either scalar or aggregate layouts. If a member layout leaves\n * its {@link Layout#property|property} undefined the\n * corresponding region of the buffer associated with the element\n * will not be mutated.\n *\n * @type {Layout[]} */\n _this.fields = fields;\n /** Control behavior of {@link Layout#decode|decode()} given short\n * buffers.\n *\n * In some situations a structure many be extended with additional\n * fields over time, with older installations providing only a\n * prefix of the full structure. If this property is `true`\n * decoding will accept those buffers and leave subsequent fields\n * undefined, as long as the buffer ends at a field boundary.\n * Defaults to `false`. */\n _this.decodePrefixes = !!decodePrefixes;\n return _this;\n }\n /** @override */\n Structure.prototype.getSpan = function (b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n var span = 0;\n try {\n span = this.fields.reduce(function (span, fd) {\n var fsp = fd.getSpan(b, offset);\n offset += fsp;\n return span + fsp;\n }, 0);\n }\n catch (e) {\n throw new RangeError('indeterminate span');\n }\n return span;\n };\n /** @override */\n Structure.prototype.decode = function (b, offset) {\n checkUint8Array(b);\n if (undefined === offset) {\n offset = 0;\n }\n var dest = this.makeDestinationObject();\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (undefined !== fd.property) {\n dest[fd.property] = fd.decode(b, offset);\n }\n offset += fd.getSpan(b, offset);\n if (this.decodePrefixes\n && (b.length === offset)) {\n break;\n }\n }\n return dest;\n };\n /** Implement {@link Layout#encode|encode} for {@link Structure}.\n *\n * If `src` is missing a property for a member with a defined {@link\n * Layout#property|property} the corresponding region of the buffer is\n * left unmodified. */\n Structure.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var firstOffset = offset;\n var lastOffset = 0;\n var lastWrote = 0;\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n var span = fd.span;\n lastWrote = (0 < span) ? span : 0;\n if (undefined !== fd.property) {\n var fv = src[fd.property];\n if (undefined !== fv) {\n lastWrote = fd.encode(fv, b, offset);\n if (0 > span) {\n /* Read the as-encoded span, which is not necessarily the\n * same as what we wrote. */\n span = fd.getSpan(b, offset);\n }\n }\n }\n lastOffset = offset;\n offset += span;\n }\n /* Use (lastOffset + lastWrote) instead of offset because the last\n * item may have had a dynamic length and we don't want to include\n * the padding between it and the end of the space reserved for\n * it. */\n return (lastOffset + lastWrote) - firstOffset;\n };\n /** @override */\n Structure.prototype.fromArray = function (values) {\n var dest = this.makeDestinationObject();\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if ((undefined !== fd.property)\n && (0 < values.length)) {\n dest[fd.property] = values.shift();\n }\n }\n return dest;\n };\n /**\n * Get access to the layout of a given property.\n *\n * @param {String} property - the structure member of interest.\n *\n * @return {Layout} - the layout associated with `property`, or\n * undefined if there is no such property.\n */\n Structure.prototype.layoutFor = function (property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (fd.property === property) {\n return fd;\n }\n }\n return undefined;\n };\n /**\n * Get the offset of a structure member.\n *\n * @param {String} property - the structure member of interest.\n *\n * @return {Number} - the offset in bytes to the start of `property`\n * within the structure, or undefined if `property` is not a field\n * within the structure. If the property is a member but follows a\n * variable-length structure member a negative number will be\n * returned.\n */\n Structure.prototype.offsetOf = function (property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n var offset = 0;\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (fd.property === property) {\n return offset;\n }\n if (0 > fd.span) {\n offset = -1;\n }\n else if (0 <= offset) {\n offset += fd.span;\n }\n }\n return undefined;\n };\n return Structure;\n}(Layout));\nexports.Structure = Structure;\n/**\n * An object that can provide a {@link\n * Union#discriminator|discriminator} API for {@link Union}.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support the {@link\n * UnionDiscriminator#encode|encode} or {@link\n * UnionDiscriminator#decode|decode} functions.\n *\n * @param {string} [property] - Default for {@link\n * UnionDiscriminator#property|property}.\n *\n * @abstract\n */\nvar UnionDiscriminator = /** @class */ (function () {\n function UnionDiscriminator(property) {\n /** The {@link Layout#property|property} to be used when the\n * discriminator is referenced in isolation (generally when {@link\n * Union#decode|Union decode} cannot delegate to a specific\n * variant). */\n this.property = property;\n }\n /** Analog to {@link Layout#decode|Layout decode} for union discriminators.\n *\n * The implementation of this method need not reference the buffer if\n * variant information is available through other means. */\n UnionDiscriminator.prototype.decode = function (b, offset) {\n throw new Error('UnionDiscriminator is abstract');\n };\n /** Analog to {@link Layout#decode|Layout encode} for union discriminators.\n *\n * The implementation of this method need not store the value if\n * variant information is maintained through other means. */\n UnionDiscriminator.prototype.encode = function (src, b, offset) {\n throw new Error('UnionDiscriminator is abstract');\n };\n return UnionDiscriminator;\n}());\nexports.UnionDiscriminator = UnionDiscriminator;\n/**\n * An object that can provide a {@link\n * UnionDiscriminator|discriminator API} for {@link Union} using an\n * unsigned integral {@link Layout} instance located either inside or\n * outside the union.\n *\n * @param {ExternalLayout} layout - initializes {@link\n * UnionLayoutDiscriminator#layout|layout}. Must satisfy {@link\n * ExternalLayout#isCount|isCount()}.\n *\n * @param {string} [property] - Default for {@link\n * UnionDiscriminator#property|property}, superseding the property\n * from `layout`, but defaulting to `variant` if neither `property`\n * nor layout provide a property name.\n *\n * @augments {UnionDiscriminator}\n */\nvar UnionLayoutDiscriminator = /** @class */ (function (_super) {\n __extends(UnionLayoutDiscriminator, _super);\n function UnionLayoutDiscriminator(layout, property) {\n var _this = this;\n if (!((layout instanceof ExternalLayout)\n && layout.isCount())) {\n throw new TypeError('layout must be an unsigned integer ExternalLayout');\n }\n _this = _super.call(this, property || layout.property || 'variant') || this;\n /** The {@link ExternalLayout} used to access the discriminator\n * value. */\n _this.layout = layout;\n return _this;\n }\n /** Delegate decoding to {@link UnionLayoutDiscriminator#layout|layout}. */\n UnionLayoutDiscriminator.prototype.decode = function (b, offset) {\n return this.layout.decode(b, offset);\n };\n /** Delegate encoding to {@link UnionLayoutDiscriminator#layout|layout}. */\n UnionLayoutDiscriminator.prototype.encode = function (src, b, offset) {\n return this.layout.encode(src, b, offset);\n };\n return UnionLayoutDiscriminator;\n}(UnionDiscriminator));\nexports.UnionLayoutDiscriminator = UnionLayoutDiscriminator;\n/**\n * Represent any number of span-compatible layouts.\n *\n * *Factory*: {@link module:Layout.union|union}\n *\n * If the union has a {@link Union#defaultLayout|default layout} that\n * layout must have a non-negative {@link Layout#span|span}. The span\n * of a fixed-span union includes its {@link\n * Union#discriminator|discriminator} if the variant is a {@link\n * Union#usesPrefixDiscriminator|prefix of the union}, plus the span\n * of its {@link Union#defaultLayout|default layout}.\n *\n * If the union does not have a default layout then the encoded span\n * of the union depends on the encoded span of its variant (which may\n * be fixed or variable).\n *\n * {@link VariantLayout#layout|Variant layout}s are added through\n * {@link Union#addVariant|addVariant}. If the union has a default\n * layout, the span of the {@link VariantLayout#layout|layout\n * contained by the variant} must not exceed the span of the {@link\n * Union#defaultLayout|default layout} (minus the span of a {@link\n * Union#usesPrefixDiscriminator|prefix disriminator}, if used). The\n * span of the variant will equal the span of the union itself.\n *\n * The variant for a buffer can only be identified from the {@link\n * Union#discriminator|discriminator} {@link\n * UnionDiscriminator#property|property} (in the case of the {@link\n * Union#defaultLayout|default layout}), or by using {@link\n * Union#getVariant|getVariant} and examining the resulting {@link\n * VariantLayout} instance.\n *\n * A variant compatible with a JavaScript object can be identified\n * using {@link Union#getSourceVariant|getSourceVariant}.\n *\n * @param {(UnionDiscriminator|ExternalLayout|Layout)} discr - How to\n * identify the layout used to interpret the union contents. The\n * parameter must be an instance of {@link UnionDiscriminator}, an\n * {@link ExternalLayout} that satisfies {@link\n * ExternalLayout#isCount|isCount()}, or {@link UInt} (or {@link\n * UIntBE}). When a non-external layout element is passed the layout\n * appears at the start of the union. In all cases the (synthesized)\n * {@link UnionDiscriminator} instance is recorded as {@link\n * Union#discriminator|discriminator}.\n *\n * @param {(Layout|null)} defaultLayout - initializer for {@link\n * Union#defaultLayout|defaultLayout}. If absent defaults to `null`.\n * If `null` there is no default layout: the union has data-dependent\n * length and attempts to decode or encode unrecognized variants will\n * throw an exception. A {@link Layout} instance must have a\n * non-negative {@link Layout#span|span}, and if it lacks a {@link\n * Layout#property|property} the {@link\n * Union#defaultLayout|defaultLayout} will be a {@link\n * Layout#replicate|replica} with property `content`.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Union = /** @class */ (function (_super) {\n __extends(Union, _super);\n function Union(discr, defaultLayout, property) {\n var _this = this;\n var upv = ((discr instanceof UInt)\n || (discr instanceof UIntBE));\n var discriminator;\n if (upv) {\n discriminator = new UnionLayoutDiscriminator(new OffsetLayout(discr));\n }\n else if ((discr instanceof ExternalLayout)\n && discr.isCount()) {\n discriminator = new UnionLayoutDiscriminator(discr);\n }\n else if (!(discr instanceof UnionDiscriminator)) {\n throw new TypeError('discr must be a UnionDiscriminator '\n + 'or an unsigned integer layout');\n }\n else {\n discriminator = discr;\n }\n if (undefined === defaultLayout) {\n defaultLayout = null;\n }\n if (!((null === defaultLayout)\n || (defaultLayout instanceof Layout))) {\n throw new TypeError('defaultLayout must be null or a Layout');\n }\n if (null !== defaultLayout) {\n if (0 > defaultLayout.span) {\n throw new Error('defaultLayout must have constant span');\n }\n if (undefined === defaultLayout.property) {\n defaultLayout = defaultLayout.replicate('content');\n }\n }\n /* The union span can be estimated only if there's a default\n * layout. The union spans its default layout, plus any prefix\n * variant layout. By construction both layouts, if present, have\n * non-negative span. */\n var span = -1;\n if (defaultLayout) {\n span = defaultLayout.span;\n if ((0 <= span) && upv) {\n span += discriminator.layout.span;\n }\n }\n _this = _super.call(this, span, property) || this;\n /** The interface for the discriminator value in isolation.\n *\n * This a {@link UnionDiscriminator} either passed to the\n * constructor or synthesized from the `discr` constructor\n * argument. {@link\n * Union#usesPrefixDiscriminator|usesPrefixDiscriminator} will be\n * `true` iff the `discr` parameter was a non-offset {@link\n * Layout} instance. */\n _this.discriminator = discriminator;\n /** `true` if the {@link Union#discriminator|discriminator} is the\n * first field in the union.\n *\n * If `false` the discriminator is obtained from somewhere\n * else. */\n _this.usesPrefixDiscriminator = upv;\n /** The layout for non-discriminator content when the value of the\n * discriminator is not recognized.\n *\n * This is the value passed to the constructor. It is\n * structurally equivalent to the second component of {@link\n * Union#layout|layout} but may have a different property\n * name. */\n _this.defaultLayout = defaultLayout;\n /** A registry of allowed variants.\n *\n * The keys are unsigned integers which should be compatible with\n * {@link Union.discriminator|discriminator}. The property value\n * is the corresponding {@link VariantLayout} instances assigned\n * to this union by {@link Union#addVariant|addVariant}.\n *\n * **NOTE** The registry remains mutable so that variants can be\n * {@link Union#addVariant|added} at any time. Users should not\n * manipulate the content of this property. */\n _this.registry = {};\n /* Private variable used when invoking getSourceVariant */\n var boundGetSourceVariant = _this.defaultGetSourceVariant.bind(_this);\n /** Function to infer the variant selected by a source object.\n *\n * Defaults to {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant} but may\n * be overridden using {@link\n * Union#configGetSourceVariant|configGetSourceVariant}.\n *\n * @param {Object} src - as with {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant}.\n *\n * @returns {(undefined|VariantLayout)} The default variant\n * (`undefined`) or first registered variant that uses a property\n * available in `src`. */\n _this.getSourceVariant = function (src) {\n return boundGetSourceVariant(src);\n };\n /** Function to override the implementation of {@link\n * Union#getSourceVariant|getSourceVariant}.\n *\n * Use this if the desired variant cannot be identified using the\n * algorithm of {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant}.\n *\n * **NOTE** The provided function will be invoked bound to this\n * Union instance, providing local access to {@link\n * Union#registry|registry}.\n *\n * @param {Function} gsv - a function that follows the API of\n * {@link Union#defaultGetSourceVariant|defaultGetSourceVariant}. */\n _this.configGetSourceVariant = function (gsv) {\n boundGetSourceVariant = gsv.bind(this);\n };\n return _this;\n }\n /** @override */\n Union.prototype.getSpan = function (b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n /* Default layouts always have non-negative span, so we don't have\n * one and we have to recognize the variant which will in turn\n * determine the span. */\n var vlo = this.getVariant(b, offset);\n if (!vlo) {\n throw new Error('unable to determine span for unrecognized variant');\n }\n return vlo.getSpan(b, offset);\n };\n /**\n * Method to infer a registered Union variant compatible with `src`.\n *\n * The first satisfied rule in the following sequence defines the\n * return value:\n * * If `src` has properties matching the Union discriminator and\n * the default layout, `undefined` is returned regardless of the\n * value of the discriminator property (this ensures the default\n * layout will be used);\n * * If `src` has a property matching the Union discriminator, the\n * value of the discriminator identifies a registered variant, and\n * either (a) the variant has no layout, or (b) `src` has the\n * variant's property, then the variant is returned (because the\n * source satisfies the constraints of the variant it identifies);\n * * If `src` does not have a property matching the Union\n * discriminator, but does have a property matching a registered\n * variant, then the variant is returned (because the source\n * matches a variant without an explicit conflict);\n * * An error is thrown (because we either can't identify a variant,\n * or we were explicitly told the variant but can't satisfy it).\n *\n * @param {Object} src - an object presumed to be compatible with\n * the content of the Union.\n *\n * @return {(undefined|VariantLayout)} - as described above.\n *\n * @throws {Error} - if `src` cannot be associated with a default or\n * registered variant.\n */\n Union.prototype.defaultGetSourceVariant = function (src) {\n if (Object.prototype.hasOwnProperty.call(src, this.discriminator.property)) {\n if (this.defaultLayout && this.defaultLayout.property\n && Object.prototype.hasOwnProperty.call(src, this.defaultLayout.property)) {\n return undefined;\n }\n var vlo = this.registry[src[this.discriminator.property]];\n if (vlo\n && ((!vlo.layout)\n || (vlo.property && Object.prototype.hasOwnProperty.call(src, vlo.property)))) {\n return vlo;\n }\n }\n else {\n for (var tag in this.registry) {\n var vlo = this.registry[tag];\n if (vlo.property && Object.prototype.hasOwnProperty.call(src, vlo.property)) {\n return vlo;\n }\n }\n }\n throw new Error('unable to infer src variant');\n };\n /** Implement {@link Layout#decode|decode} for {@link Union}.\n *\n * If the variant is {@link Union#addVariant|registered} the return\n * value is an instance of that variant, with no explicit\n * discriminator. Otherwise the {@link Union#defaultLayout|default\n * layout} is used to decode the content. */\n Union.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var dest;\n var dlo = this.discriminator;\n var discr = dlo.decode(b, offset);\n var clo = this.registry[discr];\n if (undefined === clo) {\n var defaultLayout = this.defaultLayout;\n var contentOffset = 0;\n if (this.usesPrefixDiscriminator) {\n contentOffset = dlo.layout.span;\n }\n dest = this.makeDestinationObject();\n dest[dlo.property] = discr;\n dest[defaultLayout.property] = defaultLayout.decode(b, offset + contentOffset);\n }\n else {\n dest = clo.decode(b, offset);\n }\n return dest;\n };\n /** Implement {@link Layout#encode|encode} for {@link Union}.\n *\n * This API assumes the `src` object is consistent with the union's\n * {@link Union#defaultLayout|default layout}. To encode variants\n * use the appropriate variant-specific {@link VariantLayout#encode}\n * method. */\n Union.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var vlo = this.getSourceVariant(src);\n if (undefined === vlo) {\n var dlo = this.discriminator;\n // this.defaultLayout is not undefined when vlo is undefined\n var clo = this.defaultLayout;\n var contentOffset = 0;\n if (this.usesPrefixDiscriminator) {\n contentOffset = dlo.layout.span;\n }\n dlo.encode(src[dlo.property], b, offset);\n // clo.property is not undefined when vlo is undefined\n return contentOffset + clo.encode(src[clo.property], b, offset + contentOffset);\n }\n return vlo.encode(src, b, offset);\n };\n /** Register a new variant structure within a union. The newly\n * created variant is returned.\n *\n * @param {Number} variant - initializer for {@link\n * VariantLayout#variant|variant}.\n *\n * @param {Layout} layout - initializer for {@link\n * VariantLayout#layout|layout}.\n *\n * @param {String} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {VariantLayout} */\n Union.prototype.addVariant = function (variant, layout, property) {\n var rv = new VariantLayout(this, variant, layout, property);\n this.registry[variant] = rv;\n return rv;\n };\n /**\n * Get the layout associated with a registered variant.\n *\n * If `vb` does not produce a registered variant the function returns\n * `undefined`.\n *\n * @param {(Number|Uint8Array)} vb - either the variant number, or a\n * buffer from which the discriminator is to be read.\n *\n * @param {Number} offset - offset into `vb` for the start of the\n * union. Used only when `vb` is an instance of {Uint8Array}.\n *\n * @return {({VariantLayout}|undefined)}\n */\n Union.prototype.getVariant = function (vb, offset) {\n var variant;\n if (vb instanceof Uint8Array) {\n if (undefined === offset) {\n offset = 0;\n }\n variant = this.discriminator.decode(vb, offset);\n }\n else {\n variant = vb;\n }\n return this.registry[variant];\n };\n return Union;\n}(Layout));\nexports.Union = Union;\n/**\n * Represent a specific variant within a containing union.\n *\n * **NOTE** The {@link Layout#span|span} of the variant may include\n * the span of the {@link Union#discriminator|discriminator} used to\n * identify it, but values read and written using the variant strictly\n * conform to the content of {@link VariantLayout#layout|layout}.\n *\n * **NOTE** User code should not invoke this constructor directly. Use\n * the union {@link Union#addVariant|addVariant} helper method.\n *\n * @param {Union} union - initializer for {@link\n * VariantLayout#union|union}.\n *\n * @param {Number} variant - initializer for {@link\n * VariantLayout#variant|variant}.\n *\n * @param {Layout} [layout] - initializer for {@link\n * VariantLayout#layout|layout}. If absent the variant carries no\n * data.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}. Unlike many other layouts, variant\n * layouts normally include a property name so they can be identified\n * within their containing {@link Union}. The property identifier may\n * be absent only if `layout` is is absent.\n *\n * @augments {Layout}\n */\nvar VariantLayout = /** @class */ (function (_super) {\n __extends(VariantLayout, _super);\n function VariantLayout(union, variant, layout, property) {\n var _this = this;\n if (!(union instanceof Union)) {\n throw new TypeError('union must be a Union');\n }\n if ((!Number.isInteger(variant)) || (0 > variant)) {\n throw new TypeError('variant must be a (non-negative) integer');\n }\n if (('string' === typeof layout)\n && (undefined === property)) {\n property = layout;\n layout = null;\n }\n if (layout) {\n if (!(layout instanceof Layout)) {\n throw new TypeError('layout must be a Layout');\n }\n if ((null !== union.defaultLayout)\n && (0 <= layout.span)\n && (layout.span > union.defaultLayout.span)) {\n throw new Error('variant span exceeds span of containing union');\n }\n if ('string' !== typeof property) {\n throw new TypeError('variant must have a String property');\n }\n }\n var span = union.span;\n if (0 > union.span) {\n span = layout ? layout.span : 0;\n if ((0 <= span) && union.usesPrefixDiscriminator) {\n span += union.discriminator.layout.span;\n }\n }\n _this = _super.call(this, span, property) || this;\n /** The {@link Union} to which this variant belongs. */\n _this.union = union;\n /** The unsigned integral value identifying this variant within\n * the {@link Union#discriminator|discriminator} of the containing\n * union. */\n _this.variant = variant;\n /** The {@link Layout} to be used when reading/writing the\n * non-discriminator part of the {@link\n * VariantLayout#union|union}. If `null` the variant carries no\n * data. */\n _this.layout = layout || null;\n return _this;\n }\n /** @override */\n VariantLayout.prototype.getSpan = function (b, offset) {\n if (0 <= this.span) {\n /* Will be equal to the containing union span if that is not\n * variable. */\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n var contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n /* Span is defined solely by the variant (and prefix discriminator) */\n var span = 0;\n if (this.layout) {\n span = this.layout.getSpan(b, offset + contentOffset);\n }\n return contentOffset + span;\n };\n /** @override */\n VariantLayout.prototype.decode = function (b, offset) {\n var dest = this.makeDestinationObject();\n if (undefined === offset) {\n offset = 0;\n }\n if (this !== this.union.getVariant(b, offset)) {\n throw new Error('variant mismatch');\n }\n var contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n // VariantLayout property is never undefined\n var property = this.property;\n if (this.layout) {\n dest[property] = this.layout.decode(b, offset + contentOffset);\n }\n else if (property) {\n dest[property] = true;\n }\n else if (this.union.usesPrefixDiscriminator) {\n dest[this.union.discriminator.property] = this.variant;\n }\n return dest;\n };\n /** @override */\n VariantLayout.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n // VariantLayout property is never undefined\n var property = this.property;\n if (this.layout\n && (!Object.prototype.hasOwnProperty.call(src, property))) {\n throw new TypeError('variant lacks property ' + property);\n }\n this.union.discriminator.encode(this.variant, b, offset);\n var span = contentOffset;\n if (this.layout) {\n this.layout.encode(src[property], b, offset + contentOffset);\n span += this.layout.getSpan(b, offset + contentOffset);\n if ((0 <= this.union.span)\n && (span > this.union.span)) {\n throw new Error('encoded variant overruns containing union');\n }\n }\n return span;\n };\n /** Delegate {@link Layout#fromArray|fromArray} to {@link\n * VariantLayout#layout|layout}. */\n VariantLayout.prototype.fromArray = function (values) {\n if (this.layout) {\n return this.layout.fromArray(values);\n }\n return undefined;\n };\n return VariantLayout;\n}(Layout));\nexports.VariantLayout = VariantLayout;\n/** JavaScript chose to define bitwise operations as operating on\n * signed 32-bit values in 2's complement form, meaning any integer\n * with bit 31 set is going to look negative. For right shifts that's\n * not a problem, because `>>>` is a logical shift, but for every\n * other bitwise operator we have to compensate for possible negative\n * results. */\nfunction fixBitwiseResult(v) {\n if (0 > v) {\n v += 0x100000000;\n }\n return v;\n}\n/**\n * Contain a sequence of bit fields as an unsigned integer.\n *\n * *Factory*: {@link module:Layout.bits|bits}\n *\n * This is a container element; within it there are {@link BitField}\n * instances that provide the extracted properties. The container\n * simply defines the aggregate representation and its bit ordering.\n * The representation is an object containing properties with numeric\n * or {@link Boolean} values.\n *\n * {@link BitField}s are added with the {@link\n * BitStructure#addField|addField} and {@link\n * BitStructure#addBoolean|addBoolean} methods.\n\n * @param {Layout} word - initializer for {@link\n * BitStructure#word|word}. The parameter must be an instance of\n * {@link UInt} (or {@link UIntBE}) that is no more than 4 bytes wide.\n *\n * @param {bool} [msb] - `true` if the bit numbering starts at the\n * most significant bit of the containing word; `false` (default) if\n * it starts at the least significant bit of the containing word. If\n * the parameter at this position is a string and `property` is\n * `undefined` the value of this argument will instead be used as the\n * value of `property`.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar BitStructure = /** @class */ (function (_super) {\n __extends(BitStructure, _super);\n function BitStructure(word, msb, property) {\n var _this = this;\n if (!((word instanceof UInt)\n || (word instanceof UIntBE))) {\n throw new TypeError('word must be a UInt or UIntBE layout');\n }\n if (('string' === typeof msb)\n && (undefined === property)) {\n property = msb;\n msb = false;\n }\n if (4 < word.span) {\n throw new RangeError('word cannot exceed 32 bits');\n }\n _this = _super.call(this, word.span, property) || this;\n /** The layout used for the packed value. {@link BitField}\n * instances are packed sequentially depending on {@link\n * BitStructure#msb|msb}. */\n _this.word = word;\n /** Whether the bit sequences are packed starting at the most\n * significant bit growing down (`true`), or the least significant\n * bit growing up (`false`).\n *\n * **NOTE** Regardless of this value, the least significant bit of\n * any {@link BitField} value is the least significant bit of the\n * corresponding section of the packed value. */\n _this.msb = !!msb;\n /** The sequence of {@link BitField} layouts that comprise the\n * packed structure.\n *\n * **NOTE** The array remains mutable to allow fields to be {@link\n * BitStructure#addField|added} after construction. Users should\n * not manipulate the content of this property.*/\n _this.fields = [];\n /* Storage for the value. Capture a variable instead of using an\n * instance property because we don't want anything to change the\n * value without going through the mutator. */\n var value = 0;\n _this._packedSetValue = function (v) {\n value = fixBitwiseResult(v);\n return this;\n };\n _this._packedGetValue = function () {\n return value;\n };\n return _this;\n }\n /** @override */\n BitStructure.prototype.decode = function (b, offset) {\n var dest = this.makeDestinationObject();\n if (undefined === offset) {\n offset = 0;\n }\n var value = this.word.decode(b, offset);\n this._packedSetValue(value);\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (undefined !== fd.property) {\n dest[fd.property] = fd.decode(value);\n }\n }\n return dest;\n };\n /** Implement {@link Layout#encode|encode} for {@link BitStructure}.\n *\n * If `src` is missing a property for a member with a defined {@link\n * Layout#property|property} the corresponding region of the packed\n * value is left unmodified. Unused bits are also left unmodified. */\n BitStructure.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var value = this.word.decode(b, offset);\n this._packedSetValue(value);\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (undefined !== fd.property) {\n var fv = src[fd.property];\n if (undefined !== fv) {\n fd.encode(fv);\n }\n }\n }\n return this.word.encode(this._packedGetValue(), b, offset);\n };\n /** Register a new bitfield with a containing bit structure. The\n * resulting bitfield is returned.\n *\n * @param {Number} bits - initializer for {@link BitField#bits|bits}.\n *\n * @param {string} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {BitField} */\n BitStructure.prototype.addField = function (bits, property) {\n var bf = new BitField(this, bits, property);\n this.fields.push(bf);\n return bf;\n };\n /** As with {@link BitStructure#addField|addField} for single-bit\n * fields with `boolean` value representation.\n *\n * @param {string} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {Boolean} */\n BitStructure.prototype.addBoolean = function (property) {\n // This is my Boolean, not the Javascript one.\n // eslint-disable-next-line no-new-wrappers\n var bf = new Boolean(this, property);\n this.fields.push(bf);\n return bf;\n };\n /**\n * Get access to the bit field for a given property.\n *\n * @param {String} property - the bit field of interest.\n *\n * @return {BitField} - the field associated with `property`, or\n * undefined if there is no such property.\n */\n BitStructure.prototype.fieldFor = function (property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n for (var _i = 0, _a = this.fields; _i < _a.length; _i++) {\n var fd = _a[_i];\n if (fd.property === property) {\n return fd;\n }\n }\n return undefined;\n };\n return BitStructure;\n}(Layout));\nexports.BitStructure = BitStructure;\n/**\n * Represent a sequence of bits within a {@link BitStructure}.\n *\n * All bit field values are represented as unsigned integers.\n *\n * **NOTE** User code should not invoke this constructor directly.\n * Use the container {@link BitStructure#addField|addField} helper\n * method.\n *\n * **NOTE** BitField instances are not instances of {@link Layout}\n * since {@link Layout#span|span} measures 8-bit units.\n *\n * @param {BitStructure} container - initializer for {@link\n * BitField#container|container}.\n *\n * @param {Number} bits - initializer for {@link BitField#bits|bits}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n */\nvar BitField = /** @class */ (function () {\n function BitField(container, bits, property) {\n if (!(container instanceof BitStructure)) {\n throw new TypeError('container must be a BitStructure');\n }\n if ((!Number.isInteger(bits)) || (0 >= bits)) {\n throw new TypeError('bits must be positive integer');\n }\n var totalBits = 8 * container.span;\n var usedBits = container.fields.reduce(function (sum, fd) { return sum + fd.bits; }, 0);\n if ((bits + usedBits) > totalBits) {\n throw new Error('bits too long for span remainder ('\n + (totalBits - usedBits) + ' of '\n + totalBits + ' remain)');\n }\n /** The {@link BitStructure} instance to which this bit field\n * belongs. */\n this.container = container;\n /** The span of this value in bits. */\n this.bits = bits;\n /** A mask of {@link BitField#bits|bits} bits isolating value bits\n * that fit within the field.\n *\n * That is, it masks a value that has not yet been shifted into\n * position within its containing packed integer. */\n this.valueMask = (1 << bits) - 1;\n if (32 === bits) { // shifted value out of range\n this.valueMask = 0xFFFFFFFF;\n }\n /** The offset of the value within the containing packed unsigned\n * integer. The least significant bit of the packed value is at\n * offset zero, regardless of bit ordering used. */\n this.start = usedBits;\n if (this.container.msb) {\n this.start = totalBits - usedBits - bits;\n }\n /** A mask of {@link BitField#bits|bits} isolating the field value\n * within the containing packed unsigned integer. */\n this.wordMask = fixBitwiseResult(this.valueMask << this.start);\n /** The property name used when this bitfield is represented in an\n * Object.\n *\n * Intended to be functionally equivalent to {@link\n * Layout#property}.\n *\n * If left undefined the corresponding span of bits will be\n * treated as padding: it will not be mutated by {@link\n * Layout#encode|encode} nor represented as a property in the\n * decoded Object. */\n this.property = property;\n }\n /** Store a value into the corresponding subsequence of the containing\n * bit field. */\n BitField.prototype.decode = function (b, offset) {\n var word = this.container._packedGetValue();\n var wordValue = fixBitwiseResult(word & this.wordMask);\n var value = wordValue >>> this.start;\n return value;\n };\n /** Store a value into the corresponding subsequence of the containing\n * bit field.\n *\n * **NOTE** This is not a specialization of {@link\n * Layout#encode|Layout.encode} and there is no return value. */\n BitField.prototype.encode = function (value) {\n if ((!Number.isInteger(value))\n || (value !== fixBitwiseResult(value & this.valueMask))) {\n throw new TypeError(nameWithProperty('BitField.encode', this)\n + ' value must be integer not exceeding ' + this.valueMask);\n }\n var word = this.container._packedGetValue();\n var wordValue = fixBitwiseResult(value << this.start);\n this.container._packedSetValue(fixBitwiseResult(word & ~this.wordMask)\n | wordValue);\n };\n return BitField;\n}());\nexports.BitField = BitField;\n/**\n * Represent a single bit within a {@link BitStructure} as a\n * JavaScript boolean.\n *\n * **NOTE** User code should not invoke this constructor directly.\n * Use the container {@link BitStructure#addBoolean|addBoolean} helper\n * method.\n *\n * @param {BitStructure} container - initializer for {@link\n * BitField#container|container}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {BitField}\n */\n/* eslint-disable no-extend-native */\nvar Boolean = /** @class */ (function (_super) {\n __extends(Boolean, _super);\n function Boolean(container, property) {\n return _super.call(this, container, 1, property) || this;\n }\n /** Override {@link BitField#decode|decode} for {@link Boolean|Boolean}.\n *\n * @returns {boolean} */\n Boolean.prototype.decode = function (b, offset) {\n return !!BitField.prototype.decode.call(this, b, offset);\n };\n /** @override */\n Boolean.prototype.encode = function (value) {\n if ('boolean' === typeof value) {\n // BitField requires integer values\n value = +value;\n }\n return BitField.prototype.encode.call(this, value);\n };\n return Boolean;\n}(BitField));\nexports.Boolean = Boolean;\n/* eslint-enable no-extend-native */\n/**\n * Contain a fixed-length block of arbitrary data, represented as a\n * Uint8Array.\n *\n * *Factory*: {@link module:Layout.blob|blob}\n *\n * @param {(Number|ExternalLayout)} length - initializes {@link\n * Blob#length|length}.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Blob = /** @class */ (function (_super) {\n __extends(Blob, _super);\n function Blob(length, property) {\n var _this = this;\n if (!(((length instanceof ExternalLayout) && length.isCount())\n || (Number.isInteger(length) && (0 <= length)))) {\n throw new TypeError('length must be positive integer '\n + 'or an unsigned integer ExternalLayout');\n }\n var span = -1;\n if (!(length instanceof ExternalLayout)) {\n span = length;\n }\n _this = _super.call(this, span, property) || this;\n /** The number of bytes in the blob.\n *\n * This may be a non-negative integer, or an instance of {@link\n * ExternalLayout} that satisfies {@link\n * ExternalLayout#isCount|isCount()}. */\n _this.length = length;\n return _this;\n }\n /** @override */\n Blob.prototype.getSpan = function (b, offset) {\n var span = this.span;\n if (0 > span) {\n span = this.length.decode(b, offset);\n }\n return span;\n };\n /** @override */\n Blob.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var span = this.span;\n if (0 > span) {\n span = this.length.decode(b, offset);\n }\n return uint8ArrayToBuffer(b).slice(offset, offset + span);\n };\n /** Implement {@link Layout#encode|encode} for {@link Blob}.\n *\n * **NOTE** If {@link Layout#count|count} is an instance of {@link\n * ExternalLayout} then the length of `src` will be encoded as the\n * count after `src` is encoded. */\n Blob.prototype.encode = function (src, b, offset) {\n var span = this.length;\n if (this.length instanceof ExternalLayout) {\n span = src.length;\n }\n if (!(src instanceof Uint8Array && span === src.length)) {\n throw new TypeError(nameWithProperty('Blob.encode', this)\n + ' requires (length ' + span + ') Uint8Array as src');\n }\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Uint8Array');\n }\n var srcBuffer = uint8ArrayToBuffer(src);\n uint8ArrayToBuffer(b).write(srcBuffer.toString('hex'), offset, span, 'hex');\n if (this.length instanceof ExternalLayout) {\n this.length.encode(span, b, offset);\n }\n return span;\n };\n return Blob;\n}(Layout));\nexports.Blob = Blob;\n/**\n * Contain a `NUL`-terminated UTF8 string.\n *\n * *Factory*: {@link module:Layout.cstr|cstr}\n *\n * **NOTE** Any UTF8 string that incorporates a zero-valued byte will\n * not be correctly decoded by this layout.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar CString = /** @class */ (function (_super) {\n __extends(CString, _super);\n function CString(property) {\n return _super.call(this, -1, property) || this;\n }\n /** @override */\n CString.prototype.getSpan = function (b, offset) {\n checkUint8Array(b);\n if (undefined === offset) {\n offset = 0;\n }\n var idx = offset;\n while ((idx < b.length) && (0 !== b[idx])) {\n idx += 1;\n }\n return 1 + idx - offset;\n };\n /** @override */\n CString.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var span = this.getSpan(b, offset);\n return uint8ArrayToBuffer(b).slice(offset, offset + span - 1).toString('utf-8');\n };\n /** @override */\n CString.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n /* Must force this to a string, lest it be a number and the\n * \"utf8-encoding\" below actually allocate a buffer of length\n * src */\n if ('string' !== typeof src) {\n src = src.toString();\n }\n var srcb = buffer_1.Buffer.from(src, 'utf8');\n var span = srcb.length;\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Buffer');\n }\n var buffer = uint8ArrayToBuffer(b);\n srcb.copy(buffer, offset);\n buffer[offset + span] = 0;\n return span + 1;\n };\n return CString;\n}(Layout));\nexports.CString = CString;\n/**\n * Contain a UTF8 string with implicit length.\n *\n * *Factory*: {@link module:Layout.utf8|utf8}\n *\n * **NOTE** Because the length is implicit in the size of the buffer\n * this layout should be used only in isolation, or in a situation\n * where the length can be expressed by operating on a slice of the\n * containing buffer.\n *\n * @param {Number} [maxSpan] - the maximum length allowed for encoded\n * string content. If not provided there is no bound on the allowed\n * content.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar UTF8 = /** @class */ (function (_super) {\n __extends(UTF8, _super);\n function UTF8(maxSpan, property) {\n var _this = this;\n if (('string' === typeof maxSpan) && (undefined === property)) {\n property = maxSpan;\n maxSpan = undefined;\n }\n if (undefined === maxSpan) {\n maxSpan = -1;\n }\n else if (!Number.isInteger(maxSpan)) {\n throw new TypeError('maxSpan must be an integer');\n }\n _this = _super.call(this, -1, property) || this;\n /** The maximum span of the layout in bytes.\n *\n * Positive values are generally expected. Zero is abnormal.\n * Attempts to encode or decode a value that exceeds this length\n * will throw a `RangeError`.\n *\n * A negative value indicates that there is no bound on the length\n * of the content. */\n _this.maxSpan = maxSpan;\n return _this;\n }\n /** @override */\n UTF8.prototype.getSpan = function (b, offset) {\n checkUint8Array(b);\n if (undefined === offset) {\n offset = 0;\n }\n return b.length - offset;\n };\n /** @override */\n UTF8.prototype.decode = function (b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n var span = this.getSpan(b, offset);\n if ((0 <= this.maxSpan)\n && (this.maxSpan < span)) {\n throw new RangeError('text length exceeds maxSpan');\n }\n return uint8ArrayToBuffer(b).slice(offset, offset + span).toString('utf-8');\n };\n /** @override */\n UTF8.prototype.encode = function (src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n /* Must force this to a string, lest it be a number and the\n * \"utf8-encoding\" below actually allocate a buffer of length\n * src */\n if ('string' !== typeof src) {\n src = src.toString();\n }\n var srcb = buffer_1.Buffer.from(src, 'utf8');\n var span = srcb.length;\n if ((0 <= this.maxSpan)\n && (this.maxSpan < span)) {\n throw new RangeError('text length exceeds maxSpan');\n }\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Buffer');\n }\n srcb.copy(uint8ArrayToBuffer(b), offset);\n return span;\n };\n return UTF8;\n}(Layout));\nexports.UTF8 = UTF8;\n/**\n * Contain a constant value.\n *\n * This layout may be used in cases where a JavaScript value can be\n * inferred without an expression in the binary encoding. An example\n * would be a {@link VariantLayout|variant layout} where the content\n * is implied by the union {@link Union#discriminator|discriminator}.\n *\n * @param {Object|Number|String} value - initializer for {@link\n * Constant#value|value}. If the value is an object (or array) and\n * the application intends the object to remain unchanged regardless\n * of what is done to values decoded by this layout, the value should\n * be frozen prior passing it to this constructor.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nvar Constant = /** @class */ (function (_super) {\n __extends(Constant, _super);\n function Constant(value, property) {\n var _this = _super.call(this, 0, property) || this;\n /** The value produced by this constant when the layout is {@link\n * Constant#decode|decoded}.\n *\n * Any JavaScript value including `null` and `undefined` is\n * permitted.\n *\n * **WARNING** If `value` passed in the constructor was not\n * frozen, it is possible for users of decoded values to change\n * the content of the value. */\n _this.value = value;\n return _this;\n }\n /** @override */\n Constant.prototype.decode = function (b, offset) {\n return this.value;\n };\n /** @override */\n Constant.prototype.encode = function (src, b, offset) {\n /* Constants take no space */\n return 0;\n };\n return Constant;\n}(Layout));\nexports.Constant = Constant;\n/** Factory for {@link GreedyCount}. */\nexports.greedy = (function (elementSpan, property) { return new GreedyCount(elementSpan, property); });\n/** Factory for {@link OffsetLayout}. */\nexports.offset = (function (layout, offset, property) { return new OffsetLayout(layout, offset, property); });\n/** Factory for {@link UInt|unsigned int layouts} spanning one\n * byte. */\nexports.u8 = (function (property) { return new UInt(1, property); });\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning two bytes. */\nexports.u16 = (function (property) { return new UInt(2, property); });\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning three bytes. */\nexports.u24 = (function (property) { return new UInt(3, property); });\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning four bytes. */\nexports.u32 = (function (property) { return new UInt(4, property); });\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning five bytes. */\nexports.u40 = (function (property) { return new UInt(5, property); });\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning six bytes. */\nexports.u48 = (function (property) { return new UInt(6, property); });\n/** Factory for {@link NearUInt64|little-endian unsigned int\n * layouts} interpreted as Numbers. */\nexports.nu64 = (function (property) { return new NearUInt64(property); });\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning two bytes. */\nexports.u16be = (function (property) { return new UIntBE(2, property); });\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning three bytes. */\nexports.u24be = (function (property) { return new UIntBE(3, property); });\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning four bytes. */\nexports.u32be = (function (property) { return new UIntBE(4, property); });\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning five bytes. */\nexports.u40be = (function (property) { return new UIntBE(5, property); });\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning six bytes. */\nexports.u48be = (function (property) { return new UIntBE(6, property); });\n/** Factory for {@link NearUInt64BE|big-endian unsigned int\n * layouts} interpreted as Numbers. */\nexports.nu64be = (function (property) { return new NearUInt64BE(property); });\n/** Factory for {@link Int|signed int layouts} spanning one\n * byte. */\nexports.s8 = (function (property) { return new Int(1, property); });\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning two bytes. */\nexports.s16 = (function (property) { return new Int(2, property); });\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning three bytes. */\nexports.s24 = (function (property) { return new Int(3, property); });\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning four bytes. */\nexports.s32 = (function (property) { return new Int(4, property); });\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning five bytes. */\nexports.s40 = (function (property) { return new Int(5, property); });\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning six bytes. */\nexports.s48 = (function (property) { return new Int(6, property); });\n/** Factory for {@link NearInt64|little-endian signed int layouts}\n * interpreted as Numbers. */\nexports.ns64 = (function (property) { return new NearInt64(property); });\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning two bytes. */\nexports.s16be = (function (property) { return new IntBE(2, property); });\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning three bytes. */\nexports.s24be = (function (property) { return new IntBE(3, property); });\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning four bytes. */\nexports.s32be = (function (property) { return new IntBE(4, property); });\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning five bytes. */\nexports.s40be = (function (property) { return new IntBE(5, property); });\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning six bytes. */\nexports.s48be = (function (property) { return new IntBE(6, property); });\n/** Factory for {@link NearInt64BE|big-endian signed int layouts}\n * interpreted as Numbers. */\nexports.ns64be = (function (property) { return new NearInt64BE(property); });\n/** Factory for {@link Float|little-endian 32-bit floating point} values. */\nexports.f32 = (function (property) { return new Float(property); });\n/** Factory for {@link FloatBE|big-endian 32-bit floating point} values. */\nexports.f32be = (function (property) { return new FloatBE(property); });\n/** Factory for {@link Double|little-endian 64-bit floating point} values. */\nexports.f64 = (function (property) { return new Double(property); });\n/** Factory for {@link DoubleBE|big-endian 64-bit floating point} values. */\nexports.f64be = (function (property) { return new DoubleBE(property); });\n/** Factory for {@link Structure} values. */\nexports.struct = (function (fields, property, decodePrefixes) {\n return new Structure(fields, property, decodePrefixes);\n});\n/** Factory for {@link BitStructure} values. */\nexports.bits = (function (word, msb, property) { return new BitStructure(word, msb, property); });\n/** Factory for {@link Sequence} values. */\nexports.seq = (function (elementLayout, count, property) {\n return new Sequence(elementLayout, count, property);\n});\n/** Factory for {@link Union} values. */\nexports.union = (function (discr, defaultLayout, property) {\n return new Union(discr, defaultLayout, property);\n});\n/** Factory for {@link UnionLayoutDiscriminator} values. */\nexports.unionLayoutDiscriminator = (function (layout, property) { return new UnionLayoutDiscriminator(layout, property); });\n/** Factory for {@link Blob} values. */\nexports.blob = (function (length, property) { return new Blob(length, property); });\n/** Factory for {@link CString} values. */\nexports.cstr = (function (property) { return new CString(property); });\n/** Factory for {@link UTF8} values. */\nexports.utf8 = (function (maxSpan, property) { return new UTF8(maxSpan, property); });\n/** Factory for {@link Constant} values. */\nexports.constant = (function (value, property) { return new Constant(value, property); });\n//# sourceMappingURL=Layout.js.map","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length | 0\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return ''\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (isNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (Buffer.TYPED_ARRAY_SUPPORT &&\n typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset | 0\n if (isFinite(length)) {\n length = length | 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n\n return keys;\n}\n\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n\n return target;\n}","import {Buffer} from 'buffer';\n\nexport const toBuffer = (arr: Buffer | Uint8Array | Array): Buffer => {\n if (Buffer.isBuffer(arr)) {\n return arr;\n } else if (arr instanceof Uint8Array) {\n return Buffer.from(arr.buffer, arr.byteOffset, arr.byteLength);\n } else {\n return Buffer.from(arr);\n }\n};\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n };\n} else {\n // old school shim for old browsers\n module.exports = 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","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","\"use strict\";\nlet _permanentCensorErrors = false;\nlet _censorErrors = false;\nconst LogLevels = { debug: 1, \"default\": 2, info: 2, warning: 3, error: 4, off: 5 };\nlet _logLevel = LogLevels[\"default\"];\nimport { version } from \"./_version\";\nlet _globalLogger = null;\nfunction _checkNormalize() {\n try {\n const missing = [];\n // Make sure all forms of normalization are supported\n [\"NFD\", \"NFC\", \"NFKD\", \"NFKC\"].forEach((form) => {\n try {\n if (\"test\".normalize(form) !== \"test\") {\n throw new Error(\"bad normalize\");\n }\n ;\n }\n catch (error) {\n missing.push(form);\n }\n });\n if (missing.length) {\n throw new Error(\"missing \" + missing.join(\", \"));\n }\n if (String.fromCharCode(0xe9).normalize(\"NFD\") !== String.fromCharCode(0x65, 0x0301)) {\n throw new Error(\"broken implementation\");\n }\n }\n catch (error) {\n return error.message;\n }\n return null;\n}\nconst _normalizeError = _checkNormalize();\nexport var LogLevel;\n(function (LogLevel) {\n LogLevel[\"DEBUG\"] = \"DEBUG\";\n LogLevel[\"INFO\"] = \"INFO\";\n LogLevel[\"WARNING\"] = \"WARNING\";\n LogLevel[\"ERROR\"] = \"ERROR\";\n LogLevel[\"OFF\"] = \"OFF\";\n})(LogLevel || (LogLevel = {}));\nexport var ErrorCode;\n(function (ErrorCode) {\n ///////////////////\n // Generic Errors\n // Unknown Error\n ErrorCode[\"UNKNOWN_ERROR\"] = \"UNKNOWN_ERROR\";\n // Not Implemented\n ErrorCode[\"NOT_IMPLEMENTED\"] = \"NOT_IMPLEMENTED\";\n // Unsupported Operation\n // - operation\n ErrorCode[\"UNSUPPORTED_OPERATION\"] = \"UNSUPPORTED_OPERATION\";\n // Network Error (i.e. Ethereum Network, such as an invalid chain ID)\n // - event (\"noNetwork\" is not re-thrown in provider.ready; otherwise thrown)\n ErrorCode[\"NETWORK_ERROR\"] = \"NETWORK_ERROR\";\n // Some sort of bad response from the server\n ErrorCode[\"SERVER_ERROR\"] = \"SERVER_ERROR\";\n // Timeout\n ErrorCode[\"TIMEOUT\"] = \"TIMEOUT\";\n ///////////////////\n // Operational Errors\n // Buffer Overrun\n ErrorCode[\"BUFFER_OVERRUN\"] = \"BUFFER_OVERRUN\";\n // Numeric Fault\n // - operation: the operation being executed\n // - fault: the reason this faulted\n ErrorCode[\"NUMERIC_FAULT\"] = \"NUMERIC_FAULT\";\n ///////////////////\n // Argument Errors\n // Missing new operator to an object\n // - name: The name of the class\n ErrorCode[\"MISSING_NEW\"] = \"MISSING_NEW\";\n // Invalid argument (e.g. value is incompatible with type) to a function:\n // - argument: The argument name that was invalid\n // - value: The value of the argument\n ErrorCode[\"INVALID_ARGUMENT\"] = \"INVALID_ARGUMENT\";\n // Missing argument to a function:\n // - count: The number of arguments received\n // - expectedCount: The number of arguments expected\n ErrorCode[\"MISSING_ARGUMENT\"] = \"MISSING_ARGUMENT\";\n // Too many arguments\n // - count: The number of arguments received\n // - expectedCount: The number of arguments expected\n ErrorCode[\"UNEXPECTED_ARGUMENT\"] = \"UNEXPECTED_ARGUMENT\";\n ///////////////////\n // Blockchain Errors\n // Call exception\n // - transaction: the transaction\n // - address?: the contract address\n // - args?: The arguments passed into the function\n // - method?: The Solidity method signature\n // - errorSignature?: The EIP848 error signature\n // - errorArgs?: The EIP848 error parameters\n // - reason: The reason (only for EIP848 \"Error(string)\")\n ErrorCode[\"CALL_EXCEPTION\"] = \"CALL_EXCEPTION\";\n // Insufficient funds (< value + gasLimit * gasPrice)\n // - transaction: the transaction attempted\n ErrorCode[\"INSUFFICIENT_FUNDS\"] = \"INSUFFICIENT_FUNDS\";\n // Nonce has already been used\n // - transaction: the transaction attempted\n ErrorCode[\"NONCE_EXPIRED\"] = \"NONCE_EXPIRED\";\n // The replacement fee for the transaction is too low\n // - transaction: the transaction attempted\n ErrorCode[\"REPLACEMENT_UNDERPRICED\"] = \"REPLACEMENT_UNDERPRICED\";\n // The gas limit could not be estimated\n // - transaction: the transaction passed to estimateGas\n ErrorCode[\"UNPREDICTABLE_GAS_LIMIT\"] = \"UNPREDICTABLE_GAS_LIMIT\";\n // The transaction was replaced by one with a higher gas price\n // - reason: \"cancelled\", \"replaced\" or \"repriced\"\n // - cancelled: true if reason == \"cancelled\" or reason == \"replaced\")\n // - hash: original transaction hash\n // - replacement: the full TransactionsResponse for the replacement\n // - receipt: the receipt of the replacement\n ErrorCode[\"TRANSACTION_REPLACED\"] = \"TRANSACTION_REPLACED\";\n})(ErrorCode || (ErrorCode = {}));\n;\nconst HEX = \"0123456789abcdef\";\nexport class Logger {\n constructor(version) {\n Object.defineProperty(this, \"version\", {\n enumerable: true,\n value: version,\n writable: false\n });\n }\n _log(logLevel, args) {\n const level = logLevel.toLowerCase();\n if (LogLevels[level] == null) {\n this.throwArgumentError(\"invalid log level name\", \"logLevel\", logLevel);\n }\n if (_logLevel > LogLevels[level]) {\n return;\n }\n console.log.apply(console, args);\n }\n debug(...args) {\n this._log(Logger.levels.DEBUG, args);\n }\n info(...args) {\n this._log(Logger.levels.INFO, args);\n }\n warn(...args) {\n this._log(Logger.levels.WARNING, args);\n }\n makeError(message, code, params) {\n // Errors are being censored\n if (_censorErrors) {\n return this.makeError(\"censored error\", code, {});\n }\n if (!code) {\n code = Logger.errors.UNKNOWN_ERROR;\n }\n if (!params) {\n params = {};\n }\n const messageDetails = [];\n Object.keys(params).forEach((key) => {\n const value = params[key];\n try {\n if (value instanceof Uint8Array) {\n let hex = \"\";\n for (let i = 0; i < value.length; i++) {\n hex += HEX[value[i] >> 4];\n hex += HEX[value[i] & 0x0f];\n }\n messageDetails.push(key + \"=Uint8Array(0x\" + hex + \")\");\n }\n else {\n messageDetails.push(key + \"=\" + JSON.stringify(value));\n }\n }\n catch (error) {\n messageDetails.push(key + \"=\" + JSON.stringify(params[key].toString()));\n }\n });\n messageDetails.push(`code=${code}`);\n messageDetails.push(`version=${this.version}`);\n const reason = message;\n if (messageDetails.length) {\n message += \" (\" + messageDetails.join(\", \") + \")\";\n }\n // @TODO: Any??\n const error = new Error(message);\n error.reason = reason;\n error.code = code;\n Object.keys(params).forEach(function (key) {\n error[key] = params[key];\n });\n return error;\n }\n throwError(message, code, params) {\n throw this.makeError(message, code, params);\n }\n throwArgumentError(message, name, value) {\n return this.throwError(message, Logger.errors.INVALID_ARGUMENT, {\n argument: name,\n value: value\n });\n }\n assert(condition, message, code, params) {\n if (!!condition) {\n return;\n }\n this.throwError(message, code, params);\n }\n assertArgument(condition, message, name, value) {\n if (!!condition) {\n return;\n }\n this.throwArgumentError(message, name, value);\n }\n checkNormalize(message) {\n if (message == null) {\n message = \"platform missing String.prototype.normalize\";\n }\n if (_normalizeError) {\n this.throwError(\"platform missing String.prototype.normalize\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"String.prototype.normalize\", form: _normalizeError\n });\n }\n }\n checkSafeUint53(value, message) {\n if (typeof (value) !== \"number\") {\n return;\n }\n if (message == null) {\n message = \"value not safe\";\n }\n if (value < 0 || value >= 0x1fffffffffffff) {\n this.throwError(message, Logger.errors.NUMERIC_FAULT, {\n operation: \"checkSafeInteger\",\n fault: \"out-of-safe-range\",\n value: value\n });\n }\n if (value % 1) {\n this.throwError(message, Logger.errors.NUMERIC_FAULT, {\n operation: \"checkSafeInteger\",\n fault: \"non-integer\",\n value: value\n });\n }\n }\n checkArgumentCount(count, expectedCount, message) {\n if (message) {\n message = \": \" + message;\n }\n else {\n message = \"\";\n }\n if (count < expectedCount) {\n this.throwError(\"missing argument\" + message, Logger.errors.MISSING_ARGUMENT, {\n count: count,\n expectedCount: expectedCount\n });\n }\n if (count > expectedCount) {\n this.throwError(\"too many arguments\" + message, Logger.errors.UNEXPECTED_ARGUMENT, {\n count: count,\n expectedCount: expectedCount\n });\n }\n }\n checkNew(target, kind) {\n if (target === Object || target == null) {\n this.throwError(\"missing new\", Logger.errors.MISSING_NEW, { name: kind.name });\n }\n }\n checkAbstract(target, kind) {\n if (target === kind) {\n this.throwError(\"cannot instantiate abstract class \" + JSON.stringify(kind.name) + \" directly; use a sub-class\", Logger.errors.UNSUPPORTED_OPERATION, { name: target.name, operation: \"new\" });\n }\n else if (target === Object || target == null) {\n this.throwError(\"missing new\", Logger.errors.MISSING_NEW, { name: kind.name });\n }\n }\n static globalLogger() {\n if (!_globalLogger) {\n _globalLogger = new Logger(version);\n }\n return _globalLogger;\n }\n static setCensorship(censorship, permanent) {\n if (!censorship && permanent) {\n this.globalLogger().throwError(\"cannot permanently disable censorship\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"setCensorship\"\n });\n }\n if (_permanentCensorErrors) {\n if (!censorship) {\n return;\n }\n this.globalLogger().throwError(\"error censorship permanent\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"setCensorship\"\n });\n }\n _censorErrors = !!censorship;\n _permanentCensorErrors = !!permanent;\n }\n static setLogLevel(logLevel) {\n const level = LogLevels[logLevel.toLowerCase()];\n if (level == null) {\n Logger.globalLogger().warn(\"invalid log level - \" + logLevel);\n return;\n }\n _logLevel = level;\n }\n static from(version) {\n return new Logger(version);\n }\n}\nLogger.errors = ErrorCode;\nLogger.levels = LogLevel;\n//# sourceMappingURL=index.js.map","export const version = \"logger/5.5.0\";\n//# sourceMappingURL=_version.js.map","export const version = \"bytes/5.5.0\";\n//# sourceMappingURL=_version.js.map","\"use strict\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n///////////////////////////////\nfunction isHexable(value) {\n return !!(value.toHexString);\n}\nfunction addSlice(array) {\n if (array.slice) {\n return array;\n }\n array.slice = function () {\n const args = Array.prototype.slice.call(arguments);\n return addSlice(new Uint8Array(Array.prototype.slice.apply(array, args)));\n };\n return array;\n}\nexport function isBytesLike(value) {\n return ((isHexString(value) && !(value.length % 2)) || isBytes(value));\n}\nfunction isInteger(value) {\n return (typeof (value) === \"number\" && value == value && (value % 1) === 0);\n}\nexport function isBytes(value) {\n if (value == null) {\n return false;\n }\n if (value.constructor === Uint8Array) {\n return true;\n }\n if (typeof (value) === \"string\") {\n return false;\n }\n if (!isInteger(value.length) || value.length < 0) {\n return false;\n }\n for (let i = 0; i < value.length; i++) {\n const v = value[i];\n if (!isInteger(v) || v < 0 || v >= 256) {\n return false;\n }\n }\n return true;\n}\nexport function arrayify(value, options) {\n if (!options) {\n options = {};\n }\n if (typeof (value) === \"number\") {\n logger.checkSafeUint53(value, \"invalid arrayify value\");\n const result = [];\n while (value) {\n result.unshift(value & 0xff);\n value = parseInt(String(value / 256));\n }\n if (result.length === 0) {\n result.push(0);\n }\n return addSlice(new Uint8Array(result));\n }\n if (options.allowMissingPrefix && typeof (value) === \"string\" && value.substring(0, 2) !== \"0x\") {\n value = \"0x\" + value;\n }\n if (isHexable(value)) {\n value = value.toHexString();\n }\n if (isHexString(value)) {\n let hex = value.substring(2);\n if (hex.length % 2) {\n if (options.hexPad === \"left\") {\n hex = \"0x0\" + hex.substring(2);\n }\n else if (options.hexPad === \"right\") {\n hex += \"0\";\n }\n else {\n logger.throwArgumentError(\"hex data is odd-length\", \"value\", value);\n }\n }\n const result = [];\n for (let i = 0; i < hex.length; i += 2) {\n result.push(parseInt(hex.substring(i, i + 2), 16));\n }\n return addSlice(new Uint8Array(result));\n }\n if (isBytes(value)) {\n return addSlice(new Uint8Array(value));\n }\n return logger.throwArgumentError(\"invalid arrayify value\", \"value\", value);\n}\nexport function concat(items) {\n const objects = items.map(item => arrayify(item));\n const length = objects.reduce((accum, item) => (accum + item.length), 0);\n const result = new Uint8Array(length);\n objects.reduce((offset, object) => {\n result.set(object, offset);\n return offset + object.length;\n }, 0);\n return addSlice(result);\n}\nexport function stripZeros(value) {\n let result = arrayify(value);\n if (result.length === 0) {\n return result;\n }\n // Find the first non-zero entry\n let start = 0;\n while (start < result.length && result[start] === 0) {\n start++;\n }\n // If we started with zeros, strip them\n if (start) {\n result = result.slice(start);\n }\n return result;\n}\nexport function zeroPad(value, length) {\n value = arrayify(value);\n if (value.length > length) {\n logger.throwArgumentError(\"value out of range\", \"value\", arguments[0]);\n }\n const result = new Uint8Array(length);\n result.set(value, length - value.length);\n return addSlice(result);\n}\nexport function isHexString(value, length) {\n if (typeof (value) !== \"string\" || !value.match(/^0x[0-9A-Fa-f]*$/)) {\n return false;\n }\n if (length && value.length !== 2 + 2 * length) {\n return false;\n }\n return true;\n}\nconst HexCharacters = \"0123456789abcdef\";\nexport function hexlify(value, options) {\n if (!options) {\n options = {};\n }\n if (typeof (value) === \"number\") {\n logger.checkSafeUint53(value, \"invalid hexlify value\");\n let hex = \"\";\n while (value) {\n hex = HexCharacters[value & 0xf] + hex;\n value = Math.floor(value / 16);\n }\n if (hex.length) {\n if (hex.length % 2) {\n hex = \"0\" + hex;\n }\n return \"0x\" + hex;\n }\n return \"0x00\";\n }\n if (typeof (value) === \"bigint\") {\n value = value.toString(16);\n if (value.length % 2) {\n return (\"0x0\" + value);\n }\n return \"0x\" + value;\n }\n if (options.allowMissingPrefix && typeof (value) === \"string\" && value.substring(0, 2) !== \"0x\") {\n value = \"0x\" + value;\n }\n if (isHexable(value)) {\n return value.toHexString();\n }\n if (isHexString(value)) {\n if (value.length % 2) {\n if (options.hexPad === \"left\") {\n value = \"0x0\" + value.substring(2);\n }\n else if (options.hexPad === \"right\") {\n value += \"0\";\n }\n else {\n logger.throwArgumentError(\"hex data is odd-length\", \"value\", value);\n }\n }\n return value.toLowerCase();\n }\n if (isBytes(value)) {\n let result = \"0x\";\n for (let i = 0; i < value.length; i++) {\n let v = value[i];\n result += HexCharacters[(v & 0xf0) >> 4] + HexCharacters[v & 0x0f];\n }\n return result;\n }\n return logger.throwArgumentError(\"invalid hexlify value\", \"value\", value);\n}\n/*\nfunction unoddify(value: BytesLike | Hexable | number): BytesLike | Hexable | number {\n if (typeof(value) === \"string\" && value.length % 2 && value.substring(0, 2) === \"0x\") {\n return \"0x0\" + value.substring(2);\n }\n return value;\n}\n*/\nexport function hexDataLength(data) {\n if (typeof (data) !== \"string\") {\n data = hexlify(data);\n }\n else if (!isHexString(data) || (data.length % 2)) {\n return null;\n }\n return (data.length - 2) / 2;\n}\nexport function hexDataSlice(data, offset, endOffset) {\n if (typeof (data) !== \"string\") {\n data = hexlify(data);\n }\n else if (!isHexString(data) || (data.length % 2)) {\n logger.throwArgumentError(\"invalid hexData\", \"value\", data);\n }\n offset = 2 + 2 * offset;\n if (endOffset != null) {\n return \"0x\" + data.substring(offset, 2 + 2 * endOffset);\n }\n return \"0x\" + data.substring(offset);\n}\nexport function hexConcat(items) {\n let result = \"0x\";\n items.forEach((item) => {\n result += hexlify(item).substring(2);\n });\n return result;\n}\nexport function hexValue(value) {\n const trimmed = hexStripZeros(hexlify(value, { hexPad: \"left\" }));\n if (trimmed === \"0x\") {\n return \"0x0\";\n }\n return trimmed;\n}\nexport function hexStripZeros(value) {\n if (typeof (value) !== \"string\") {\n value = hexlify(value);\n }\n if (!isHexString(value)) {\n logger.throwArgumentError(\"invalid hex string\", \"value\", value);\n }\n value = value.substring(2);\n let offset = 0;\n while (offset < value.length && value[offset] === \"0\") {\n offset++;\n }\n return \"0x\" + value.substring(offset);\n}\nexport function hexZeroPad(value, length) {\n if (typeof (value) !== \"string\") {\n value = hexlify(value);\n }\n else if (!isHexString(value)) {\n logger.throwArgumentError(\"invalid hex string\", \"value\", value);\n }\n if (value.length > 2 * length + 2) {\n logger.throwArgumentError(\"value out of range\", \"value\", arguments[1]);\n }\n while (value.length < 2 * length + 2) {\n value = \"0x0\" + value.substring(2);\n }\n return value;\n}\nexport function splitSignature(signature) {\n const result = {\n r: \"0x\",\n s: \"0x\",\n _vs: \"0x\",\n recoveryParam: 0,\n v: 0\n };\n if (isBytesLike(signature)) {\n const bytes = arrayify(signature);\n if (bytes.length !== 65) {\n logger.throwArgumentError(\"invalid signature string; must be 65 bytes\", \"signature\", signature);\n }\n // Get the r, s and v\n result.r = hexlify(bytes.slice(0, 32));\n result.s = hexlify(bytes.slice(32, 64));\n result.v = bytes[64];\n // Allow a recid to be used as the v\n if (result.v < 27) {\n if (result.v === 0 || result.v === 1) {\n result.v += 27;\n }\n else {\n logger.throwArgumentError(\"signature invalid v byte\", \"signature\", signature);\n }\n }\n // Compute recoveryParam from v\n result.recoveryParam = 1 - (result.v % 2);\n // Compute _vs from recoveryParam and s\n if (result.recoveryParam) {\n bytes[32] |= 0x80;\n }\n result._vs = hexlify(bytes.slice(32, 64));\n }\n else {\n result.r = signature.r;\n result.s = signature.s;\n result.v = signature.v;\n result.recoveryParam = signature.recoveryParam;\n result._vs = signature._vs;\n // If the _vs is available, use it to populate missing s, v and recoveryParam\n // and verify non-missing s, v and recoveryParam\n if (result._vs != null) {\n const vs = zeroPad(arrayify(result._vs), 32);\n result._vs = hexlify(vs);\n // Set or check the recid\n const recoveryParam = ((vs[0] >= 128) ? 1 : 0);\n if (result.recoveryParam == null) {\n result.recoveryParam = recoveryParam;\n }\n else if (result.recoveryParam !== recoveryParam) {\n logger.throwArgumentError(\"signature recoveryParam mismatch _vs\", \"signature\", signature);\n }\n // Set or check the s\n vs[0] &= 0x7f;\n const s = hexlify(vs);\n if (result.s == null) {\n result.s = s;\n }\n else if (result.s !== s) {\n logger.throwArgumentError(\"signature v mismatch _vs\", \"signature\", signature);\n }\n }\n // Use recid and v to populate each other\n if (result.recoveryParam == null) {\n if (result.v == null) {\n logger.throwArgumentError(\"signature missing v and recoveryParam\", \"signature\", signature);\n }\n else if (result.v === 0 || result.v === 1) {\n result.recoveryParam = result.v;\n }\n else {\n result.recoveryParam = 1 - (result.v % 2);\n }\n }\n else {\n if (result.v == null) {\n result.v = 27 + result.recoveryParam;\n }\n else {\n const recId = (result.v === 0 || result.v === 1) ? result.v : (1 - (result.v % 2));\n if (result.recoveryParam !== recId) {\n logger.throwArgumentError(\"signature recoveryParam mismatch v\", \"signature\", signature);\n }\n }\n }\n if (result.r == null || !isHexString(result.r)) {\n logger.throwArgumentError(\"signature missing or invalid r\", \"signature\", signature);\n }\n else {\n result.r = hexZeroPad(result.r, 32);\n }\n if (result.s == null || !isHexString(result.s)) {\n logger.throwArgumentError(\"signature missing or invalid s\", \"signature\", signature);\n }\n else {\n result.s = hexZeroPad(result.s, 32);\n }\n const vs = arrayify(result.s);\n if (vs[0] >= 128) {\n logger.throwArgumentError(\"signature s out of range\", \"signature\", signature);\n }\n if (result.recoveryParam) {\n vs[0] |= 0x80;\n }\n const _vs = hexlify(vs);\n if (result._vs) {\n if (!isHexString(result._vs)) {\n logger.throwArgumentError(\"signature invalid _vs\", \"signature\", signature);\n }\n result._vs = hexZeroPad(result._vs, 32);\n }\n // Set or check the _vs\n if (result._vs == null) {\n result._vs = _vs;\n }\n else if (result._vs !== _vs) {\n logger.throwArgumentError(\"signature _vs mismatch v and s\", \"signature\", signature);\n }\n }\n return result;\n}\nexport function joinSignature(signature) {\n signature = splitSignature(signature);\n return hexlify(concat([\n signature.r,\n signature.s,\n (signature.recoveryParam ? \"0x1c\" : \"0x1b\")\n ]));\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nimport hash from \"hash.js\";\n//const _ripemd160 = _hash.ripemd160;\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { SupportedAlgorithm } from \"./types\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nexport function ripemd160(data) {\n return \"0x\" + (hash.ripemd160().update(arrayify(data)).digest(\"hex\"));\n}\nexport function sha256(data) {\n return \"0x\" + (hash.sha256().update(arrayify(data)).digest(\"hex\"));\n}\nexport function sha512(data) {\n return \"0x\" + (hash.sha512().update(arrayify(data)).digest(\"hex\"));\n}\nexport function computeHmac(algorithm, key, data) {\n if (!SupportedAlgorithm[algorithm]) {\n logger.throwError(\"unsupported algorithm \" + algorithm, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"hmac\",\n algorithm: algorithm\n });\n }\n return \"0x\" + hash.hmac(hash[algorithm], arrayify(key)).update(arrayify(data)).digest(\"hex\");\n}\n//# sourceMappingURL=sha2.js.map","export const version = \"sha2/5.5.0\";\n//# sourceMappingURL=_version.js.map","import {Buffer} from 'buffer';\nimport {serialize, deserialize, deserializeUnchecked} from 'borsh';\n\n// Class wrapping a plain object\nexport class Struct {\n constructor(properties: any) {\n Object.assign(this, properties);\n }\n\n encode(): Buffer {\n return Buffer.from(serialize(SOLANA_SCHEMA, this));\n }\n\n static decode(data: Buffer): any {\n return deserialize(SOLANA_SCHEMA, this, data);\n }\n\n static decodeUnchecked(data: Buffer): any {\n return deserializeUnchecked(SOLANA_SCHEMA, this, data);\n }\n}\n\n// Class representing a Rust-compatible enum, since enums are only strings or\n// numbers in pure JS\nexport class Enum extends Struct {\n enum: string = '';\n constructor(properties: any) {\n super(properties);\n if (Object.keys(properties).length !== 1) {\n throw new Error('Enum can only take single value');\n }\n Object.keys(properties).map(key => {\n this.enum = key;\n });\n }\n}\n\nexport const SOLANA_SCHEMA: Map = new Map();\n","import BN from 'bn.js';\nimport bs58 from 'bs58';\nimport {Buffer} from 'buffer';\nimport nacl from 'tweetnacl';\nimport {sha256} from '@ethersproject/sha2';\n\nimport {Struct, SOLANA_SCHEMA} from './util/borsh-schema';\nimport {toBuffer} from './util/to-buffer';\n\n/**\n * Maximum length of derived pubkey seed\n */\nexport const MAX_SEED_LENGTH = 32;\n\n/**\n * Value to be converted into public key\n */\nexport type PublicKeyInitData =\n | number\n | string\n | Buffer\n | Uint8Array\n | Array\n | PublicKeyData;\n\n/**\n * JSON object representation of PublicKey class\n */\nexport type PublicKeyData = {\n /** @internal */\n _bn: BN;\n};\n\nfunction isPublicKeyData(value: PublicKeyInitData): value is PublicKeyData {\n return (value as PublicKeyData)._bn !== undefined;\n}\n\n/**\n * A public key\n */\nexport class PublicKey extends Struct {\n /** @internal */\n _bn: BN;\n\n /**\n * Create a new PublicKey object\n * @param value ed25519 public key as buffer or base-58 encoded string\n */\n constructor(value: PublicKeyInitData) {\n super({});\n if (isPublicKeyData(value)) {\n this._bn = value._bn;\n } else {\n if (typeof value === 'string') {\n // assume base 58 encoding by default\n const decoded = bs58.decode(value);\n if (decoded.length != 32) {\n throw new Error(`Invalid public key input`);\n }\n this._bn = new BN(decoded);\n } else {\n this._bn = new BN(value);\n }\n\n if (this._bn.byteLength() > 32) {\n throw new Error(`Invalid public key input`);\n }\n }\n }\n\n /**\n * Default public key value. (All zeros)\n */\n static default: PublicKey = new PublicKey('11111111111111111111111111111111');\n\n /**\n * Checks if two publicKeys are equal\n */\n equals(publicKey: PublicKey): boolean {\n return this._bn.eq(publicKey._bn);\n }\n\n /**\n * Return the base-58 representation of the public key\n */\n toBase58(): string {\n return bs58.encode(this.toBytes());\n }\n\n toJSON(): string {\n return this.toBase58();\n }\n\n /**\n * Return the byte array representation of the public key\n */\n toBytes(): Uint8Array {\n return this.toBuffer();\n }\n\n /**\n * Return the Buffer representation of the public key\n */\n toBuffer(): Buffer {\n const b = this._bn.toArrayLike(Buffer);\n if (b.length === 32) {\n return b;\n }\n\n const zeroPad = Buffer.alloc(32);\n b.copy(zeroPad, 32 - b.length);\n return zeroPad;\n }\n\n /**\n * Return the base-58 representation of the public key\n */\n toString(): string {\n return this.toBase58();\n }\n\n /**\n * Derive a public key from another key, a seed, and a program ID.\n * The program ID will also serve as the owner of the public key, giving\n * it permission to write data to the account.\n */\n /* eslint-disable require-await */\n static async createWithSeed(\n fromPublicKey: PublicKey,\n seed: string,\n programId: PublicKey,\n ): Promise {\n const buffer = Buffer.concat([\n fromPublicKey.toBuffer(),\n Buffer.from(seed),\n programId.toBuffer(),\n ]);\n const hash = sha256(new Uint8Array(buffer)).slice(2);\n return new PublicKey(Buffer.from(hash, 'hex'));\n }\n\n /**\n * Derive a program address from seeds and a program ID.\n */\n /* eslint-disable require-await */\n static async createProgramAddress(\n seeds: Array,\n programId: PublicKey,\n ): Promise {\n let buffer = Buffer.alloc(0);\n seeds.forEach(function (seed) {\n if (seed.length > MAX_SEED_LENGTH) {\n throw new TypeError(`Max seed length exceeded`);\n }\n buffer = Buffer.concat([buffer, toBuffer(seed)]);\n });\n buffer = Buffer.concat([\n buffer,\n programId.toBuffer(),\n Buffer.from('ProgramDerivedAddress'),\n ]);\n let hash = sha256(new Uint8Array(buffer)).slice(2);\n let publicKeyBytes = new BN(hash, 16).toArray(undefined, 32);\n if (is_on_curve(publicKeyBytes)) {\n throw new Error(`Invalid seeds, address must fall off the curve`);\n }\n return new PublicKey(publicKeyBytes);\n }\n\n /**\n * Find a valid program address\n *\n * Valid program addresses must fall off the ed25519 curve. This function\n * iterates a nonce until it finds one that when combined with the seeds\n * results in a valid program address.\n */\n static async findProgramAddress(\n seeds: Array,\n programId: PublicKey,\n ): Promise<[PublicKey, number]> {\n let nonce = 255;\n let address;\n while (nonce != 0) {\n try {\n const seedsWithNonce = seeds.concat(Buffer.from([nonce]));\n address = await this.createProgramAddress(seedsWithNonce, programId);\n } catch (err) {\n if (err instanceof TypeError) {\n throw err;\n }\n nonce--;\n continue;\n }\n return [address, nonce];\n }\n throw new Error(`Unable to find a viable program address nonce`);\n }\n\n /**\n * Check that a pubkey is on the ed25519 curve.\n */\n static isOnCurve(pubkey: Uint8Array): boolean {\n return is_on_curve(pubkey) == 1;\n }\n}\n\nSOLANA_SCHEMA.set(PublicKey, {\n kind: 'struct',\n fields: [['_bn', 'u256']],\n});\n\n// @ts-ignore\nlet naclLowLevel = nacl.lowlevel;\n\n// Check that a pubkey is on the curve.\n// This function and its dependents were sourced from:\n// https://github.com/dchest/tweetnacl-js/blob/f1ec050ceae0861f34280e62498b1d3ed9c350c6/nacl.js#L792\nfunction is_on_curve(p: any) {\n var r = [\n naclLowLevel.gf(),\n naclLowLevel.gf(),\n naclLowLevel.gf(),\n naclLowLevel.gf(),\n ];\n\n var t = naclLowLevel.gf(),\n chk = naclLowLevel.gf(),\n num = naclLowLevel.gf(),\n den = naclLowLevel.gf(),\n den2 = naclLowLevel.gf(),\n den4 = naclLowLevel.gf(),\n den6 = naclLowLevel.gf();\n\n naclLowLevel.set25519(r[2], gf1);\n naclLowLevel.unpack25519(r[1], p);\n naclLowLevel.S(num, r[1]);\n naclLowLevel.M(den, num, naclLowLevel.D);\n naclLowLevel.Z(num, num, r[2]);\n naclLowLevel.A(den, r[2], den);\n\n naclLowLevel.S(den2, den);\n naclLowLevel.S(den4, den2);\n naclLowLevel.M(den6, den4, den2);\n naclLowLevel.M(t, den6, num);\n naclLowLevel.M(t, t, den);\n\n naclLowLevel.pow2523(t, t);\n naclLowLevel.M(t, t, num);\n naclLowLevel.M(t, t, den);\n naclLowLevel.M(t, t, den);\n naclLowLevel.M(r[0], t, den);\n\n naclLowLevel.S(chk, r[0]);\n naclLowLevel.M(chk, chk, den);\n if (neq25519(chk, num)) naclLowLevel.M(r[0], r[0], I);\n\n naclLowLevel.S(chk, r[0]);\n naclLowLevel.M(chk, chk, den);\n if (neq25519(chk, num)) return 0;\n return 1;\n}\nlet gf1 = naclLowLevel.gf([1]);\nlet I = naclLowLevel.gf([\n 0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43, 0xd7a7,\n 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83,\n]);\nfunction neq25519(a: any, b: any) {\n var c = new Uint8Array(32),\n d = new Uint8Array(32);\n naclLowLevel.pack25519(c, a);\n naclLowLevel.pack25519(d, b);\n return naclLowLevel.crypto_verify_32(c, 0, d, 0);\n}\n","import nacl from 'tweetnacl';\nimport type {SignKeyPair as KeyPair} from 'tweetnacl';\nimport type {Buffer} from 'buffer';\n\nimport {toBuffer} from './util/to-buffer';\nimport {PublicKey} from './publickey';\n\n/**\n * An account key pair (public and secret keys).\n *\n * @deprecated since v1.10.0, please use {@link Keypair} instead.\n */\nexport class Account {\n /** @internal */\n _keypair: KeyPair;\n\n /**\n * Create a new Account object\n *\n * If the secretKey parameter is not provided a new key pair is randomly\n * created for the account\n *\n * @param secretKey Secret key for the account\n */\n constructor(secretKey?: Buffer | Uint8Array | Array) {\n if (secretKey) {\n this._keypair = nacl.sign.keyPair.fromSecretKey(toBuffer(secretKey));\n } else {\n this._keypair = nacl.sign.keyPair();\n }\n }\n\n /**\n * The public key for this account\n */\n get publicKey(): PublicKey {\n return new PublicKey(this._keypair.publicKey);\n }\n\n /**\n * The **unencrypted** secret key for this account\n */\n get secretKey(): Buffer {\n return toBuffer(this._keypair.secretKey);\n }\n}\n","import {PublicKey} from './publickey';\n\nexport const BPF_LOADER_DEPRECATED_PROGRAM_ID = new PublicKey(\n 'BPFLoader1111111111111111111111111111111111',\n);\n","import {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\n\n/**\n * Layout for a public key\n */\nexport const publicKey = (\n property: string = 'publicKey',\n): BufferLayout.Layout => {\n return BufferLayout.blob(32, property);\n};\n\n/**\n * Layout for a 64bit unsigned value\n */\nexport const uint64 = (property: string = 'uint64'): BufferLayout.Layout => {\n return BufferLayout.blob(8, property);\n};\n\n/**\n * Layout for a Rust String type\n */\nexport const rustString = (property: string = 'string') => {\n const rsl = BufferLayout.struct(\n [\n BufferLayout.u32('length'),\n BufferLayout.u32('lengthPadding'),\n BufferLayout.blob(BufferLayout.offset(BufferLayout.u32(), -8), 'chars'),\n ],\n property,\n );\n const _decode = rsl.decode.bind(rsl);\n const _encode = rsl.encode.bind(rsl);\n\n rsl.decode = (buffer: any, offset: any) => {\n const data = _decode(buffer, offset);\n return data['chars'].toString('utf8');\n };\n\n rsl.encode = (str: any, buffer: any, offset: any) => {\n const data = {\n chars: Buffer.from(str, 'utf8'),\n };\n return _encode(data, buffer, offset);\n };\n\n (rsl as any).alloc = (str: any) => {\n return (\n BufferLayout.u32().span +\n BufferLayout.u32().span +\n Buffer.from(str, 'utf8').length\n );\n };\n\n return rsl;\n};\n\n/**\n * Layout for an Authorized object\n */\nexport const authorized = (property: string = 'authorized') => {\n return BufferLayout.struct(\n [publicKey('staker'), publicKey('withdrawer')],\n property,\n );\n};\n\n/**\n * Layout for a Lockup object\n */\nexport const lockup = (property: string = 'lockup') => {\n return BufferLayout.struct(\n [\n BufferLayout.ns64('unixTimestamp'),\n BufferLayout.ns64('epoch'),\n publicKey('custodian'),\n ],\n property,\n );\n};\n\nexport function getAlloc(type: any, fields: any): number {\n let alloc = 0;\n type.layout.fields.forEach((item: any) => {\n if (item.span >= 0) {\n alloc += item.span;\n } else if (typeof item.alloc === 'function') {\n alloc += item.alloc(fields[item.property]);\n }\n });\n return alloc;\n}\n","export function decodeLength(bytes: Array): number {\n let len = 0;\n let size = 0;\n for (;;) {\n let elem = bytes.shift() as number;\n len |= (elem & 0x7f) << (size * 7);\n size += 1;\n if ((elem & 0x80) === 0) {\n break;\n }\n }\n return len;\n}\n\nexport function encodeLength(bytes: Array, len: number) {\n let rem_len = len;\n for (;;) {\n let elem = rem_len & 0x7f;\n rem_len >>= 7;\n if (rem_len == 0) {\n bytes.push(elem);\n break;\n } else {\n elem |= 0x80;\n bytes.push(elem);\n }\n }\n}\n","import bs58 from 'bs58';\nimport {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\n\nimport {PublicKey} from './publickey';\nimport type {Blockhash} from './blockhash';\nimport * as Layout from './layout';\nimport {PACKET_DATA_SIZE} from './transaction';\nimport * as shortvec from './util/shortvec-encoding';\nimport {toBuffer} from './util/to-buffer';\n\n/**\n * The message header, identifying signed and read-only account\n */\nexport type MessageHeader = {\n /**\n * The number of signatures required for this message to be considered valid. The\n * signatures must match the first `numRequiredSignatures` of `accountKeys`.\n */\n numRequiredSignatures: number;\n /** The last `numReadonlySignedAccounts` of the signed keys are read-only accounts */\n numReadonlySignedAccounts: number;\n /** The last `numReadonlySignedAccounts` of the unsigned keys are read-only accounts */\n numReadonlyUnsignedAccounts: number;\n};\n\n/**\n * An instruction to execute by a program\n *\n * @property {number} programIdIndex\n * @property {number[]} accounts\n * @property {string} data\n */\nexport type CompiledInstruction = {\n /** Index into the transaction keys array indicating the program account that executes this instruction */\n programIdIndex: number;\n /** Ordered indices into the transaction keys array indicating which accounts to pass to the program */\n accounts: number[];\n /** The program input data encoded as base 58 */\n data: string;\n};\n\n/**\n * Message constructor arguments\n */\nexport type MessageArgs = {\n /** The message header, identifying signed and read-only `accountKeys` */\n header: MessageHeader;\n /** All the account keys used by this transaction */\n accountKeys: string[];\n /** The hash of a recent ledger block */\n recentBlockhash: Blockhash;\n /** Instructions that will be executed in sequence and committed in one atomic transaction if all succeed. */\n instructions: CompiledInstruction[];\n};\n\nconst PUBKEY_LENGTH = 32;\n\n/**\n * List of instructions to be processed atomically\n */\nexport class Message {\n header: MessageHeader;\n accountKeys: PublicKey[];\n recentBlockhash: Blockhash;\n instructions: CompiledInstruction[];\n\n private indexToProgramIds: Map = new Map<\n number,\n PublicKey\n >();\n\n constructor(args: MessageArgs) {\n this.header = args.header;\n this.accountKeys = args.accountKeys.map(account => new PublicKey(account));\n this.recentBlockhash = args.recentBlockhash;\n this.instructions = args.instructions;\n this.instructions.forEach(ix =>\n this.indexToProgramIds.set(\n ix.programIdIndex,\n this.accountKeys[ix.programIdIndex],\n ),\n );\n }\n\n isAccountSigner(index: number): boolean {\n return index < this.header.numRequiredSignatures;\n }\n\n isAccountWritable(index: number): boolean {\n return (\n index <\n this.header.numRequiredSignatures -\n this.header.numReadonlySignedAccounts ||\n (index >= this.header.numRequiredSignatures &&\n index <\n this.accountKeys.length - this.header.numReadonlyUnsignedAccounts)\n );\n }\n\n isProgramId(index: number): boolean {\n return this.indexToProgramIds.has(index);\n }\n\n programIds(): PublicKey[] {\n return [...this.indexToProgramIds.values()];\n }\n\n nonProgramIds(): PublicKey[] {\n return this.accountKeys.filter((_, index) => !this.isProgramId(index));\n }\n\n serialize(): Buffer {\n const numKeys = this.accountKeys.length;\n\n let keyCount: number[] = [];\n shortvec.encodeLength(keyCount, numKeys);\n\n const instructions = this.instructions.map(instruction => {\n const {accounts, programIdIndex} = instruction;\n const data = bs58.decode(instruction.data);\n\n let keyIndicesCount: number[] = [];\n shortvec.encodeLength(keyIndicesCount, accounts.length);\n\n let dataCount: number[] = [];\n shortvec.encodeLength(dataCount, data.length);\n\n return {\n programIdIndex,\n keyIndicesCount: Buffer.from(keyIndicesCount),\n keyIndices: Buffer.from(accounts),\n dataLength: Buffer.from(dataCount),\n data,\n };\n });\n\n let instructionCount: number[] = [];\n shortvec.encodeLength(instructionCount, instructions.length);\n let instructionBuffer = Buffer.alloc(PACKET_DATA_SIZE);\n Buffer.from(instructionCount).copy(instructionBuffer);\n let instructionBufferLength = instructionCount.length;\n\n instructions.forEach(instruction => {\n const instructionLayout = BufferLayout.struct([\n BufferLayout.u8('programIdIndex'),\n\n BufferLayout.blob(\n instruction.keyIndicesCount.length,\n 'keyIndicesCount',\n ),\n BufferLayout.seq(\n BufferLayout.u8('keyIndex'),\n instruction.keyIndices.length,\n 'keyIndices',\n ),\n BufferLayout.blob(instruction.dataLength.length, 'dataLength'),\n BufferLayout.seq(\n BufferLayout.u8('userdatum'),\n instruction.data.length,\n 'data',\n ),\n ]);\n const length = instructionLayout.encode(\n instruction,\n instructionBuffer,\n instructionBufferLength,\n );\n instructionBufferLength += length;\n });\n instructionBuffer = instructionBuffer.slice(0, instructionBufferLength);\n\n const signDataLayout = BufferLayout.struct([\n BufferLayout.blob(1, 'numRequiredSignatures'),\n BufferLayout.blob(1, 'numReadonlySignedAccounts'),\n BufferLayout.blob(1, 'numReadonlyUnsignedAccounts'),\n BufferLayout.blob(keyCount.length, 'keyCount'),\n BufferLayout.seq(Layout.publicKey('key'), numKeys, 'keys'),\n Layout.publicKey('recentBlockhash'),\n ]);\n\n const transaction = {\n numRequiredSignatures: Buffer.from([this.header.numRequiredSignatures]),\n numReadonlySignedAccounts: Buffer.from([\n this.header.numReadonlySignedAccounts,\n ]),\n numReadonlyUnsignedAccounts: Buffer.from([\n this.header.numReadonlyUnsignedAccounts,\n ]),\n keyCount: Buffer.from(keyCount),\n keys: this.accountKeys.map(key => toBuffer(key.toBytes())),\n recentBlockhash: bs58.decode(this.recentBlockhash),\n };\n\n let signData = Buffer.alloc(2048);\n const length = signDataLayout.encode(transaction, signData);\n instructionBuffer.copy(signData, length);\n return signData.slice(0, length + instructionBuffer.length);\n }\n\n /**\n * Decode a compiled message into a Message object.\n */\n static from(buffer: Buffer | Uint8Array | Array): Message {\n // Slice up wire data\n let byteArray = [...buffer];\n\n const numRequiredSignatures = byteArray.shift() as number;\n const numReadonlySignedAccounts = byteArray.shift() as number;\n const numReadonlyUnsignedAccounts = byteArray.shift() as number;\n\n const accountCount = shortvec.decodeLength(byteArray);\n let accountKeys = [];\n for (let i = 0; i < accountCount; i++) {\n const account = byteArray.slice(0, PUBKEY_LENGTH);\n byteArray = byteArray.slice(PUBKEY_LENGTH);\n accountKeys.push(bs58.encode(Buffer.from(account)));\n }\n\n const recentBlockhash = byteArray.slice(0, PUBKEY_LENGTH);\n byteArray = byteArray.slice(PUBKEY_LENGTH);\n\n const instructionCount = shortvec.decodeLength(byteArray);\n let instructions: CompiledInstruction[] = [];\n for (let i = 0; i < instructionCount; i++) {\n const programIdIndex = byteArray.shift() as number;\n const accountCount = shortvec.decodeLength(byteArray);\n const accounts = byteArray.slice(0, accountCount);\n byteArray = byteArray.slice(accountCount);\n const dataLength = shortvec.decodeLength(byteArray);\n const dataSlice = byteArray.slice(0, dataLength);\n const data = bs58.encode(Buffer.from(dataSlice));\n byteArray = byteArray.slice(dataLength);\n instructions.push({\n programIdIndex,\n accounts,\n data,\n });\n }\n\n const messageArgs = {\n header: {\n numRequiredSignatures,\n numReadonlySignedAccounts,\n numReadonlyUnsignedAccounts,\n },\n recentBlockhash: bs58.encode(Buffer.from(recentBlockhash)),\n accountKeys,\n instructions,\n };\n\n return new Message(messageArgs);\n }\n}\n","export default function (\n condition: unknown,\n message?: string,\n): asserts condition {\n if (!condition) {\n throw new Error(message || 'Assertion failed');\n }\n}\n","import nacl from 'tweetnacl';\nimport bs58 from 'bs58';\nimport {Buffer} from 'buffer';\n\nimport {Message} from './message';\nimport {PublicKey} from './publickey';\nimport * as shortvec from './util/shortvec-encoding';\nimport {toBuffer} from './util/to-buffer';\nimport invariant from './util/assert';\nimport type {Signer} from './keypair';\nimport type {Blockhash} from './blockhash';\nimport type {CompiledInstruction} from './message';\n\n/**\n * Transaction signature as base-58 encoded string\n */\nexport type TransactionSignature = string;\n\n/**\n * Default (empty) signature\n *\n * Signatures are 64 bytes in length\n */\nconst DEFAULT_SIGNATURE = Buffer.alloc(64).fill(0);\n\n/**\n * Maximum over-the-wire size of a Transaction\n *\n * 1280 is IPv6 minimum MTU\n * 40 bytes is the size of the IPv6 header\n * 8 bytes is the size of the fragment header\n */\nexport const PACKET_DATA_SIZE = 1280 - 40 - 8;\n\nconst SIGNATURE_LENGTH = 64;\n\n/**\n * Account metadata used to define instructions\n */\nexport type AccountMeta = {\n /** An account's public key */\n pubkey: PublicKey;\n /** True if an instruction requires a transaction signature matching `pubkey` */\n isSigner: boolean;\n /** True if the `pubkey` can be loaded as a read-write account. */\n isWritable: boolean;\n};\n\n/**\n * List of TransactionInstruction object fields that may be initialized at construction\n */\nexport type TransactionInstructionCtorFields = {\n keys: Array;\n programId: PublicKey;\n data?: Buffer;\n};\n\n/**\n * Configuration object for Transaction.serialize()\n */\nexport type SerializeConfig = {\n /** Require all transaction signatures be present (default: true) */\n requireAllSignatures?: boolean;\n /** Verify provided signatures (default: true) */\n verifySignatures?: boolean;\n};\n\n/**\n * Transaction Instruction class\n */\nexport class TransactionInstruction {\n /**\n * Public keys to include in this transaction\n * Boolean represents whether this pubkey needs to sign the transaction\n */\n keys: Array;\n\n /**\n * Program Id to execute\n */\n programId: PublicKey;\n\n /**\n * Program input\n */\n data: Buffer = Buffer.alloc(0);\n\n constructor(opts: TransactionInstructionCtorFields) {\n this.programId = opts.programId;\n this.keys = opts.keys;\n if (opts.data) {\n this.data = opts.data;\n }\n }\n}\n\n/**\n * Pair of signature and corresponding public key\n */\nexport type SignaturePubkeyPair = {\n signature: Buffer | null;\n publicKey: PublicKey;\n};\n\n/**\n * List of Transaction object fields that may be initialized at construction\n *\n */\nexport type TransactionCtorFields = {\n /** A recent blockhash */\n recentBlockhash?: Blockhash | null;\n /** Optional nonce information used for offline nonce'd transactions */\n nonceInfo?: NonceInformation | null;\n /** The transaction fee payer */\n feePayer?: PublicKey | null;\n /** One or more signatures */\n signatures?: Array;\n};\n\n/**\n * Nonce information to be used to build an offline Transaction.\n */\nexport type NonceInformation = {\n /** The current blockhash stored in the nonce */\n nonce: Blockhash;\n /** AdvanceNonceAccount Instruction */\n nonceInstruction: TransactionInstruction;\n};\n\n/**\n * Transaction class\n */\nexport class Transaction {\n /**\n * Signatures for the transaction. Typically created by invoking the\n * `sign()` method\n */\n signatures: Array = [];\n\n /**\n * The first (payer) Transaction signature\n */\n get signature(): Buffer | null {\n if (this.signatures.length > 0) {\n return this.signatures[0].signature;\n }\n return null;\n }\n\n /**\n * The transaction fee payer\n */\n feePayer?: PublicKey;\n\n /**\n * The instructions to atomically execute\n */\n instructions: Array = [];\n\n /**\n * A recent transaction id. Must be populated by the caller\n */\n recentBlockhash?: Blockhash;\n\n /**\n * Optional Nonce information. If populated, transaction will use a durable\n * Nonce hash instead of a recentBlockhash. Must be populated by the caller\n */\n nonceInfo?: NonceInformation;\n\n /**\n * Construct an empty Transaction\n */\n constructor(opts?: TransactionCtorFields) {\n opts && Object.assign(this, opts);\n }\n\n /**\n * Add one or more instructions to this Transaction\n */\n add(\n ...items: Array<\n Transaction | TransactionInstruction | TransactionInstructionCtorFields\n >\n ): Transaction {\n if (items.length === 0) {\n throw new Error('No instructions');\n }\n\n items.forEach((item: any) => {\n if ('instructions' in item) {\n this.instructions = this.instructions.concat(item.instructions);\n } else if ('data' in item && 'programId' in item && 'keys' in item) {\n this.instructions.push(item);\n } else {\n this.instructions.push(new TransactionInstruction(item));\n }\n });\n return this;\n }\n\n /**\n * Compile transaction data\n */\n compileMessage(): Message {\n const {nonceInfo} = this;\n if (nonceInfo && this.instructions[0] != nonceInfo.nonceInstruction) {\n this.recentBlockhash = nonceInfo.nonce;\n this.instructions.unshift(nonceInfo.nonceInstruction);\n }\n const {recentBlockhash} = this;\n if (!recentBlockhash) {\n throw new Error('Transaction recentBlockhash required');\n }\n\n if (this.instructions.length < 1) {\n console.warn('No instructions provided');\n }\n\n let feePayer: PublicKey;\n if (this.feePayer) {\n feePayer = this.feePayer;\n } else if (this.signatures.length > 0 && this.signatures[0].publicKey) {\n // Use implicit fee payer\n feePayer = this.signatures[0].publicKey;\n } else {\n throw new Error('Transaction fee payer required');\n }\n\n for (let i = 0; i < this.instructions.length; i++) {\n if (this.instructions[i].programId === undefined) {\n throw new Error(\n `Transaction instruction index ${i} has undefined program id`,\n );\n }\n }\n\n const programIds: string[] = [];\n const accountMetas: AccountMeta[] = [];\n this.instructions.forEach(instruction => {\n instruction.keys.forEach(accountMeta => {\n accountMetas.push({...accountMeta});\n });\n\n const programId = instruction.programId.toString();\n if (!programIds.includes(programId)) {\n programIds.push(programId);\n }\n });\n\n // Append programID account metas\n programIds.forEach(programId => {\n accountMetas.push({\n pubkey: new PublicKey(programId),\n isSigner: false,\n isWritable: false,\n });\n });\n\n // Sort. Prioritizing first by signer, then by writable\n accountMetas.sort(function (x, y) {\n const pubkeySorting = x.pubkey\n .toBase58()\n .localeCompare(y.pubkey.toBase58());\n const checkSigner = x.isSigner === y.isSigner ? 0 : x.isSigner ? -1 : 1;\n const checkWritable =\n x.isWritable === y.isWritable ? pubkeySorting : x.isWritable ? -1 : 1;\n return checkSigner || checkWritable;\n });\n\n // Cull duplicate account metas\n const uniqueMetas: AccountMeta[] = [];\n accountMetas.forEach(accountMeta => {\n const pubkeyString = accountMeta.pubkey.toString();\n const uniqueIndex = uniqueMetas.findIndex(x => {\n return x.pubkey.toString() === pubkeyString;\n });\n if (uniqueIndex > -1) {\n uniqueMetas[uniqueIndex].isWritable =\n uniqueMetas[uniqueIndex].isWritable || accountMeta.isWritable;\n } else {\n uniqueMetas.push(accountMeta);\n }\n });\n\n // Move fee payer to the front\n const feePayerIndex = uniqueMetas.findIndex(x => {\n return x.pubkey.equals(feePayer);\n });\n if (feePayerIndex > -1) {\n const [payerMeta] = uniqueMetas.splice(feePayerIndex, 1);\n payerMeta.isSigner = true;\n payerMeta.isWritable = true;\n uniqueMetas.unshift(payerMeta);\n } else {\n uniqueMetas.unshift({\n pubkey: feePayer,\n isSigner: true,\n isWritable: true,\n });\n }\n\n // Disallow unknown signers\n for (const signature of this.signatures) {\n const uniqueIndex = uniqueMetas.findIndex(x => {\n return x.pubkey.equals(signature.publicKey);\n });\n if (uniqueIndex > -1) {\n if (!uniqueMetas[uniqueIndex].isSigner) {\n uniqueMetas[uniqueIndex].isSigner = true;\n console.warn(\n 'Transaction references a signature that is unnecessary, ' +\n 'only the fee payer and instruction signer accounts should sign a transaction. ' +\n 'This behavior is deprecated and will throw an error in the next major version release.',\n );\n }\n } else {\n throw new Error(`unknown signer: ${signature.publicKey.toString()}`);\n }\n }\n\n let numRequiredSignatures = 0;\n let numReadonlySignedAccounts = 0;\n let numReadonlyUnsignedAccounts = 0;\n\n // Split out signing from non-signing keys and count header values\n const signedKeys: string[] = [];\n const unsignedKeys: string[] = [];\n uniqueMetas.forEach(({pubkey, isSigner, isWritable}) => {\n if (isSigner) {\n signedKeys.push(pubkey.toString());\n numRequiredSignatures += 1;\n if (!isWritable) {\n numReadonlySignedAccounts += 1;\n }\n } else {\n unsignedKeys.push(pubkey.toString());\n if (!isWritable) {\n numReadonlyUnsignedAccounts += 1;\n }\n }\n });\n\n const accountKeys = signedKeys.concat(unsignedKeys);\n const instructions: CompiledInstruction[] = this.instructions.map(\n instruction => {\n const {data, programId} = instruction;\n return {\n programIdIndex: accountKeys.indexOf(programId.toString()),\n accounts: instruction.keys.map(meta =>\n accountKeys.indexOf(meta.pubkey.toString()),\n ),\n data: bs58.encode(data),\n };\n },\n );\n\n instructions.forEach(instruction => {\n invariant(instruction.programIdIndex >= 0);\n instruction.accounts.forEach(keyIndex => invariant(keyIndex >= 0));\n });\n\n return new Message({\n header: {\n numRequiredSignatures,\n numReadonlySignedAccounts,\n numReadonlyUnsignedAccounts,\n },\n accountKeys,\n recentBlockhash,\n instructions,\n });\n }\n\n /**\n * @internal\n */\n _compile(): Message {\n const message = this.compileMessage();\n const signedKeys = message.accountKeys.slice(\n 0,\n message.header.numRequiredSignatures,\n );\n\n if (this.signatures.length === signedKeys.length) {\n const valid = this.signatures.every((pair, index) => {\n return signedKeys[index].equals(pair.publicKey);\n });\n\n if (valid) return message;\n }\n\n this.signatures = signedKeys.map(publicKey => ({\n signature: null,\n publicKey,\n }));\n\n return message;\n }\n\n /**\n * Get a buffer of the Transaction data that need to be covered by signatures\n */\n serializeMessage(): Buffer {\n return this._compile().serialize();\n }\n\n /**\n * Specify the public keys which will be used to sign the Transaction.\n * The first signer will be used as the transaction fee payer account.\n *\n * Signatures can be added with either `partialSign` or `addSignature`\n *\n * @deprecated Deprecated since v0.84.0. Only the fee payer needs to be\n * specified and it can be set in the Transaction constructor or with the\n * `feePayer` property.\n */\n setSigners(...signers: Array) {\n if (signers.length === 0) {\n throw new Error('No signers');\n }\n\n const seen = new Set();\n this.signatures = signers\n .filter(publicKey => {\n const key = publicKey.toString();\n if (seen.has(key)) {\n return false;\n } else {\n seen.add(key);\n return true;\n }\n })\n .map(publicKey => ({signature: null, publicKey}));\n }\n\n /**\n * Sign the Transaction with the specified signers. Multiple signatures may\n * be applied to a Transaction. The first signature is considered \"primary\"\n * and is used identify and confirm transactions.\n *\n * If the Transaction `feePayer` is not set, the first signer will be used\n * as the transaction fee payer account.\n *\n * Transaction fields should not be modified after the first call to `sign`,\n * as doing so may invalidate the signature and cause the Transaction to be\n * rejected.\n *\n * The Transaction must be assigned a valid `recentBlockhash` before invoking this method\n */\n sign(...signers: Array) {\n if (signers.length === 0) {\n throw new Error('No signers');\n }\n\n // Dedupe signers\n const seen = new Set();\n const uniqueSigners = [];\n for (const signer of signers) {\n const key = signer.publicKey.toString();\n if (seen.has(key)) {\n continue;\n } else {\n seen.add(key);\n uniqueSigners.push(signer);\n }\n }\n\n this.signatures = uniqueSigners.map(signer => ({\n signature: null,\n publicKey: signer.publicKey,\n }));\n\n const message = this._compile();\n this._partialSign(message, ...uniqueSigners);\n this._verifySignatures(message.serialize(), true);\n }\n\n /**\n * Partially sign a transaction with the specified accounts. All accounts must\n * correspond to either the fee payer or a signer account in the transaction\n * instructions.\n *\n * All the caveats from the `sign` method apply to `partialSign`\n */\n partialSign(...signers: Array) {\n if (signers.length === 0) {\n throw new Error('No signers');\n }\n\n // Dedupe signers\n const seen = new Set();\n const uniqueSigners = [];\n for (const signer of signers) {\n const key = signer.publicKey.toString();\n if (seen.has(key)) {\n continue;\n } else {\n seen.add(key);\n uniqueSigners.push(signer);\n }\n }\n\n const message = this._compile();\n this._partialSign(message, ...uniqueSigners);\n }\n\n /**\n * @internal\n */\n _partialSign(message: Message, ...signers: Array) {\n const signData = message.serialize();\n signers.forEach(signer => {\n const signature = nacl.sign.detached(signData, signer.secretKey);\n this._addSignature(signer.publicKey, toBuffer(signature));\n });\n }\n\n /**\n * Add an externally created signature to a transaction. The public key\n * must correspond to either the fee payer or a signer account in the transaction\n * instructions.\n */\n addSignature(pubkey: PublicKey, signature: Buffer) {\n this._compile(); // Ensure signatures array is populated\n this._addSignature(pubkey, signature);\n }\n\n /**\n * @internal\n */\n _addSignature(pubkey: PublicKey, signature: Buffer) {\n invariant(signature.length === 64);\n\n const index = this.signatures.findIndex(sigpair =>\n pubkey.equals(sigpair.publicKey),\n );\n if (index < 0) {\n throw new Error(`unknown signer: ${pubkey.toString()}`);\n }\n\n this.signatures[index].signature = Buffer.from(signature);\n }\n\n /**\n * Verify signatures of a complete, signed Transaction\n */\n verifySignatures(): boolean {\n return this._verifySignatures(this.serializeMessage(), true);\n }\n\n /**\n * @internal\n */\n _verifySignatures(signData: Buffer, requireAllSignatures: boolean): boolean {\n for (const {signature, publicKey} of this.signatures) {\n if (signature === null) {\n if (requireAllSignatures) {\n return false;\n }\n } else {\n if (\n !nacl.sign.detached.verify(signData, signature, publicKey.toBuffer())\n ) {\n return false;\n }\n }\n }\n return true;\n }\n\n /**\n * Serialize the Transaction in the wire format.\n */\n serialize(config?: SerializeConfig): Buffer {\n const {requireAllSignatures, verifySignatures} = Object.assign(\n {requireAllSignatures: true, verifySignatures: true},\n config,\n );\n\n const signData = this.serializeMessage();\n if (\n verifySignatures &&\n !this._verifySignatures(signData, requireAllSignatures)\n ) {\n throw new Error('Signature verification failed');\n }\n\n return this._serialize(signData);\n }\n\n /**\n * @internal\n */\n _serialize(signData: Buffer): Buffer {\n const {signatures} = this;\n const signatureCount: number[] = [];\n shortvec.encodeLength(signatureCount, signatures.length);\n const transactionLength =\n signatureCount.length + signatures.length * 64 + signData.length;\n const wireTransaction = Buffer.alloc(transactionLength);\n invariant(signatures.length < 256);\n Buffer.from(signatureCount).copy(wireTransaction, 0);\n signatures.forEach(({signature}, index) => {\n if (signature !== null) {\n invariant(signature.length === 64, `signature has invalid length`);\n Buffer.from(signature).copy(\n wireTransaction,\n signatureCount.length + index * 64,\n );\n }\n });\n signData.copy(\n wireTransaction,\n signatureCount.length + signatures.length * 64,\n );\n invariant(\n wireTransaction.length <= PACKET_DATA_SIZE,\n `Transaction too large: ${wireTransaction.length} > ${PACKET_DATA_SIZE}`,\n );\n return wireTransaction;\n }\n\n /**\n * Deprecated method\n * @internal\n */\n get keys(): Array {\n invariant(this.instructions.length === 1);\n return this.instructions[0].keys.map(keyObj => keyObj.pubkey);\n }\n\n /**\n * Deprecated method\n * @internal\n */\n get programId(): PublicKey {\n invariant(this.instructions.length === 1);\n return this.instructions[0].programId;\n }\n\n /**\n * Deprecated method\n * @internal\n */\n get data(): Buffer {\n invariant(this.instructions.length === 1);\n return this.instructions[0].data;\n }\n\n /**\n * Parse a wire transaction into a Transaction object.\n */\n static from(buffer: Buffer | Uint8Array | Array): Transaction {\n // Slice up wire data\n let byteArray = [...buffer];\n\n const signatureCount = shortvec.decodeLength(byteArray);\n let signatures = [];\n for (let i = 0; i < signatureCount; i++) {\n const signature = byteArray.slice(0, SIGNATURE_LENGTH);\n byteArray = byteArray.slice(SIGNATURE_LENGTH);\n signatures.push(bs58.encode(Buffer.from(signature)));\n }\n\n return Transaction.populate(Message.from(byteArray), signatures);\n }\n\n /**\n * Populate Transaction object from message and signatures\n */\n static populate(\n message: Message,\n signatures: Array = [],\n ): Transaction {\n const transaction = new Transaction();\n transaction.recentBlockhash = message.recentBlockhash;\n if (message.header.numRequiredSignatures > 0) {\n transaction.feePayer = message.accountKeys[0];\n }\n signatures.forEach((signature, index) => {\n const sigPubkeyPair = {\n signature:\n signature == bs58.encode(DEFAULT_SIGNATURE)\n ? null\n : bs58.decode(signature),\n publicKey: message.accountKeys[index],\n };\n transaction.signatures.push(sigPubkeyPair);\n });\n\n message.instructions.forEach(instruction => {\n const keys = instruction.accounts.map(account => {\n const pubkey = message.accountKeys[account];\n return {\n pubkey,\n isSigner:\n transaction.signatures.some(\n keyObj => keyObj.publicKey.toString() === pubkey.toString(),\n ) || message.isAccountSigner(account),\n isWritable: message.isAccountWritable(account),\n };\n });\n\n transaction.instructions.push(\n new TransactionInstruction({\n keys,\n programId: message.accountKeys[instruction.programIdIndex],\n data: bs58.decode(instruction.data),\n }),\n );\n });\n\n return transaction;\n }\n}\n","import {PublicKey} from './publickey';\n\nexport const SYSVAR_CLOCK_PUBKEY = new PublicKey(\n 'SysvarC1ock11111111111111111111111111111111',\n);\n\nexport const SYSVAR_EPOCH_SCHEDULE_PUBKEY = new PublicKey(\n 'SysvarEpochSchedu1e111111111111111111111111',\n);\n\nexport const SYSVAR_INSTRUCTIONS_PUBKEY = new PublicKey(\n 'Sysvar1nstructions1111111111111111111111111',\n);\n\nexport const SYSVAR_RECENT_BLOCKHASHES_PUBKEY = new PublicKey(\n 'SysvarRecentB1ockHashes11111111111111111111',\n);\n\nexport const SYSVAR_RENT_PUBKEY = new PublicKey(\n 'SysvarRent111111111111111111111111111111111',\n);\n\nexport const SYSVAR_REWARDS_PUBKEY = new PublicKey(\n 'SysvarRewards111111111111111111111111111111',\n);\n\nexport const SYSVAR_SLOT_HASHES_PUBKEY = new PublicKey(\n 'SysvarS1otHashes111111111111111111111111111',\n);\n\nexport const SYSVAR_SLOT_HISTORY_PUBKEY = new PublicKey(\n 'SysvarS1otHistory11111111111111111111111111',\n);\n\nexport const SYSVAR_STAKE_HISTORY_PUBKEY = new PublicKey(\n 'SysvarStakeHistory1111111111111111111111111',\n);\n","import {Connection} from '../connection';\nimport {Transaction} from '../transaction';\nimport type {ConfirmOptions} from '../connection';\nimport type {Signer} from '../keypair';\nimport type {TransactionSignature} from '../transaction';\n\n/**\n * Sign, send and confirm a transaction.\n *\n * If `commitment` option is not specified, defaults to 'max' commitment.\n *\n * @param {Connection} connection\n * @param {Transaction} transaction\n * @param {Array} signers\n * @param {ConfirmOptions} [options]\n * @returns {Promise}\n */\nexport async function sendAndConfirmTransaction(\n connection: Connection,\n transaction: Transaction,\n signers: Array,\n options?: ConfirmOptions,\n): Promise {\n const sendOptions = options && {\n skipPreflight: options.skipPreflight,\n preflightCommitment: options.preflightCommitment || options.commitment,\n };\n\n const signature = await connection.sendTransaction(\n transaction,\n signers,\n sendOptions,\n );\n\n const status = (\n await connection.confirmTransaction(\n signature,\n options && options.commitment,\n )\n ).value;\n\n if (status.err) {\n throw new Error(\n `Transaction ${signature} failed (${JSON.stringify(status)})`,\n );\n }\n\n return signature;\n}\n","// zzz\nexport function sleep(ms: number): Promise {\n return new Promise(resolve => setTimeout(resolve, ms));\n}\n","import {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\n\nimport * as Layout from './layout';\n\n/**\n * @internal\n */\nexport type InstructionType = {\n /** The Instruction index (from solana upstream program) */\n index: number;\n /** The BufferLayout to use to build data */\n layout: BufferLayout.Layout;\n};\n\n/**\n * Populate a buffer of instruction data using an InstructionType\n * @internal\n */\nexport function encodeData(type: InstructionType, fields?: any): Buffer {\n const allocLength =\n type.layout.span >= 0 ? type.layout.span : Layout.getAlloc(type, fields);\n const data = Buffer.alloc(allocLength);\n const layoutFields = Object.assign({instruction: type.index}, fields);\n type.layout.encode(layoutFields, data);\n return data;\n}\n\n/**\n * Decode instruction data buffer using an InstructionType\n * @internal\n */\nexport function decodeData(type: InstructionType, buffer: Buffer): any {\n let data;\n try {\n data = type.layout.decode(buffer);\n } catch (err) {\n throw new Error('invalid instruction; ' + err);\n }\n\n if (data.instruction !== type.index) {\n throw new Error(\n `invalid instruction; instruction index mismatch ${data.instruction} != ${type.index}`,\n );\n }\n\n return data;\n}\n","import * as BufferLayout from '@solana/buffer-layout';\n\n/**\n * https://github.com/solana-labs/solana/blob/90bedd7e067b5b8f3ddbb45da00a4e9cabb22c62/sdk/src/fee_calculator.rs#L7-L11\n *\n * @internal\n */\nexport const FeeCalculatorLayout = BufferLayout.nu64('lamportsPerSignature');\n\n/**\n * Calculator for transaction fees.\n */\nexport interface FeeCalculator {\n /** Cost in lamports to validate a signature. */\n lamportsPerSignature: number;\n}\n","import * as BufferLayout from '@solana/buffer-layout';\nimport {Buffer} from 'buffer';\n\nimport type {Blockhash} from './blockhash';\nimport * as Layout from './layout';\nimport {PublicKey} from './publickey';\nimport type {FeeCalculator} from './fee-calculator';\nimport {FeeCalculatorLayout} from './fee-calculator';\nimport {toBuffer} from './util/to-buffer';\n\n/**\n * See https://github.com/solana-labs/solana/blob/0ea2843ec9cdc517572b8e62c959f41b55cf4453/sdk/src/nonce_state.rs#L29-L32\n *\n * @internal\n */\nconst NonceAccountLayout = BufferLayout.struct([\n BufferLayout.u32('version'),\n BufferLayout.u32('state'),\n Layout.publicKey('authorizedPubkey'),\n Layout.publicKey('nonce'),\n BufferLayout.struct([FeeCalculatorLayout], 'feeCalculator'),\n]);\n\nexport const NONCE_ACCOUNT_LENGTH = NonceAccountLayout.span;\n\ntype NonceAccountArgs = {\n authorizedPubkey: PublicKey;\n nonce: Blockhash;\n feeCalculator: FeeCalculator;\n};\n\n/**\n * NonceAccount class\n */\nexport class NonceAccount {\n authorizedPubkey: PublicKey;\n nonce: Blockhash;\n feeCalculator: FeeCalculator;\n\n /**\n * @internal\n */\n constructor(args: NonceAccountArgs) {\n this.authorizedPubkey = args.authorizedPubkey;\n this.nonce = args.nonce;\n this.feeCalculator = args.feeCalculator;\n }\n\n /**\n * Deserialize NonceAccount from the account data.\n *\n * @param buffer account data\n * @return NonceAccount\n */\n static fromAccountData(\n buffer: Buffer | Uint8Array | Array,\n ): NonceAccount {\n const nonceAccount = NonceAccountLayout.decode(toBuffer(buffer), 0);\n return new NonceAccount({\n authorizedPubkey: new PublicKey(nonceAccount.authorizedPubkey),\n nonce: new PublicKey(nonceAccount.nonce).toString(),\n feeCalculator: nonceAccount.feeCalculator,\n });\n }\n}\n","import * as BufferLayout from '@solana/buffer-layout';\n\nimport {encodeData, decodeData, InstructionType} from './instruction';\nimport * as Layout from './layout';\nimport {NONCE_ACCOUNT_LENGTH} from './nonce-account';\nimport {PublicKey} from './publickey';\nimport {SYSVAR_RECENT_BLOCKHASHES_PUBKEY, SYSVAR_RENT_PUBKEY} from './sysvar';\nimport {Transaction, TransactionInstruction} from './transaction';\nimport {toBuffer} from './util/to-buffer';\n\n/**\n * Create account system transaction params\n */\nexport type CreateAccountParams = {\n /** The account that will transfer lamports to the created account */\n fromPubkey: PublicKey;\n /** Public key of the created account */\n newAccountPubkey: PublicKey;\n /** Amount of lamports to transfer to the created account */\n lamports: number;\n /** Amount of space in bytes to allocate to the created account */\n space: number;\n /** Public key of the program to assign as the owner of the created account */\n programId: PublicKey;\n};\n\n/**\n * Transfer system transaction params\n */\nexport type TransferParams = {\n /** Account that will transfer lamports */\n fromPubkey: PublicKey;\n /** Account that will receive transferred lamports */\n toPubkey: PublicKey;\n /** Amount of lamports to transfer */\n lamports: number;\n};\n\n/**\n * Assign system transaction params\n */\nexport type AssignParams = {\n /** Public key of the account which will be assigned a new owner */\n accountPubkey: PublicKey;\n /** Public key of the program to assign as the owner */\n programId: PublicKey;\n};\n\n/**\n * Create account with seed system transaction params\n */\nexport type CreateAccountWithSeedParams = {\n /** The account that will transfer lamports to the created account */\n fromPubkey: PublicKey;\n /** Public key of the created account. Must be pre-calculated with PublicKey.createWithSeed() */\n newAccountPubkey: PublicKey;\n /** Base public key to use to derive the address of the created account. Must be the same as the base key used to create `newAccountPubkey` */\n basePubkey: PublicKey;\n /** Seed to use to derive the address of the created account. Must be the same as the seed used to create `newAccountPubkey` */\n seed: string;\n /** Amount of lamports to transfer to the created account */\n lamports: number;\n /** Amount of space in bytes to allocate to the created account */\n space: number;\n /** Public key of the program to assign as the owner of the created account */\n programId: PublicKey;\n};\n\n/**\n * Create nonce account system transaction params\n */\nexport type CreateNonceAccountParams = {\n /** The account that will transfer lamports to the created nonce account */\n fromPubkey: PublicKey;\n /** Public key of the created nonce account */\n noncePubkey: PublicKey;\n /** Public key to set as authority of the created nonce account */\n authorizedPubkey: PublicKey;\n /** Amount of lamports to transfer to the created nonce account */\n lamports: number;\n};\n\n/**\n * Create nonce account with seed system transaction params\n */\nexport type CreateNonceAccountWithSeedParams = {\n /** The account that will transfer lamports to the created nonce account */\n fromPubkey: PublicKey;\n /** Public key of the created nonce account */\n noncePubkey: PublicKey;\n /** Public key to set as authority of the created nonce account */\n authorizedPubkey: PublicKey;\n /** Amount of lamports to transfer to the created nonce account */\n lamports: number;\n /** Base public key to use to derive the address of the nonce account */\n basePubkey: PublicKey;\n /** Seed to use to derive the address of the nonce account */\n seed: string;\n};\n\n/**\n * Initialize nonce account system instruction params\n */\nexport type InitializeNonceParams = {\n /** Nonce account which will be initialized */\n noncePubkey: PublicKey;\n /** Public key to set as authority of the initialized nonce account */\n authorizedPubkey: PublicKey;\n};\n\n/**\n * Advance nonce account system instruction params\n */\nexport type AdvanceNonceParams = {\n /** Nonce account */\n noncePubkey: PublicKey;\n /** Public key of the nonce authority */\n authorizedPubkey: PublicKey;\n};\n\n/**\n * Withdraw nonce account system transaction params\n */\nexport type WithdrawNonceParams = {\n /** Nonce account */\n noncePubkey: PublicKey;\n /** Public key of the nonce authority */\n authorizedPubkey: PublicKey;\n /** Public key of the account which will receive the withdrawn nonce account balance */\n toPubkey: PublicKey;\n /** Amount of lamports to withdraw from the nonce account */\n lamports: number;\n};\n\n/**\n * Authorize nonce account system transaction params\n */\nexport type AuthorizeNonceParams = {\n /** Nonce account */\n noncePubkey: PublicKey;\n /** Public key of the current nonce authority */\n authorizedPubkey: PublicKey;\n /** Public key to set as the new nonce authority */\n newAuthorizedPubkey: PublicKey;\n};\n\n/**\n * Allocate account system transaction params\n */\nexport type AllocateParams = {\n /** Account to allocate */\n accountPubkey: PublicKey;\n /** Amount of space in bytes to allocate */\n space: number;\n};\n\n/**\n * Allocate account with seed system transaction params\n */\nexport type AllocateWithSeedParams = {\n /** Account to allocate */\n accountPubkey: PublicKey;\n /** Base public key to use to derive the address of the allocated account */\n basePubkey: PublicKey;\n /** Seed to use to derive the address of the allocated account */\n seed: string;\n /** Amount of space in bytes to allocate */\n space: number;\n /** Public key of the program to assign as the owner of the allocated account */\n programId: PublicKey;\n};\n\n/**\n * Assign account with seed system transaction params\n */\nexport type AssignWithSeedParams = {\n /** Public key of the account which will be assigned a new owner */\n accountPubkey: PublicKey;\n /** Base public key to use to derive the address of the assigned account */\n basePubkey: PublicKey;\n /** Seed to use to derive the address of the assigned account */\n seed: string;\n /** Public key of the program to assign as the owner */\n programId: PublicKey;\n};\n\n/**\n * Transfer with seed system transaction params\n */\nexport type TransferWithSeedParams = {\n /** Account that will transfer lamports */\n fromPubkey: PublicKey;\n /** Base public key to use to derive the funding account address */\n basePubkey: PublicKey;\n /** Account that will receive transferred lamports */\n toPubkey: PublicKey;\n /** Amount of lamports to transfer */\n lamports: number;\n /** Seed to use to derive the funding account address */\n seed: string;\n /** Program id to use to derive the funding account address */\n programId: PublicKey;\n};\n\n/**\n * System Instruction class\n */\nexport class SystemInstruction {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Decode a system instruction and retrieve the instruction type.\n */\n static decodeInstructionType(\n instruction: TransactionInstruction,\n ): SystemInstructionType {\n this.checkProgramId(instruction.programId);\n\n const instructionTypeLayout = BufferLayout.u32('instruction');\n const typeIndex = instructionTypeLayout.decode(instruction.data);\n\n let type: SystemInstructionType | undefined;\n for (const [ixType, layout] of Object.entries(SYSTEM_INSTRUCTION_LAYOUTS)) {\n if (layout.index == typeIndex) {\n type = ixType as SystemInstructionType;\n break;\n }\n }\n\n if (!type) {\n throw new Error('Instruction type incorrect; not a SystemInstruction');\n }\n\n return type;\n }\n\n /**\n * Decode a create account system instruction and retrieve the instruction params.\n */\n static decodeCreateAccount(\n instruction: TransactionInstruction,\n ): CreateAccountParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {lamports, space, programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.Create,\n instruction.data,\n );\n\n return {\n fromPubkey: instruction.keys[0].pubkey,\n newAccountPubkey: instruction.keys[1].pubkey,\n lamports,\n space,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode a transfer system instruction and retrieve the instruction params.\n */\n static decodeTransfer(instruction: TransactionInstruction): TransferParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {lamports} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.Transfer,\n instruction.data,\n );\n\n return {\n fromPubkey: instruction.keys[0].pubkey,\n toPubkey: instruction.keys[1].pubkey,\n lamports,\n };\n }\n\n /**\n * Decode a transfer with seed system instruction and retrieve the instruction params.\n */\n static decodeTransferWithSeed(\n instruction: TransactionInstruction,\n ): TransferWithSeedParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n\n const {lamports, seed, programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.TransferWithSeed,\n instruction.data,\n );\n\n return {\n fromPubkey: instruction.keys[0].pubkey,\n basePubkey: instruction.keys[1].pubkey,\n toPubkey: instruction.keys[2].pubkey,\n lamports,\n seed,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode an allocate system instruction and retrieve the instruction params.\n */\n static decodeAllocate(instruction: TransactionInstruction): AllocateParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 1);\n\n const {space} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.Allocate,\n instruction.data,\n );\n\n return {\n accountPubkey: instruction.keys[0].pubkey,\n space,\n };\n }\n\n /**\n * Decode an allocate with seed system instruction and retrieve the instruction params.\n */\n static decodeAllocateWithSeed(\n instruction: TransactionInstruction,\n ): AllocateWithSeedParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 1);\n\n const {base, seed, space, programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.AllocateWithSeed,\n instruction.data,\n );\n\n return {\n accountPubkey: instruction.keys[0].pubkey,\n basePubkey: new PublicKey(base),\n seed,\n space,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode an assign system instruction and retrieve the instruction params.\n */\n static decodeAssign(instruction: TransactionInstruction): AssignParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 1);\n\n const {programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.Assign,\n instruction.data,\n );\n\n return {\n accountPubkey: instruction.keys[0].pubkey,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode an assign with seed system instruction and retrieve the instruction params.\n */\n static decodeAssignWithSeed(\n instruction: TransactionInstruction,\n ): AssignWithSeedParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 1);\n\n const {base, seed, programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.AssignWithSeed,\n instruction.data,\n );\n\n return {\n accountPubkey: instruction.keys[0].pubkey,\n basePubkey: new PublicKey(base),\n seed,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode a create account with seed system instruction and retrieve the instruction params.\n */\n static decodeCreateWithSeed(\n instruction: TransactionInstruction,\n ): CreateAccountWithSeedParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {base, seed, lamports, space, programId} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.CreateWithSeed,\n instruction.data,\n );\n\n return {\n fromPubkey: instruction.keys[0].pubkey,\n newAccountPubkey: instruction.keys[1].pubkey,\n basePubkey: new PublicKey(base),\n seed,\n lamports,\n space,\n programId: new PublicKey(programId),\n };\n }\n\n /**\n * Decode a nonce initialize system instruction and retrieve the instruction params.\n */\n static decodeNonceInitialize(\n instruction: TransactionInstruction,\n ): InitializeNonceParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n\n const {authorized} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.InitializeNonceAccount,\n instruction.data,\n );\n\n return {\n noncePubkey: instruction.keys[0].pubkey,\n authorizedPubkey: new PublicKey(authorized),\n };\n }\n\n /**\n * Decode a nonce advance system instruction and retrieve the instruction params.\n */\n static decodeNonceAdvance(\n instruction: TransactionInstruction,\n ): AdvanceNonceParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n\n decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.AdvanceNonceAccount,\n instruction.data,\n );\n\n return {\n noncePubkey: instruction.keys[0].pubkey,\n authorizedPubkey: instruction.keys[2].pubkey,\n };\n }\n\n /**\n * Decode a nonce withdraw system instruction and retrieve the instruction params.\n */\n static decodeNonceWithdraw(\n instruction: TransactionInstruction,\n ): WithdrawNonceParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 5);\n\n const {lamports} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.WithdrawNonceAccount,\n instruction.data,\n );\n\n return {\n noncePubkey: instruction.keys[0].pubkey,\n toPubkey: instruction.keys[1].pubkey,\n authorizedPubkey: instruction.keys[4].pubkey,\n lamports,\n };\n }\n\n /**\n * Decode a nonce authorize system instruction and retrieve the instruction params.\n */\n static decodeNonceAuthorize(\n instruction: TransactionInstruction,\n ): AuthorizeNonceParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {authorized} = decodeData(\n SYSTEM_INSTRUCTION_LAYOUTS.AuthorizeNonceAccount,\n instruction.data,\n );\n\n return {\n noncePubkey: instruction.keys[0].pubkey,\n authorizedPubkey: instruction.keys[1].pubkey,\n newAuthorizedPubkey: new PublicKey(authorized),\n };\n }\n\n /**\n * @internal\n */\n static checkProgramId(programId: PublicKey) {\n if (!programId.equals(SystemProgram.programId)) {\n throw new Error('invalid instruction; programId is not SystemProgram');\n }\n }\n\n /**\n * @internal\n */\n static checkKeyLength(keys: Array, expectedLength: number) {\n if (keys.length < expectedLength) {\n throw new Error(\n `invalid instruction; found ${keys.length} keys, expected at least ${expectedLength}`,\n );\n }\n }\n}\n\n/**\n * An enumeration of valid SystemInstructionType's\n */\nexport type SystemInstructionType =\n | 'AdvanceNonceAccount'\n | 'Allocate'\n | 'AllocateWithSeed'\n | 'Assign'\n | 'AssignWithSeed'\n | 'AuthorizeNonceAccount'\n | 'Create'\n | 'CreateWithSeed'\n | 'InitializeNonceAccount'\n | 'Transfer'\n | 'TransferWithSeed'\n | 'WithdrawNonceAccount';\n\n/**\n * An enumeration of valid system InstructionType's\n * @internal\n */\nexport const SYSTEM_INSTRUCTION_LAYOUTS: {\n [type in SystemInstructionType]: InstructionType;\n} = Object.freeze({\n Create: {\n index: 0,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n BufferLayout.ns64('space'),\n Layout.publicKey('programId'),\n ]),\n },\n Assign: {\n index: 1,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('programId'),\n ]),\n },\n Transfer: {\n index: 2,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n ]),\n },\n CreateWithSeed: {\n index: 3,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('base'),\n Layout.rustString('seed'),\n BufferLayout.ns64('lamports'),\n BufferLayout.ns64('space'),\n Layout.publicKey('programId'),\n ]),\n },\n AdvanceNonceAccount: {\n index: 4,\n layout: BufferLayout.struct([BufferLayout.u32('instruction')]),\n },\n WithdrawNonceAccount: {\n index: 5,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n ]),\n },\n InitializeNonceAccount: {\n index: 6,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('authorized'),\n ]),\n },\n AuthorizeNonceAccount: {\n index: 7,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('authorized'),\n ]),\n },\n Allocate: {\n index: 8,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('space'),\n ]),\n },\n AllocateWithSeed: {\n index: 9,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('base'),\n Layout.rustString('seed'),\n BufferLayout.ns64('space'),\n Layout.publicKey('programId'),\n ]),\n },\n AssignWithSeed: {\n index: 10,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('base'),\n Layout.rustString('seed'),\n Layout.publicKey('programId'),\n ]),\n },\n TransferWithSeed: {\n index: 11,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n Layout.rustString('seed'),\n Layout.publicKey('programId'),\n ]),\n },\n});\n\n/**\n * Factory class for transactions to interact with the System program\n */\nexport class SystemProgram {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Public key that identifies the System program\n */\n static programId: PublicKey = new PublicKey(\n '11111111111111111111111111111111',\n );\n\n /**\n * Generate a transaction instruction that creates a new account\n */\n static createAccount(params: CreateAccountParams): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.Create;\n const data = encodeData(type, {\n lamports: params.lamports,\n space: params.space,\n programId: toBuffer(params.programId.toBuffer()),\n });\n\n return new TransactionInstruction({\n keys: [\n {pubkey: params.fromPubkey, isSigner: true, isWritable: true},\n {pubkey: params.newAccountPubkey, isSigner: true, isWritable: true},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction instruction that transfers lamports from one account to another\n */\n static transfer(\n params: TransferParams | TransferWithSeedParams,\n ): TransactionInstruction {\n let data;\n let keys;\n if ('basePubkey' in params) {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.TransferWithSeed;\n data = encodeData(type, {\n lamports: params.lamports,\n seed: params.seed,\n programId: toBuffer(params.programId.toBuffer()),\n });\n keys = [\n {pubkey: params.fromPubkey, isSigner: false, isWritable: true},\n {pubkey: params.basePubkey, isSigner: true, isWritable: false},\n {pubkey: params.toPubkey, isSigner: false, isWritable: true},\n ];\n } else {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.Transfer;\n data = encodeData(type, {lamports: params.lamports});\n keys = [\n {pubkey: params.fromPubkey, isSigner: true, isWritable: true},\n {pubkey: params.toPubkey, isSigner: false, isWritable: true},\n ];\n }\n\n return new TransactionInstruction({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction instruction that assigns an account to a program\n */\n static assign(\n params: AssignParams | AssignWithSeedParams,\n ): TransactionInstruction {\n let data;\n let keys;\n if ('basePubkey' in params) {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.AssignWithSeed;\n data = encodeData(type, {\n base: toBuffer(params.basePubkey.toBuffer()),\n seed: params.seed,\n programId: toBuffer(params.programId.toBuffer()),\n });\n keys = [\n {pubkey: params.accountPubkey, isSigner: false, isWritable: true},\n {pubkey: params.basePubkey, isSigner: true, isWritable: false},\n ];\n } else {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.Assign;\n data = encodeData(type, {\n programId: toBuffer(params.programId.toBuffer()),\n });\n keys = [{pubkey: params.accountPubkey, isSigner: true, isWritable: true}];\n }\n\n return new TransactionInstruction({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction instruction that creates a new account at\n * an address generated with `from`, a seed, and programId\n */\n static createAccountWithSeed(\n params: CreateAccountWithSeedParams,\n ): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.CreateWithSeed;\n const data = encodeData(type, {\n base: toBuffer(params.basePubkey.toBuffer()),\n seed: params.seed,\n lamports: params.lamports,\n space: params.space,\n programId: toBuffer(params.programId.toBuffer()),\n });\n let keys = [\n {pubkey: params.fromPubkey, isSigner: true, isWritable: true},\n {pubkey: params.newAccountPubkey, isSigner: false, isWritable: true},\n ];\n if (params.basePubkey != params.fromPubkey) {\n keys.push({pubkey: params.basePubkey, isSigner: true, isWritable: false});\n }\n\n return new TransactionInstruction({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction that creates a new Nonce account\n */\n static createNonceAccount(\n params: CreateNonceAccountParams | CreateNonceAccountWithSeedParams,\n ): Transaction {\n const transaction = new Transaction();\n if ('basePubkey' in params && 'seed' in params) {\n transaction.add(\n SystemProgram.createAccountWithSeed({\n fromPubkey: params.fromPubkey,\n newAccountPubkey: params.noncePubkey,\n basePubkey: params.basePubkey,\n seed: params.seed,\n lamports: params.lamports,\n space: NONCE_ACCOUNT_LENGTH,\n programId: this.programId,\n }),\n );\n } else {\n transaction.add(\n SystemProgram.createAccount({\n fromPubkey: params.fromPubkey,\n newAccountPubkey: params.noncePubkey,\n lamports: params.lamports,\n space: NONCE_ACCOUNT_LENGTH,\n programId: this.programId,\n }),\n );\n }\n\n const initParams = {\n noncePubkey: params.noncePubkey,\n authorizedPubkey: params.authorizedPubkey,\n };\n\n transaction.add(this.nonceInitialize(initParams));\n return transaction;\n }\n\n /**\n * Generate an instruction to initialize a Nonce account\n */\n static nonceInitialize(\n params: InitializeNonceParams,\n ): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.InitializeNonceAccount;\n const data = encodeData(type, {\n authorized: toBuffer(params.authorizedPubkey.toBuffer()),\n });\n const instructionData = {\n keys: [\n {pubkey: params.noncePubkey, isSigner: false, isWritable: true},\n {\n pubkey: SYSVAR_RECENT_BLOCKHASHES_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: SYSVAR_RENT_PUBKEY, isSigner: false, isWritable: false},\n ],\n programId: this.programId,\n data,\n };\n return new TransactionInstruction(instructionData);\n }\n\n /**\n * Generate an instruction to advance the nonce in a Nonce account\n */\n static nonceAdvance(params: AdvanceNonceParams): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.AdvanceNonceAccount;\n const data = encodeData(type);\n const instructionData = {\n keys: [\n {pubkey: params.noncePubkey, isSigner: false, isWritable: true},\n {\n pubkey: SYSVAR_RECENT_BLOCKHASHES_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: params.authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n };\n return new TransactionInstruction(instructionData);\n }\n\n /**\n * Generate a transaction instruction that withdraws lamports from a Nonce account\n */\n static nonceWithdraw(params: WithdrawNonceParams): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.WithdrawNonceAccount;\n const data = encodeData(type, {lamports: params.lamports});\n\n return new TransactionInstruction({\n keys: [\n {pubkey: params.noncePubkey, isSigner: false, isWritable: true},\n {pubkey: params.toPubkey, isSigner: false, isWritable: true},\n {\n pubkey: SYSVAR_RECENT_BLOCKHASHES_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {\n pubkey: SYSVAR_RENT_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: params.authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction instruction that authorizes a new PublicKey as the authority\n * on a Nonce account.\n */\n static nonceAuthorize(params: AuthorizeNonceParams): TransactionInstruction {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.AuthorizeNonceAccount;\n const data = encodeData(type, {\n authorized: toBuffer(params.newAuthorizedPubkey.toBuffer()),\n });\n\n return new TransactionInstruction({\n keys: [\n {pubkey: params.noncePubkey, isSigner: false, isWritable: true},\n {pubkey: params.authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a transaction instruction that allocates space in an account without funding\n */\n static allocate(\n params: AllocateParams | AllocateWithSeedParams,\n ): TransactionInstruction {\n let data;\n let keys;\n if ('basePubkey' in params) {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.AllocateWithSeed;\n data = encodeData(type, {\n base: toBuffer(params.basePubkey.toBuffer()),\n seed: params.seed,\n space: params.space,\n programId: toBuffer(params.programId.toBuffer()),\n });\n keys = [\n {pubkey: params.accountPubkey, isSigner: false, isWritable: true},\n {pubkey: params.basePubkey, isSigner: true, isWritable: false},\n ];\n } else {\n const type = SYSTEM_INSTRUCTION_LAYOUTS.Allocate;\n data = encodeData(type, {\n space: params.space,\n });\n keys = [{pubkey: params.accountPubkey, isSigner: true, isWritable: true}];\n }\n\n return new TransactionInstruction({\n keys,\n programId: this.programId,\n data,\n });\n }\n}\n","import {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\n\nimport {PublicKey} from './publickey';\nimport {Transaction, PACKET_DATA_SIZE} from './transaction';\nimport {SYSVAR_RENT_PUBKEY} from './sysvar';\nimport {sendAndConfirmTransaction} from './util/send-and-confirm-transaction';\nimport {sleep} from './util/sleep';\nimport type {Connection} from './connection';\nimport type {Signer} from './keypair';\nimport {SystemProgram} from './system-program';\n\n// Keep program chunks under PACKET_DATA_SIZE, leaving enough room for the\n// rest of the Transaction fields\n//\n// TODO: replace 300 with a proper constant for the size of the other\n// Transaction fields\nconst CHUNK_SIZE = PACKET_DATA_SIZE - 300;\n\n/**\n * Program loader interface\n */\nexport class Loader {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Amount of program data placed in each load Transaction\n */\n static chunkSize: number = CHUNK_SIZE;\n\n /**\n * Minimum number of signatures required to load a program not including\n * retries\n *\n * Can be used to calculate transaction fees\n */\n static getMinNumSignatures(dataLength: number): number {\n return (\n 2 * // Every transaction requires two signatures (payer + program)\n (Math.ceil(dataLength / Loader.chunkSize) +\n 1 + // Add one for Create transaction\n 1) // Add one for Finalize transaction\n );\n }\n\n /**\n * Loads a generic program\n *\n * @param connection The connection to use\n * @param payer System account that pays to load the program\n * @param program Account to load the program into\n * @param programId Public key that identifies the loader\n * @param data Program octets\n * @return true if program was loaded successfully, false if program was already loaded\n */\n static async load(\n connection: Connection,\n payer: Signer,\n program: Signer,\n programId: PublicKey,\n data: Buffer | Uint8Array | Array,\n ): Promise {\n {\n const balanceNeeded = await connection.getMinimumBalanceForRentExemption(\n data.length,\n );\n\n // Fetch program account info to check if it has already been created\n const programInfo = await connection.getAccountInfo(\n program.publicKey,\n 'confirmed',\n );\n\n let transaction: Transaction | null = null;\n if (programInfo !== null) {\n if (programInfo.executable) {\n console.error('Program load failed, account is already executable');\n return false;\n }\n\n if (programInfo.data.length !== data.length) {\n transaction = transaction || new Transaction();\n transaction.add(\n SystemProgram.allocate({\n accountPubkey: program.publicKey,\n space: data.length,\n }),\n );\n }\n\n if (!programInfo.owner.equals(programId)) {\n transaction = transaction || new Transaction();\n transaction.add(\n SystemProgram.assign({\n accountPubkey: program.publicKey,\n programId,\n }),\n );\n }\n\n if (programInfo.lamports < balanceNeeded) {\n transaction = transaction || new Transaction();\n transaction.add(\n SystemProgram.transfer({\n fromPubkey: payer.publicKey,\n toPubkey: program.publicKey,\n lamports: balanceNeeded - programInfo.lamports,\n }),\n );\n }\n } else {\n transaction = new Transaction().add(\n SystemProgram.createAccount({\n fromPubkey: payer.publicKey,\n newAccountPubkey: program.publicKey,\n lamports: balanceNeeded > 0 ? balanceNeeded : 1,\n space: data.length,\n programId,\n }),\n );\n }\n\n // If the account is already created correctly, skip this step\n // and proceed directly to loading instructions\n if (transaction !== null) {\n await sendAndConfirmTransaction(\n connection,\n transaction,\n [payer, program],\n {\n commitment: 'confirmed',\n },\n );\n }\n }\n\n const dataLayout = BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.u32('offset'),\n BufferLayout.u32('bytesLength'),\n BufferLayout.u32('bytesLengthPadding'),\n BufferLayout.seq(\n BufferLayout.u8('byte'),\n BufferLayout.offset(BufferLayout.u32(), -8),\n 'bytes',\n ),\n ]);\n\n const chunkSize = Loader.chunkSize;\n let offset = 0;\n let array = data;\n let transactions = [];\n while (array.length > 0) {\n const bytes = array.slice(0, chunkSize);\n const data = Buffer.alloc(chunkSize + 16);\n dataLayout.encode(\n {\n instruction: 0, // Load instruction\n offset,\n bytes,\n },\n data,\n );\n\n const transaction = new Transaction().add({\n keys: [{pubkey: program.publicKey, isSigner: true, isWritable: true}],\n programId,\n data,\n });\n transactions.push(\n sendAndConfirmTransaction(connection, transaction, [payer, program], {\n commitment: 'confirmed',\n }),\n );\n\n // Delay between sends in an attempt to reduce rate limit errors\n if (connection._rpcEndpoint.includes('solana.com')) {\n const REQUESTS_PER_SECOND = 4;\n await sleep(1000 / REQUESTS_PER_SECOND);\n }\n\n offset += chunkSize;\n array = array.slice(chunkSize);\n }\n await Promise.all(transactions);\n\n // Finalize the account loaded with program data for execution\n {\n const dataLayout = BufferLayout.struct([BufferLayout.u32('instruction')]);\n\n const data = Buffer.alloc(dataLayout.span);\n dataLayout.encode(\n {\n instruction: 1, // Finalize instruction\n },\n data,\n );\n\n const transaction = new Transaction().add({\n keys: [\n {pubkey: program.publicKey, isSigner: true, isWritable: true},\n {pubkey: SYSVAR_RENT_PUBKEY, isSigner: false, isWritable: false},\n ],\n programId,\n data,\n });\n await sendAndConfirmTransaction(\n connection,\n transaction,\n [payer, program],\n {\n commitment: 'confirmed',\n },\n );\n }\n\n // success\n return true;\n }\n}\n","import type {Buffer} from 'buffer';\n\nimport {PublicKey} from './publickey';\nimport {Loader} from './loader';\nimport type {Connection} from './connection';\nimport type {Signer} from './keypair';\n\nexport const BPF_LOADER_PROGRAM_ID = new PublicKey(\n 'BPFLoader2111111111111111111111111111111111',\n);\n\n/**\n * Factory class for transactions to interact with a program loader\n */\nexport class BpfLoader {\n /**\n * Minimum number of signatures required to load a program not including\n * retries\n *\n * Can be used to calculate transaction fees\n */\n static getMinNumSignatures(dataLength: number): number {\n return Loader.getMinNumSignatures(dataLength);\n }\n\n /**\n * Load a BPF program\n *\n * @param connection The connection to use\n * @param payer Account that will pay program loading fees\n * @param program Account to load the program into\n * @param elf The entire ELF containing the BPF program\n * @param loaderProgramId The program id of the BPF loader to use\n * @return true if program was loaded successfully, false if program was already loaded\n */\n static load(\n connection: Connection,\n payer: Signer,\n program: Signer,\n elf: Buffer | Uint8Array | Array,\n loaderProgramId: PublicKey,\n ): Promise {\n return Loader.load(connection, payer, program, loaderProgramId, elf);\n }\n}\n","var global = typeof self !== 'undefined' ? self : this;\nvar __self__ = (function () {\nfunction F() {\nthis.fetch = false;\nthis.DOMException = global.DOMException\n}\nF.prototype = global;\nreturn new F();\n})();\n(function(self) {\n\nvar irrelevant = (function (exports) {\n\n var support = {\n searchParams: 'URLSearchParams' in self,\n iterable: 'Symbol' in self && 'iterator' in Symbol,\n blob:\n 'FileReader' in self &&\n 'Blob' in self &&\n (function() {\n try {\n new Blob();\n return true\n } catch (e) {\n return false\n }\n })(),\n formData: 'FormData' in self,\n arrayBuffer: 'ArrayBuffer' in self\n };\n\n function isDataView(obj) {\n return obj && DataView.prototype.isPrototypeOf(obj)\n }\n\n if (support.arrayBuffer) {\n var viewClasses = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]'\n ];\n\n var isArrayBufferView =\n ArrayBuffer.isView ||\n function(obj) {\n return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n };\n }\n\n function normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name);\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~]/i.test(name)) {\n throw new TypeError('Invalid character in header field name')\n }\n return name.toLowerCase()\n }\n\n function normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value);\n }\n return value\n }\n\n // Build a destructive iterator for the value list\n function iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift();\n return {done: value === undefined, value: value}\n }\n };\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n };\n }\n\n return iterator\n }\n\n function Headers(headers) {\n this.map = {};\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value);\n }, this);\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n this.append(header[0], header[1]);\n }, this);\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name]);\n }, this);\n }\n }\n\n Headers.prototype.append = function(name, value) {\n name = normalizeName(name);\n value = normalizeValue(value);\n var oldValue = this.map[name];\n this.map[name] = oldValue ? oldValue + ', ' + value : value;\n };\n\n Headers.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)];\n };\n\n Headers.prototype.get = function(name) {\n name = normalizeName(name);\n return this.has(name) ? this.map[name] : null\n };\n\n Headers.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n };\n\n Headers.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value);\n };\n\n Headers.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this);\n }\n }\n };\n\n Headers.prototype.keys = function() {\n var items = [];\n this.forEach(function(value, name) {\n items.push(name);\n });\n return iteratorFor(items)\n };\n\n Headers.prototype.values = function() {\n var items = [];\n this.forEach(function(value) {\n items.push(value);\n });\n return iteratorFor(items)\n };\n\n Headers.prototype.entries = function() {\n var items = [];\n this.forEach(function(value, name) {\n items.push([name, value]);\n });\n return iteratorFor(items)\n };\n\n if (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries;\n }\n\n function consumed(body) {\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true;\n }\n\n function fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result);\n };\n reader.onerror = function() {\n reject(reader.error);\n };\n })\n }\n\n function readBlobAsArrayBuffer(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsArrayBuffer(blob);\n return promise\n }\n\n function readBlobAsText(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsText(blob);\n return promise\n }\n\n function readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf);\n var chars = new Array(view.length);\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i]);\n }\n return chars.join('')\n }\n\n function bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength);\n view.set(new Uint8Array(buf));\n return view.buffer\n }\n }\n\n function Body() {\n this.bodyUsed = false;\n\n this._initBody = function(body) {\n this._bodyInit = body;\n if (!body) {\n this._bodyText = '';\n } else if (typeof body === 'string') {\n this._bodyText = body;\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body;\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body;\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString();\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer);\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer]);\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body);\n } else {\n this._bodyText = body = Object.prototype.toString.call(body);\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8');\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type);\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8');\n }\n }\n };\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this);\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n };\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n return consumed(this) || Promise.resolve(this._bodyArrayBuffer)\n } else {\n return this.blob().then(readBlobAsArrayBuffer)\n }\n };\n }\n\n this.text = function() {\n var rejected = consumed(this);\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n };\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n };\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n };\n\n return this\n }\n\n // HTTP methods whose capitalization should be normalized\n var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT'];\n\n function normalizeMethod(method) {\n var upcased = method.toUpperCase();\n return methods.indexOf(upcased) > -1 ? upcased : method\n }\n\n function Request(input, options) {\n options = options || {};\n var body = options.body;\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url;\n this.credentials = input.credentials;\n if (!options.headers) {\n this.headers = new Headers(input.headers);\n }\n this.method = input.method;\n this.mode = input.mode;\n this.signal = input.signal;\n if (!body && input._bodyInit != null) {\n body = input._bodyInit;\n input.bodyUsed = true;\n }\n } else {\n this.url = String(input);\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin';\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers);\n }\n this.method = normalizeMethod(options.method || this.method || 'GET');\n this.mode = options.mode || this.mode || null;\n this.signal = options.signal || this.signal;\n this.referrer = null;\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body);\n }\n\n Request.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n };\n\n function decode(body) {\n var form = new FormData();\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=');\n var name = split.shift().replace(/\\+/g, ' ');\n var value = split.join('=').replace(/\\+/g, ' ');\n form.append(decodeURIComponent(name), decodeURIComponent(value));\n }\n });\n return form\n }\n\n function parseHeaders(rawHeaders) {\n var headers = new Headers();\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ');\n preProcessedHeaders.split(/\\r?\\n/).forEach(function(line) {\n var parts = line.split(':');\n var key = parts.shift().trim();\n if (key) {\n var value = parts.join(':').trim();\n headers.append(key, value);\n }\n });\n return headers\n }\n\n Body.call(Request.prototype);\n\n function Response(bodyInit, options) {\n if (!options) {\n options = {};\n }\n\n this.type = 'default';\n this.status = options.status === undefined ? 200 : options.status;\n this.ok = this.status >= 200 && this.status < 300;\n this.statusText = 'statusText' in options ? options.statusText : 'OK';\n this.headers = new Headers(options.headers);\n this.url = options.url || '';\n this._initBody(bodyInit);\n }\n\n Body.call(Response.prototype);\n\n Response.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n };\n\n Response.error = function() {\n var response = new Response(null, {status: 0, statusText: ''});\n response.type = 'error';\n return response\n };\n\n var redirectStatuses = [301, 302, 303, 307, 308];\n\n Response.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n };\n\n exports.DOMException = self.DOMException;\n try {\n new exports.DOMException();\n } catch (err) {\n exports.DOMException = function(message, name) {\n this.message = message;\n this.name = name;\n var error = Error(message);\n this.stack = error.stack;\n };\n exports.DOMException.prototype = Object.create(Error.prototype);\n exports.DOMException.prototype.constructor = exports.DOMException;\n }\n\n function fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init);\n\n if (request.signal && request.signal.aborted) {\n return reject(new exports.DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest();\n\n function abortXhr() {\n xhr.abort();\n }\n\n xhr.onload = function() {\n var options = {\n status: xhr.status,\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n };\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL');\n var body = 'response' in xhr ? xhr.response : xhr.responseText;\n resolve(new Response(body, options));\n };\n\n xhr.onerror = function() {\n reject(new TypeError('Network request failed'));\n };\n\n xhr.ontimeout = function() {\n reject(new TypeError('Network request failed'));\n };\n\n xhr.onabort = function() {\n reject(new exports.DOMException('Aborted', 'AbortError'));\n };\n\n xhr.open(request.method, request.url, true);\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true;\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false;\n }\n\n if ('responseType' in xhr && support.blob) {\n xhr.responseType = 'blob';\n }\n\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value);\n });\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr);\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr);\n }\n };\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit);\n })\n }\n\n fetch.polyfill = true;\n\n if (!self.fetch) {\n self.fetch = fetch;\n self.Headers = Headers;\n self.Request = Request;\n self.Response = Response;\n }\n\n exports.Headers = Headers;\n exports.Request = Request;\n exports.Response = Response;\n exports.fetch = fetch;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n return exports;\n\n}({}));\n})(__self__);\n__self__.fetch.ponyfill = true;\n// Remove \"polyfill\" property added by whatwg-fetch\ndelete __self__.fetch.polyfill;\n// Choose between native implementation (global) or custom implementation (__self__)\n// var ctx = global.fetch ? global : __self__;\nvar ctx = __self__; // this line disable service worker support temporarily\nexports = ctx.fetch // To enable: import fetch from 'cross-fetch'\nexports.default = ctx.fetch // For TypeScript consumers without esModuleInterop.\nexports.fetch = ctx.fetch // To enable: import {fetch} from 'cross-fetch'\nexports.Headers = ctx.Headers\nexports.Request = ctx.Request\nexports.Response = ctx.Response\nmodule.exports = exports\n","const MINIMUM_SLOT_PER_EPOCH = 32;\n\n// Returns the number of trailing zeros in the binary representation of self.\nfunction trailingZeros(n: number) {\n let trailingZeros = 0;\n while (n > 1) {\n n /= 2;\n trailingZeros++;\n }\n return trailingZeros;\n}\n\n// Returns the smallest power of two greater than or equal to n\nfunction nextPowerOfTwo(n: number) {\n if (n === 0) return 1;\n n--;\n n |= n >> 1;\n n |= n >> 2;\n n |= n >> 4;\n n |= n >> 8;\n n |= n >> 16;\n n |= n >> 32;\n return n + 1;\n}\n\n/**\n * Epoch schedule\n * (see https://docs.solana.com/terminology#epoch)\n * Can be retrieved with the {@link connection.getEpochSchedule} method\n */\nexport class EpochSchedule {\n /** The maximum number of slots in each epoch */\n public slotsPerEpoch: number;\n /** The number of slots before beginning of an epoch to calculate a leader schedule for that epoch */\n public leaderScheduleSlotOffset: number;\n /** Indicates whether epochs start short and grow */\n public warmup: boolean;\n /** The first epoch with `slotsPerEpoch` slots */\n public firstNormalEpoch: number;\n /** The first slot of `firstNormalEpoch` */\n public firstNormalSlot: number;\n\n constructor(\n slotsPerEpoch: number,\n leaderScheduleSlotOffset: number,\n warmup: boolean,\n firstNormalEpoch: number,\n firstNormalSlot: number,\n ) {\n this.slotsPerEpoch = slotsPerEpoch;\n this.leaderScheduleSlotOffset = leaderScheduleSlotOffset;\n this.warmup = warmup;\n this.firstNormalEpoch = firstNormalEpoch;\n this.firstNormalSlot = firstNormalSlot;\n }\n\n getEpoch(slot: number): number {\n return this.getEpochAndSlotIndex(slot)[0];\n }\n\n getEpochAndSlotIndex(slot: number): [number, number] {\n if (slot < this.firstNormalSlot) {\n const epoch =\n trailingZeros(nextPowerOfTwo(slot + MINIMUM_SLOT_PER_EPOCH + 1)) -\n trailingZeros(MINIMUM_SLOT_PER_EPOCH) -\n 1;\n\n const epochLen = this.getSlotsInEpoch(epoch);\n const slotIndex = slot - (epochLen - MINIMUM_SLOT_PER_EPOCH);\n return [epoch, slotIndex];\n } else {\n const normalSlotIndex = slot - this.firstNormalSlot;\n const normalEpochIndex = Math.floor(normalSlotIndex / this.slotsPerEpoch);\n const epoch = this.firstNormalEpoch + normalEpochIndex;\n const slotIndex = normalSlotIndex % this.slotsPerEpoch;\n return [epoch, slotIndex];\n }\n }\n\n getFirstSlotInEpoch(epoch: number): number {\n if (epoch <= this.firstNormalEpoch) {\n return (Math.pow(2, epoch) - 1) * MINIMUM_SLOT_PER_EPOCH;\n } else {\n return (\n (epoch - this.firstNormalEpoch) * this.slotsPerEpoch +\n this.firstNormalSlot\n );\n }\n }\n\n getLastSlotInEpoch(epoch: number): number {\n return this.getFirstSlotInEpoch(epoch) + this.getSlotsInEpoch(epoch) - 1;\n }\n\n getSlotsInEpoch(epoch: number) {\n if (epoch < this.firstNormalEpoch) {\n return Math.pow(2, epoch + trailingZeros(MINIMUM_SLOT_PER_EPOCH));\n } else {\n return this.slotsPerEpoch;\n }\n }\n}\n","export class SendTransactionError extends Error {\n logs: string[] | undefined;\n\n constructor(message: string, logs?: string[]) {\n super(message);\n\n this.logs = logs;\n }\n}\n","export function promiseTimeout(\n promise: Promise,\n timeoutMs: number,\n): Promise {\n let timeoutId: ReturnType;\n const timeoutPromise: Promise = new Promise(resolve => {\n timeoutId = setTimeout(() => resolve(null), timeoutMs);\n });\n\n return Promise.race([promise, timeoutPromise]).then((result: T | null) => {\n clearTimeout(timeoutId);\n return result;\n });\n}\n","import bs58 from 'bs58';\nimport {Buffer} from 'buffer';\nimport fetch from 'cross-fetch';\nimport type {Response} from 'cross-fetch';\nimport {\n type as pick,\n number,\n string,\n array,\n boolean,\n literal,\n record,\n union,\n optional,\n nullable,\n coerce,\n instance,\n create,\n tuple,\n unknown,\n any,\n} from 'superstruct';\nimport type {Struct} from 'superstruct';\nimport {Client as RpcWebSocketClient} from 'rpc-websockets';\nimport RpcClient from 'jayson/lib/client/browser';\nimport {IWSRequestParams} from 'rpc-websockets/dist/lib/client';\n\nimport {AgentManager} from './agent-manager';\nimport {EpochSchedule} from './epoch-schedule';\nimport {SendTransactionError} from './errors';\nimport {NonceAccount} from './nonce-account';\nimport {PublicKey} from './publickey';\nimport {Signer} from './keypair';\nimport {MS_PER_SLOT} from './timing';\nimport {Transaction} from './transaction';\nimport {Message} from './message';\nimport assert from './util/assert';\nimport {sleep} from './util/sleep';\nimport {promiseTimeout} from './util/promise-timeout';\nimport {toBuffer} from './util/to-buffer';\nimport {makeWebsocketUrl} from './util/url';\nimport type {Blockhash} from './blockhash';\nimport type {FeeCalculator} from './fee-calculator';\nimport type {TransactionSignature} from './transaction';\nimport type {CompiledInstruction} from './message';\n\nconst PublicKeyFromString = coerce(\n instance(PublicKey),\n string(),\n value => new PublicKey(value),\n);\n\nconst RawAccountDataResult = tuple([string(), literal('base64')]);\n\nconst BufferFromRawAccountData = coerce(\n instance(Buffer),\n RawAccountDataResult,\n value => Buffer.from(value[0], 'base64'),\n);\n\n/**\n * Attempt to use a recent blockhash for up to 30 seconds\n * @internal\n */\nexport const BLOCKHASH_CACHE_TIMEOUT_MS = 30 * 1000;\n\ntype RpcRequest = (methodName: string, args: Array) => any;\n\ntype RpcBatchRequest = (requests: RpcParams[]) => any;\n\n/**\n * @internal\n */\nexport type RpcParams = {\n methodName: string;\n args: Array;\n};\n\nexport type TokenAccountsFilter =\n | {\n mint: PublicKey;\n }\n | {\n programId: PublicKey;\n };\n\n/**\n * Extra contextual information for RPC responses\n */\nexport type Context = {\n slot: number;\n};\n\n/**\n * Options for sending transactions\n */\nexport type SendOptions = {\n /** disable transaction verification step */\n skipPreflight?: boolean;\n /** preflight commitment level */\n preflightCommitment?: Commitment;\n};\n\n/**\n * Options for confirming transactions\n */\nexport type ConfirmOptions = {\n /** disable transaction verification step */\n skipPreflight?: boolean;\n /** desired commitment level */\n commitment?: Commitment;\n /** preflight commitment level */\n preflightCommitment?: Commitment;\n};\n\n/**\n * Options for getConfirmedSignaturesForAddress2\n */\nexport type ConfirmedSignaturesForAddress2Options = {\n /**\n * Start searching backwards from this transaction signature.\n * @remark If not provided the search starts from the highest max confirmed block.\n */\n before?: TransactionSignature;\n /** Search until this transaction signature is reached, if found before `limit`. */\n until?: TransactionSignature;\n /** Maximum transaction signatures to return (between 1 and 1,000, default: 1,000). */\n limit?: number;\n};\n\n/**\n * Options for getSignaturesForAddress\n */\nexport type SignaturesForAddressOptions = {\n /**\n * Start searching backwards from this transaction signature.\n * @remark If not provided the search starts from the highest max confirmed block.\n */\n before?: TransactionSignature;\n /** Search until this transaction signature is reached, if found before `limit`. */\n until?: TransactionSignature;\n /** Maximum transaction signatures to return (between 1 and 1,000, default: 1,000). */\n limit?: number;\n};\n\n/**\n * RPC Response with extra contextual information\n */\nexport type RpcResponseAndContext = {\n /** response context */\n context: Context;\n /** response value */\n value: T;\n};\n\n/**\n * @internal\n */\nfunction createRpcResult(result: Struct) {\n return union([\n pick({\n jsonrpc: literal('2.0'),\n id: string(),\n result,\n }),\n pick({\n jsonrpc: literal('2.0'),\n id: string(),\n error: pick({\n code: unknown(),\n message: string(),\n data: optional(any()),\n }),\n }),\n ]);\n}\n\nconst UnknownRpcResult = createRpcResult(unknown());\n\n/**\n * @internal\n */\nfunction jsonRpcResult(schema: Struct) {\n return coerce(createRpcResult(schema), UnknownRpcResult, value => {\n if ('error' in value) {\n return value;\n } else {\n return {\n ...value,\n result: create(value.result, schema),\n };\n }\n });\n}\n\n/**\n * @internal\n */\nfunction jsonRpcResultAndContext(value: Struct) {\n return jsonRpcResult(\n pick({\n context: pick({\n slot: number(),\n }),\n value,\n }),\n );\n}\n\n/**\n * @internal\n */\nfunction notificationResultAndContext(value: Struct) {\n return pick({\n context: pick({\n slot: number(),\n }),\n value,\n });\n}\n\n/**\n * The level of commitment desired when querying state\n *
\n *   'processed': Query the most recent block which has reached 1 confirmation by the connected node\n *   'confirmed': Query the most recent block which has reached 1 confirmation by the cluster\n *   'finalized': Query the most recent block which has been finalized by the cluster\n * 
\n */\nexport type Commitment =\n | 'processed'\n | 'confirmed'\n | 'finalized'\n | 'recent' // Deprecated as of v1.5.5\n | 'single' // Deprecated as of v1.5.5\n | 'singleGossip' // Deprecated as of v1.5.5\n | 'root' // Deprecated as of v1.5.5\n | 'max'; // Deprecated as of v1.5.5\n\n/**\n * A subset of Commitment levels, which are at least optimistically confirmed\n *
\n *   'confirmed': Query the most recent block which has reached 1 confirmation by the cluster\n *   'finalized': Query the most recent block which has been finalized by the cluster\n * 
\n */\nexport type Finality = 'confirmed' | 'finalized';\n\n/**\n * Filter for largest accounts query\n *
\n *   'circulating':    Return the largest accounts that are part of the circulating supply\n *   'nonCirculating': Return the largest accounts that are not part of the circulating supply\n * 
\n */\nexport type LargestAccountsFilter = 'circulating' | 'nonCirculating';\n\n/**\n * Configuration object for changing `getLargestAccounts` query behavior\n */\nexport type GetLargestAccountsConfig = {\n /** The level of commitment desired */\n commitment?: Commitment;\n /** Filter largest accounts by whether they are part of the circulating supply */\n filter?: LargestAccountsFilter;\n};\n\n/**\n * Configuration object for changing `getSupply` request behavior\n */\nexport type GetSupplyConfig = {\n /** The level of commitment desired */\n commitment?: Commitment;\n /** Exclude non circulating accounts list from response */\n excludeNonCirculatingAccountsList?: boolean;\n};\n\n/**\n * Configuration object for changing query behavior\n */\nexport type SignatureStatusConfig = {\n /** enable searching status history, not needed for recent transactions */\n searchTransactionHistory: boolean;\n};\n\n/**\n * Information describing a cluster node\n */\nexport type ContactInfo = {\n /** Identity public key of the node */\n pubkey: string;\n /** Gossip network address for the node */\n gossip: string | null;\n /** TPU network address for the node (null if not available) */\n tpu: string | null;\n /** JSON RPC network address for the node (null if not available) */\n rpc: string | null;\n /** Software version of the node (null if not available) */\n version: string | null;\n};\n\n/**\n * Information describing a vote account\n */\nexport type VoteAccountInfo = {\n /** Public key of the vote account */\n votePubkey: string;\n /** Identity public key of the node voting with this account */\n nodePubkey: string;\n /** The stake, in lamports, delegated to this vote account and activated */\n activatedStake: number;\n /** Whether the vote account is staked for this epoch */\n epochVoteAccount: boolean;\n /** Recent epoch voting credit history for this voter */\n epochCredits: Array<[number, number, number]>;\n /** A percentage (0-100) of rewards payout owed to the voter */\n commission: number;\n /** Most recent slot voted on by this vote account */\n lastVote: number;\n};\n\n/**\n * A collection of cluster vote accounts\n */\nexport type VoteAccountStatus = {\n /** Active vote accounts */\n current: Array;\n /** Inactive vote accounts */\n delinquent: Array;\n};\n\n/**\n * Network Inflation\n * (see https://docs.solana.com/implemented-proposals/ed_overview)\n */\nexport type InflationGovernor = {\n foundation: number;\n foundationTerm: number;\n initial: number;\n taper: number;\n terminal: number;\n};\n\nconst GetInflationGovernorResult = pick({\n foundation: number(),\n foundationTerm: number(),\n initial: number(),\n taper: number(),\n terminal: number(),\n});\n\n/**\n * The inflation reward for an epoch\n */\nexport type InflationReward = {\n /** epoch for which the reward occurs */\n epoch: number;\n /** the slot in which the rewards are effective */\n effectiveSlot: number;\n /** reward amount in lamports */\n amount: number;\n /** post balance of the account in lamports */\n postBalance: number;\n};\n\n/**\n * Expected JSON RPC response for the \"getInflationReward\" message\n */\nconst GetInflationRewardResult = jsonRpcResult(\n array(\n nullable(\n pick({\n epoch: number(),\n effectiveSlot: number(),\n amount: number(),\n postBalance: number(),\n }),\n ),\n ),\n);\n\n/**\n * Information about the current epoch\n */\nexport type EpochInfo = {\n epoch: number;\n slotIndex: number;\n slotsInEpoch: number;\n absoluteSlot: number;\n blockHeight?: number;\n transactionCount?: number;\n};\n\nconst GetEpochInfoResult = pick({\n epoch: number(),\n slotIndex: number(),\n slotsInEpoch: number(),\n absoluteSlot: number(),\n blockHeight: optional(number()),\n transactionCount: optional(number()),\n});\n\nconst GetEpochScheduleResult = pick({\n slotsPerEpoch: number(),\n leaderScheduleSlotOffset: number(),\n warmup: boolean(),\n firstNormalEpoch: number(),\n firstNormalSlot: number(),\n});\n\n/**\n * Leader schedule\n * (see https://docs.solana.com/terminology#leader-schedule)\n */\nexport type LeaderSchedule = {\n [address: string]: number[];\n};\n\nconst GetLeaderScheduleResult = record(string(), array(number()));\n\n/**\n * Transaction error or null\n */\nconst TransactionErrorResult = nullable(union([pick({}), string()]));\n\n/**\n * Signature status for a transaction\n */\nconst SignatureStatusResult = pick({\n err: TransactionErrorResult,\n});\n\n/**\n * Transaction signature received notification\n */\nconst SignatureReceivedResult = literal('receivedSignature');\n\n/**\n * Version info for a node\n */\nexport type Version = {\n /** Version of solana-core */\n 'solana-core': string;\n 'feature-set'?: number;\n};\n\nconst VersionResult = pick({\n 'solana-core': string(),\n 'feature-set': optional(number()),\n});\n\nexport type SimulatedTransactionAccountInfo = {\n /** `true` if this account's data contains a loaded program */\n executable: boolean;\n /** Identifier of the program that owns the account */\n owner: string;\n /** Number of lamports assigned to the account */\n lamports: number;\n /** Optional data assigned to the account */\n data: string[];\n /** Optional rent epoch info for account */\n rentEpoch?: number;\n};\n\nexport type SimulatedTransactionResponse = {\n err: TransactionError | string | null;\n logs: Array | null;\n accounts?: SimulatedTransactionAccountInfo[] | null;\n unitsConsumed?: number;\n};\n\nconst SimulatedTransactionResponseStruct = jsonRpcResultAndContext(\n pick({\n err: nullable(union([pick({}), string()])),\n logs: nullable(array(string())),\n accounts: optional(\n nullable(\n array(\n pick({\n executable: boolean(),\n owner: string(),\n lamports: number(),\n data: array(string()),\n rentEpoch: optional(number()),\n }),\n ),\n ),\n ),\n unitsConsumed: optional(number()),\n }),\n);\n\nexport type ParsedInnerInstruction = {\n index: number;\n instructions: (ParsedInstruction | PartiallyDecodedInstruction)[];\n};\n\nexport type TokenBalance = {\n accountIndex: number;\n mint: string;\n owner?: string;\n uiTokenAmount: TokenAmount;\n};\n\n/**\n * Metadata for a parsed confirmed transaction on the ledger\n */\nexport type ParsedConfirmedTransactionMeta = {\n /** The fee charged for processing the transaction */\n fee: number;\n /** An array of cross program invoked parsed instructions */\n innerInstructions?: ParsedInnerInstruction[] | null;\n /** The balances of the transaction accounts before processing */\n preBalances: Array;\n /** The balances of the transaction accounts after processing */\n postBalances: Array;\n /** An array of program log messages emitted during a transaction */\n logMessages?: Array | null;\n /** The token balances of the transaction accounts before processing */\n preTokenBalances?: Array | null;\n /** The token balances of the transaction accounts after processing */\n postTokenBalances?: Array | null;\n /** The error result of transaction processing */\n err: TransactionError | null;\n};\n\nexport type CompiledInnerInstruction = {\n index: number;\n instructions: CompiledInstruction[];\n};\n\n/**\n * Metadata for a confirmed transaction on the ledger\n */\nexport type ConfirmedTransactionMeta = {\n /** The fee charged for processing the transaction */\n fee: number;\n /** An array of cross program invoked instructions */\n innerInstructions?: CompiledInnerInstruction[] | null;\n /** The balances of the transaction accounts before processing */\n preBalances: Array;\n /** The balances of the transaction accounts after processing */\n postBalances: Array;\n /** An array of program log messages emitted during a transaction */\n logMessages?: Array | null;\n /** The token balances of the transaction accounts before processing */\n preTokenBalances?: Array | null;\n /** The token balances of the transaction accounts after processing */\n postTokenBalances?: Array | null;\n /** The error result of transaction processing */\n err: TransactionError | null;\n};\n\n/**\n * A processed transaction from the RPC API\n */\nexport type TransactionResponse = {\n /** The slot during which the transaction was processed */\n slot: number;\n /** The transaction */\n transaction: {\n /** The transaction message */\n message: Message;\n /** The transaction signatures */\n signatures: string[];\n };\n /** Metadata produced from the transaction */\n meta: ConfirmedTransactionMeta | null;\n /** The unix timestamp of when the transaction was processed */\n blockTime?: number | null;\n};\n\n/**\n * A confirmed transaction on the ledger\n */\nexport type ConfirmedTransaction = {\n /** The slot during which the transaction was processed */\n slot: number;\n /** The details of the transaction */\n transaction: Transaction;\n /** Metadata produced from the transaction */\n meta: ConfirmedTransactionMeta | null;\n /** The unix timestamp of when the transaction was processed */\n blockTime?: number | null;\n};\n\n/**\n * A partially decoded transaction instruction\n */\nexport type PartiallyDecodedInstruction = {\n /** Program id called by this instruction */\n programId: PublicKey;\n /** Public keys of accounts passed to this instruction */\n accounts: Array;\n /** Raw base-58 instruction data */\n data: string;\n};\n\n/**\n * A parsed transaction message account\n */\nexport type ParsedMessageAccount = {\n /** Public key of the account */\n pubkey: PublicKey;\n /** Indicates if the account signed the transaction */\n signer: boolean;\n /** Indicates if the account is writable for this transaction */\n writable: boolean;\n};\n\n/**\n * A parsed transaction instruction\n */\nexport type ParsedInstruction = {\n /** Name of the program for this instruction */\n program: string;\n /** ID of the program for this instruction */\n programId: PublicKey;\n /** Parsed instruction info */\n parsed: any;\n};\n\n/**\n * A parsed transaction message\n */\nexport type ParsedMessage = {\n /** Accounts used in the instructions */\n accountKeys: ParsedMessageAccount[];\n /** The atomically executed instructions for the transaction */\n instructions: (ParsedInstruction | PartiallyDecodedInstruction)[];\n /** Recent blockhash */\n recentBlockhash: string;\n};\n\n/**\n * A parsed transaction\n */\nexport type ParsedTransaction = {\n /** Signatures for the transaction */\n signatures: Array;\n /** Message of the transaction */\n message: ParsedMessage;\n};\n\n/**\n * A parsed and confirmed transaction on the ledger\n */\nexport type ParsedConfirmedTransaction = {\n /** The slot during which the transaction was processed */\n slot: number;\n /** The details of the transaction */\n transaction: ParsedTransaction;\n /** Metadata produced from the transaction */\n meta: ParsedConfirmedTransactionMeta | null;\n /** The unix timestamp of when the transaction was processed */\n blockTime?: number | null;\n};\n\n/**\n * A processed block fetched from the RPC API\n */\nexport type BlockResponse = {\n /** Blockhash of this block */\n blockhash: Blockhash;\n /** Blockhash of this block's parent */\n previousBlockhash: Blockhash;\n /** Slot index of this block's parent */\n parentSlot: number;\n /** Vector of transactions with status meta and original message */\n transactions: Array<{\n /** The transaction */\n transaction: {\n /** The transaction message */\n message: Message;\n /** The transaction signatures */\n signatures: string[];\n };\n /** Metadata produced from the transaction */\n meta: ConfirmedTransactionMeta | null;\n }>;\n /** Vector of block rewards */\n rewards?: Array<{\n /** Public key of reward recipient */\n pubkey: string;\n /** Reward value in lamports */\n lamports: number;\n /** Account balance after reward is applied */\n postBalance: number | null;\n /** Type of reward received */\n rewardType: string | null;\n }>;\n /** The unix timestamp of when the block was processed */\n blockTime: number | null;\n};\n\n/**\n * A ConfirmedBlock on the ledger\n */\nexport type ConfirmedBlock = {\n /** Blockhash of this block */\n blockhash: Blockhash;\n /** Blockhash of this block's parent */\n previousBlockhash: Blockhash;\n /** Slot index of this block's parent */\n parentSlot: number;\n /** Vector of transactions and status metas */\n transactions: Array<{\n transaction: Transaction;\n meta: ConfirmedTransactionMeta | null;\n }>;\n /** Vector of block rewards */\n rewards?: Array<{\n pubkey: string;\n lamports: number;\n postBalance: number | null;\n rewardType: string | null;\n }>;\n /** The unix timestamp of when the block was processed */\n blockTime: number | null;\n};\n\n/**\n * A ConfirmedBlock on the ledger with signatures only\n */\nexport type ConfirmedBlockSignatures = {\n /** Blockhash of this block */\n blockhash: Blockhash;\n /** Blockhash of this block's parent */\n previousBlockhash: Blockhash;\n /** Slot index of this block's parent */\n parentSlot: number;\n /** Vector of signatures */\n signatures: Array;\n /** The unix timestamp of when the block was processed */\n blockTime: number | null;\n};\n\n/**\n * A performance sample\n */\nexport type PerfSample = {\n /** Slot number of sample */\n slot: number;\n /** Number of transactions in a sample window */\n numTransactions: number;\n /** Number of slots in a sample window */\n numSlots: number;\n /** Sample window in seconds */\n samplePeriodSecs: number;\n};\n\nfunction createRpcClient(\n url: string,\n useHttps: boolean,\n httpHeaders?: HttpHeaders,\n fetchMiddleware?: FetchMiddleware,\n disableRetryOnRateLimit?: boolean,\n): RpcClient {\n let agentManager: AgentManager | undefined;\n if (!process.env.BROWSER) {\n agentManager = new AgentManager(useHttps);\n }\n\n let fetchWithMiddleware:\n | ((url: string, options: any) => Promise)\n | undefined;\n\n if (fetchMiddleware) {\n fetchWithMiddleware = async (url: string, options: any) => {\n const modifiedFetchArgs = await new Promise<[string, any]>(\n (resolve, reject) => {\n try {\n fetchMiddleware(url, options, (modifiedUrl, modifiedOptions) =>\n resolve([modifiedUrl, modifiedOptions]),\n );\n } catch (error) {\n reject(error);\n }\n },\n );\n return await fetch(...modifiedFetchArgs);\n };\n }\n\n const clientBrowser = new RpcClient(async (request, callback) => {\n const agent = agentManager ? agentManager.requestStart() : undefined;\n const options = {\n method: 'POST',\n body: request,\n agent,\n headers: Object.assign(\n {\n 'Content-Type': 'application/json',\n },\n httpHeaders || {},\n ),\n };\n\n try {\n let too_many_requests_retries = 5;\n let res: Response;\n let waitTime = 500;\n for (;;) {\n if (fetchWithMiddleware) {\n res = await fetchWithMiddleware(url, options);\n } else {\n res = await fetch(url, options);\n }\n\n if (res.status !== 429 /* Too many requests */) {\n break;\n }\n if (disableRetryOnRateLimit === true) {\n break;\n }\n too_many_requests_retries -= 1;\n if (too_many_requests_retries === 0) {\n break;\n }\n console.log(\n `Server responded with ${res.status} ${res.statusText}. Retrying after ${waitTime}ms delay...`,\n );\n await sleep(waitTime);\n waitTime *= 2;\n }\n\n const text = await res.text();\n if (res.ok) {\n callback(null, text);\n } else {\n callback(new Error(`${res.status} ${res.statusText}: ${text}`));\n }\n } catch (err) {\n if (err instanceof Error) callback(err);\n } finally {\n agentManager && agentManager.requestEnd();\n }\n }, {});\n\n return clientBrowser;\n}\n\nfunction createRpcRequest(client: RpcClient): RpcRequest {\n return (method, args) => {\n return new Promise((resolve, reject) => {\n client.request(method, args, (err: any, response: any) => {\n if (err) {\n reject(err);\n return;\n }\n resolve(response);\n });\n });\n };\n}\n\nfunction createRpcBatchRequest(client: RpcClient): RpcBatchRequest {\n return (requests: RpcParams[]) => {\n return new Promise((resolve, reject) => {\n // Do nothing if requests is empty\n if (requests.length === 0) resolve([]);\n\n const batch = requests.map((params: RpcParams) => {\n return client.request(params.methodName, params.args);\n });\n\n client.request(batch, (err: any, response: any) => {\n if (err) {\n reject(err);\n return;\n }\n resolve(response);\n });\n });\n };\n}\n\n/**\n * Expected JSON RPC response for the \"getInflationGovernor\" message\n */\nconst GetInflationGovernorRpcResult = jsonRpcResult(GetInflationGovernorResult);\n\n/**\n * Expected JSON RPC response for the \"getEpochInfo\" message\n */\nconst GetEpochInfoRpcResult = jsonRpcResult(GetEpochInfoResult);\n\n/**\n * Expected JSON RPC response for the \"getEpochSchedule\" message\n */\nconst GetEpochScheduleRpcResult = jsonRpcResult(GetEpochScheduleResult);\n\n/**\n * Expected JSON RPC response for the \"getLeaderSchedule\" message\n */\nconst GetLeaderScheduleRpcResult = jsonRpcResult(GetLeaderScheduleResult);\n\n/**\n * Expected JSON RPC response for the \"minimumLedgerSlot\" and \"getFirstAvailableBlock\" messages\n */\nconst SlotRpcResult = jsonRpcResult(number());\n\n/**\n * Supply\n */\nexport type Supply = {\n /** Total supply in lamports */\n total: number;\n /** Circulating supply in lamports */\n circulating: number;\n /** Non-circulating supply in lamports */\n nonCirculating: number;\n /** List of non-circulating account addresses */\n nonCirculatingAccounts: Array;\n};\n\n/**\n * Expected JSON RPC response for the \"getSupply\" message\n */\nconst GetSupplyRpcResult = jsonRpcResultAndContext(\n pick({\n total: number(),\n circulating: number(),\n nonCirculating: number(),\n nonCirculatingAccounts: array(PublicKeyFromString),\n }),\n);\n\n/**\n * Token amount object which returns a token amount in different formats\n * for various client use cases.\n */\nexport type TokenAmount = {\n /** Raw amount of tokens as string ignoring decimals */\n amount: string;\n /** Number of decimals configured for token's mint */\n decimals: number;\n /** Token amount as float, accounts for decimals */\n uiAmount: number | null;\n /** Token amount as string, accounts for decimals */\n uiAmountString?: string;\n};\n\n/**\n * Expected JSON RPC structure for token amounts\n */\nconst TokenAmountResult = pick({\n amount: string(),\n uiAmount: nullable(number()),\n decimals: number(),\n uiAmountString: optional(string()),\n});\n\n/**\n * Token address and balance.\n */\nexport type TokenAccountBalancePair = {\n /** Address of the token account */\n address: PublicKey;\n /** Raw amount of tokens as string ignoring decimals */\n amount: string;\n /** Number of decimals configured for token's mint */\n decimals: number;\n /** Token amount as float, accounts for decimals */\n uiAmount: number | null;\n /** Token amount as string, accounts for decimals */\n uiAmountString?: string;\n};\n\n/**\n * Expected JSON RPC response for the \"getTokenLargestAccounts\" message\n */\nconst GetTokenLargestAccountsResult = jsonRpcResultAndContext(\n array(\n pick({\n address: PublicKeyFromString,\n amount: string(),\n uiAmount: nullable(number()),\n decimals: number(),\n uiAmountString: optional(string()),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getTokenAccountsByOwner\" message\n */\nconst GetTokenAccountsByOwner = jsonRpcResultAndContext(\n array(\n pick({\n pubkey: PublicKeyFromString,\n account: pick({\n executable: boolean(),\n owner: PublicKeyFromString,\n lamports: number(),\n data: BufferFromRawAccountData,\n rentEpoch: number(),\n }),\n }),\n ),\n);\n\nconst ParsedAccountDataResult = pick({\n program: string(),\n parsed: unknown(),\n space: number(),\n});\n\n/**\n * Expected JSON RPC response for the \"getTokenAccountsByOwner\" message with parsed data\n */\nconst GetParsedTokenAccountsByOwner = jsonRpcResultAndContext(\n array(\n pick({\n pubkey: PublicKeyFromString,\n account: pick({\n executable: boolean(),\n owner: PublicKeyFromString,\n lamports: number(),\n data: ParsedAccountDataResult,\n rentEpoch: number(),\n }),\n }),\n ),\n);\n\n/**\n * Pair of an account address and its balance\n */\nexport type AccountBalancePair = {\n address: PublicKey;\n lamports: number;\n};\n\n/**\n * Expected JSON RPC response for the \"getLargestAccounts\" message\n */\nconst GetLargestAccountsRpcResult = jsonRpcResultAndContext(\n array(\n pick({\n lamports: number(),\n address: PublicKeyFromString,\n }),\n ),\n);\n\n/**\n * @internal\n */\nconst AccountInfoResult = pick({\n executable: boolean(),\n owner: PublicKeyFromString,\n lamports: number(),\n data: BufferFromRawAccountData,\n rentEpoch: number(),\n});\n\n/**\n * @internal\n */\nconst KeyedAccountInfoResult = pick({\n pubkey: PublicKeyFromString,\n account: AccountInfoResult,\n});\n\nconst ParsedOrRawAccountData = coerce(\n union([instance(Buffer), ParsedAccountDataResult]),\n union([RawAccountDataResult, ParsedAccountDataResult]),\n value => {\n if (Array.isArray(value)) {\n return create(value, BufferFromRawAccountData);\n } else {\n return value;\n }\n },\n);\n\n/**\n * @internal\n */\nconst ParsedAccountInfoResult = pick({\n executable: boolean(),\n owner: PublicKeyFromString,\n lamports: number(),\n data: ParsedOrRawAccountData,\n rentEpoch: number(),\n});\n\nconst KeyedParsedAccountInfoResult = pick({\n pubkey: PublicKeyFromString,\n account: ParsedAccountInfoResult,\n});\n\n/**\n * @internal\n */\nconst StakeActivationResult = pick({\n state: union([\n literal('active'),\n literal('inactive'),\n literal('activating'),\n literal('deactivating'),\n ]),\n active: number(),\n inactive: number(),\n});\n\n/**\n * Expected JSON RPC response for the \"getConfirmedSignaturesForAddress2\" message\n */\n\nconst GetConfirmedSignaturesForAddress2RpcResult = jsonRpcResult(\n array(\n pick({\n signature: string(),\n slot: number(),\n err: TransactionErrorResult,\n memo: nullable(string()),\n blockTime: optional(nullable(number())),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getSignaturesForAddress\" message\n */\nconst GetSignaturesForAddressRpcResult = jsonRpcResult(\n array(\n pick({\n signature: string(),\n slot: number(),\n err: TransactionErrorResult,\n memo: nullable(string()),\n blockTime: optional(nullable(number())),\n }),\n ),\n);\n\n/***\n * Expected JSON RPC response for the \"accountNotification\" message\n */\nconst AccountNotificationResult = pick({\n subscription: number(),\n result: notificationResultAndContext(AccountInfoResult),\n});\n\n/**\n * @internal\n */\nconst ProgramAccountInfoResult = pick({\n pubkey: PublicKeyFromString,\n account: AccountInfoResult,\n});\n\n/***\n * Expected JSON RPC response for the \"programNotification\" message\n */\nconst ProgramAccountNotificationResult = pick({\n subscription: number(),\n result: notificationResultAndContext(ProgramAccountInfoResult),\n});\n\n/**\n * @internal\n */\nconst SlotInfoResult = pick({\n parent: number(),\n slot: number(),\n root: number(),\n});\n\n/**\n * Expected JSON RPC response for the \"slotNotification\" message\n */\nconst SlotNotificationResult = pick({\n subscription: number(),\n result: SlotInfoResult,\n});\n\n/**\n * Slot updates which can be used for tracking the live progress of a cluster.\n * - `\"firstShredReceived\"`: connected node received the first shred of a block.\n * Indicates that a new block that is being produced.\n * - `\"completed\"`: connected node has received all shreds of a block. Indicates\n * a block was recently produced.\n * - `\"optimisticConfirmation\"`: block was optimistically confirmed by the\n * cluster. It is not guaranteed that an optimistic confirmation notification\n * will be sent for every finalized blocks.\n * - `\"root\"`: the connected node rooted this block.\n * - `\"createdBank\"`: the connected node has started validating this block.\n * - `\"frozen\"`: the connected node has validated this block.\n * - `\"dead\"`: the connected node failed to validate this block.\n */\nexport type SlotUpdate =\n | {\n type: 'firstShredReceived';\n slot: number;\n timestamp: number;\n }\n | {\n type: 'completed';\n slot: number;\n timestamp: number;\n }\n | {\n type: 'createdBank';\n slot: number;\n timestamp: number;\n parent: number;\n }\n | {\n type: 'frozen';\n slot: number;\n timestamp: number;\n stats: {\n numTransactionEntries: number;\n numSuccessfulTransactions: number;\n numFailedTransactions: number;\n maxTransactionsPerEntry: number;\n };\n }\n | {\n type: 'dead';\n slot: number;\n timestamp: number;\n err: string;\n }\n | {\n type: 'optimisticConfirmation';\n slot: number;\n timestamp: number;\n }\n | {\n type: 'root';\n slot: number;\n timestamp: number;\n };\n\n/**\n * @internal\n */\nconst SlotUpdateResult = union([\n pick({\n type: union([\n literal('firstShredReceived'),\n literal('completed'),\n literal('optimisticConfirmation'),\n literal('root'),\n ]),\n slot: number(),\n timestamp: number(),\n }),\n pick({\n type: literal('createdBank'),\n parent: number(),\n slot: number(),\n timestamp: number(),\n }),\n pick({\n type: literal('frozen'),\n slot: number(),\n timestamp: number(),\n stats: pick({\n numTransactionEntries: number(),\n numSuccessfulTransactions: number(),\n numFailedTransactions: number(),\n maxTransactionsPerEntry: number(),\n }),\n }),\n pick({\n type: literal('dead'),\n slot: number(),\n timestamp: number(),\n err: string(),\n }),\n]);\n\n/**\n * Expected JSON RPC response for the \"slotsUpdatesNotification\" message\n */\nconst SlotUpdateNotificationResult = pick({\n subscription: number(),\n result: SlotUpdateResult,\n});\n\n/**\n * Expected JSON RPC response for the \"signatureNotification\" message\n */\nconst SignatureNotificationResult = pick({\n subscription: number(),\n result: notificationResultAndContext(\n union([SignatureStatusResult, SignatureReceivedResult]),\n ),\n});\n\n/**\n * Expected JSON RPC response for the \"rootNotification\" message\n */\nconst RootNotificationResult = pick({\n subscription: number(),\n result: number(),\n});\n\nconst ContactInfoResult = pick({\n pubkey: string(),\n gossip: nullable(string()),\n tpu: nullable(string()),\n rpc: nullable(string()),\n version: nullable(string()),\n});\n\nconst VoteAccountInfoResult = pick({\n votePubkey: string(),\n nodePubkey: string(),\n activatedStake: number(),\n epochVoteAccount: boolean(),\n epochCredits: array(tuple([number(), number(), number()])),\n commission: number(),\n lastVote: number(),\n rootSlot: nullable(number()),\n});\n\n/**\n * Expected JSON RPC response for the \"getVoteAccounts\" message\n */\nconst GetVoteAccounts = jsonRpcResult(\n pick({\n current: array(VoteAccountInfoResult),\n delinquent: array(VoteAccountInfoResult),\n }),\n);\n\nconst ConfirmationStatus = union([\n literal('processed'),\n literal('confirmed'),\n literal('finalized'),\n]);\n\nconst SignatureStatusResponse = pick({\n slot: number(),\n confirmations: nullable(number()),\n err: TransactionErrorResult,\n confirmationStatus: optional(ConfirmationStatus),\n});\n\n/**\n * Expected JSON RPC response for the \"getSignatureStatuses\" message\n */\nconst GetSignatureStatusesRpcResult = jsonRpcResultAndContext(\n array(nullable(SignatureStatusResponse)),\n);\n\n/**\n * Expected JSON RPC response for the \"getMinimumBalanceForRentExemption\" message\n */\nconst GetMinimumBalanceForRentExemptionRpcResult = jsonRpcResult(number());\n\nconst ConfirmedTransactionResult = pick({\n signatures: array(string()),\n message: pick({\n accountKeys: array(string()),\n header: pick({\n numRequiredSignatures: number(),\n numReadonlySignedAccounts: number(),\n numReadonlyUnsignedAccounts: number(),\n }),\n instructions: array(\n pick({\n accounts: array(number()),\n data: string(),\n programIdIndex: number(),\n }),\n ),\n recentBlockhash: string(),\n }),\n});\n\nconst ParsedInstructionResult = pick({\n parsed: unknown(),\n program: string(),\n programId: PublicKeyFromString,\n});\n\nconst RawInstructionResult = pick({\n accounts: array(PublicKeyFromString),\n data: string(),\n programId: PublicKeyFromString,\n});\n\nconst InstructionResult = union([\n RawInstructionResult,\n ParsedInstructionResult,\n]);\n\nconst UnknownInstructionResult = union([\n pick({\n parsed: unknown(),\n program: string(),\n programId: string(),\n }),\n pick({\n accounts: array(string()),\n data: string(),\n programId: string(),\n }),\n]);\n\nconst ParsedOrRawInstruction = coerce(\n InstructionResult,\n UnknownInstructionResult,\n value => {\n if ('accounts' in value) {\n return create(value, RawInstructionResult);\n } else {\n return create(value, ParsedInstructionResult);\n }\n },\n);\n\n/**\n * @internal\n */\nconst ParsedConfirmedTransactionResult = pick({\n signatures: array(string()),\n message: pick({\n accountKeys: array(\n pick({\n pubkey: PublicKeyFromString,\n signer: boolean(),\n writable: boolean(),\n }),\n ),\n instructions: array(ParsedOrRawInstruction),\n recentBlockhash: string(),\n }),\n});\n\nconst TokenBalanceResult = pick({\n accountIndex: number(),\n mint: string(),\n owner: optional(string()),\n uiTokenAmount: TokenAmountResult,\n});\n\n/**\n * @internal\n */\nconst ConfirmedTransactionMetaResult = pick({\n err: TransactionErrorResult,\n fee: number(),\n innerInstructions: optional(\n nullable(\n array(\n pick({\n index: number(),\n instructions: array(\n pick({\n accounts: array(number()),\n data: string(),\n programIdIndex: number(),\n }),\n ),\n }),\n ),\n ),\n ),\n preBalances: array(number()),\n postBalances: array(number()),\n logMessages: optional(nullable(array(string()))),\n preTokenBalances: optional(nullable(array(TokenBalanceResult))),\n postTokenBalances: optional(nullable(array(TokenBalanceResult))),\n});\n\n/**\n * @internal\n */\nconst ParsedConfirmedTransactionMetaResult = pick({\n err: TransactionErrorResult,\n fee: number(),\n innerInstructions: optional(\n nullable(\n array(\n pick({\n index: number(),\n instructions: array(ParsedOrRawInstruction),\n }),\n ),\n ),\n ),\n preBalances: array(number()),\n postBalances: array(number()),\n logMessages: optional(nullable(array(string()))),\n preTokenBalances: optional(nullable(array(TokenBalanceResult))),\n postTokenBalances: optional(nullable(array(TokenBalanceResult))),\n});\n\n/**\n * Expected JSON RPC response for the \"getConfirmedBlock\" message\n */\nconst GetConfirmedBlockRpcResult = jsonRpcResult(\n nullable(\n pick({\n blockhash: string(),\n previousBlockhash: string(),\n parentSlot: number(),\n transactions: array(\n pick({\n transaction: ConfirmedTransactionResult,\n meta: nullable(ConfirmedTransactionMetaResult),\n }),\n ),\n rewards: optional(\n array(\n pick({\n pubkey: string(),\n lamports: number(),\n postBalance: nullable(number()),\n rewardType: nullable(string()),\n }),\n ),\n ),\n blockTime: nullable(number()),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getConfirmedBlockSignatures\" message\n */\nconst GetConfirmedBlockSignaturesRpcResult = jsonRpcResult(\n nullable(\n pick({\n blockhash: string(),\n previousBlockhash: string(),\n parentSlot: number(),\n signatures: array(string()),\n blockTime: nullable(number()),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getConfirmedTransaction\" message\n */\nconst GetConfirmedTransactionRpcResult = jsonRpcResult(\n nullable(\n pick({\n slot: number(),\n meta: ConfirmedTransactionMetaResult,\n blockTime: optional(nullable(number())),\n transaction: ConfirmedTransactionResult,\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getConfirmedTransaction\" message\n */\nconst GetParsedConfirmedTransactionRpcResult = jsonRpcResult(\n nullable(\n pick({\n slot: number(),\n transaction: ParsedConfirmedTransactionResult,\n meta: nullable(ParsedConfirmedTransactionMetaResult),\n blockTime: optional(nullable(number())),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"getRecentBlockhash\" message\n */\nconst GetRecentBlockhashAndContextRpcResult = jsonRpcResultAndContext(\n pick({\n blockhash: string(),\n feeCalculator: pick({\n lamportsPerSignature: number(),\n }),\n }),\n);\n\nconst PerfSampleResult = pick({\n slot: number(),\n numTransactions: number(),\n numSlots: number(),\n samplePeriodSecs: number(),\n});\n\n/*\n * Expected JSON RPC response for \"getRecentPerformanceSamples\" message\n */\nconst GetRecentPerformanceSamplesRpcResult = jsonRpcResult(\n array(PerfSampleResult),\n);\n\n/**\n * Expected JSON RPC response for the \"getFeeCalculatorForBlockhash\" message\n */\nconst GetFeeCalculatorRpcResult = jsonRpcResultAndContext(\n nullable(\n pick({\n feeCalculator: pick({\n lamportsPerSignature: number(),\n }),\n }),\n ),\n);\n\n/**\n * Expected JSON RPC response for the \"requestAirdrop\" message\n */\nconst RequestAirdropRpcResult = jsonRpcResult(string());\n\n/**\n * Expected JSON RPC response for the \"sendTransaction\" message\n */\nconst SendTransactionRpcResult = jsonRpcResult(string());\n\n/**\n * Information about the latest slot being processed by a node\n */\nexport type SlotInfo = {\n /** Currently processing slot */\n slot: number;\n /** Parent of the current slot */\n parent: number;\n /** The root block of the current slot's fork */\n root: number;\n};\n\n/**\n * Parsed account data\n */\nexport type ParsedAccountData = {\n /** Name of the program that owns this account */\n program: string;\n /** Parsed account data */\n parsed: any;\n /** Space used by account data */\n space: number;\n};\n\n/**\n * Stake Activation data\n */\nexport type StakeActivationData = {\n /** the stake account's activation state */\n state: 'active' | 'inactive' | 'activating' | 'deactivating';\n /** stake active during the epoch */\n active: number;\n /** stake inactive during the epoch */\n inactive: number;\n};\n\n/**\n * Data slice argument for getProgramAccounts\n */\nexport type DataSlice = {\n /** offset of data slice */\n offset: number;\n /** length of data slice */\n length: number;\n};\n\n/**\n * Memory comparison filter for getProgramAccounts\n */\nexport type MemcmpFilter = {\n memcmp: {\n /** offset into program account data to start comparison */\n offset: number;\n /** data to match, as base-58 encoded string and limited to less than 129 bytes */\n bytes: string;\n };\n};\n\n/**\n * Data size comparison filter for getProgramAccounts\n */\nexport type DataSizeFilter = {\n /** Size of data for program account data length comparison */\n dataSize: number;\n};\n\n/**\n * A filter object for getProgramAccounts\n */\nexport type GetProgramAccountsFilter = MemcmpFilter | DataSizeFilter;\n\n/**\n * Configuration object for getProgramAccounts requests\n */\nexport type GetProgramAccountsConfig = {\n /** Optional commitment level */\n commitment?: Commitment;\n /** Optional encoding for account data (default base64)\n * To use \"jsonParsed\" encoding, please refer to `getParsedProgramAccounts` in connection.ts\n * */\n encoding?: 'base64';\n /** Optional data slice to limit the returned account data */\n dataSlice?: DataSlice;\n /** Optional array of filters to apply to accounts */\n filters?: GetProgramAccountsFilter[];\n};\n\n/**\n * Configuration object for getParsedProgramAccounts\n */\nexport type GetParsedProgramAccountsConfig = {\n /** Optional commitment level */\n commitment?: Commitment;\n /** Optional array of filters to apply to accounts */\n filters?: GetProgramAccountsFilter[];\n};\n\n/**\n * Configuration object for getMultipleAccounts\n */\nexport type GetMultipleAccountsConfig = {\n /** Optional commitment level */\n commitment?: Commitment;\n /** Optional encoding for account data (default base64) */\n encoding?: 'base64' | 'jsonParsed';\n};\n\n/**\n * Information describing an account\n */\nexport type AccountInfo = {\n /** `true` if this account's data contains a loaded program */\n executable: boolean;\n /** Identifier of the program that owns the account */\n owner: PublicKey;\n /** Number of lamports assigned to the account */\n lamports: number;\n /** Optional data assigned to the account */\n data: T;\n /** Optional rent epoch info for account */\n rentEpoch?: number;\n};\n\n/**\n * Account information identified by pubkey\n */\nexport type KeyedAccountInfo = {\n accountId: PublicKey;\n accountInfo: AccountInfo;\n};\n\n/**\n * Callback function for account change notifications\n */\nexport type AccountChangeCallback = (\n accountInfo: AccountInfo,\n context: Context,\n) => void;\n\n/**\n * @internal\n */\ntype SubscriptionId = 'subscribing' | number;\n\n/**\n * @internal\n */\ntype AccountSubscriptionInfo = {\n publicKey: string; // PublicKey of the account as a base 58 string\n callback: AccountChangeCallback;\n commitment?: Commitment;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n};\n\n/**\n * Callback function for program account change notifications\n */\nexport type ProgramAccountChangeCallback = (\n keyedAccountInfo: KeyedAccountInfo,\n context: Context,\n) => void;\n\n/**\n * @internal\n */\ntype ProgramAccountSubscriptionInfo = {\n programId: string; // PublicKey of the program as a base 58 string\n callback: ProgramAccountChangeCallback;\n commitment?: Commitment;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n filters?: GetProgramAccountsFilter[];\n};\n\n/**\n * Callback function for slot change notifications\n */\nexport type SlotChangeCallback = (slotInfo: SlotInfo) => void;\n\n/**\n * @internal\n */\ntype SlotSubscriptionInfo = {\n callback: SlotChangeCallback;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n};\n\n/**\n * Callback function for slot update notifications\n */\nexport type SlotUpdateCallback = (slotUpdate: SlotUpdate) => void;\n\n/**\n * @private\n */\ntype SlotUpdateSubscriptionInfo = {\n callback: SlotUpdateCallback;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n};\n\n/**\n * Callback function for signature status notifications\n */\nexport type SignatureResultCallback = (\n signatureResult: SignatureResult,\n context: Context,\n) => void;\n\n/**\n * Signature status notification with transaction result\n */\nexport type SignatureStatusNotification = {\n type: 'status';\n result: SignatureResult;\n};\n\n/**\n * Signature received notification\n */\nexport type SignatureReceivedNotification = {\n type: 'received';\n};\n\n/**\n * Callback function for signature notifications\n */\nexport type SignatureSubscriptionCallback = (\n notification: SignatureStatusNotification | SignatureReceivedNotification,\n context: Context,\n) => void;\n\n/**\n * Signature subscription options\n */\nexport type SignatureSubscriptionOptions = {\n commitment?: Commitment;\n enableReceivedNotification?: boolean;\n};\n\n/**\n * @internal\n */\ntype SignatureSubscriptionInfo = {\n signature: TransactionSignature; // TransactionSignature as a base 58 string\n callback: SignatureSubscriptionCallback;\n options?: SignatureSubscriptionOptions;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n};\n\n/**\n * Callback function for root change notifications\n */\nexport type RootChangeCallback = (root: number) => void;\n\n/**\n * @internal\n */\ntype RootSubscriptionInfo = {\n callback: RootChangeCallback;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n};\n\n/**\n * @internal\n */\nconst LogsResult = pick({\n err: TransactionErrorResult,\n logs: array(string()),\n signature: string(),\n});\n\n/**\n * Logs result.\n */\nexport type Logs = {\n err: TransactionError | null;\n logs: string[];\n signature: string;\n};\n\n/**\n * Expected JSON RPC response for the \"logsNotification\" message.\n */\nconst LogsNotificationResult = pick({\n result: notificationResultAndContext(LogsResult),\n subscription: number(),\n});\n\n/**\n * Filter for log subscriptions.\n */\nexport type LogsFilter = PublicKey | 'all' | 'allWithVotes';\n\n/**\n * Callback function for log notifications.\n */\nexport type LogsCallback = (logs: Logs, ctx: Context) => void;\n\n/**\n * @private\n */\ntype LogsSubscriptionInfo = {\n callback: LogsCallback;\n filter: LogsFilter;\n subscriptionId: SubscriptionId | null; // null when there's no current server subscription id\n commitment?: Commitment;\n};\n\n/**\n * Signature result\n */\nexport type SignatureResult = {\n err: TransactionError | null;\n};\n\n/**\n * Transaction error\n */\nexport type TransactionError = {} | string;\n\n/**\n * Transaction confirmation status\n *
\n *   'processed': Transaction landed in a block which has reached 1 confirmation by the connected node\n *   'confirmed': Transaction landed in a block which has reached 1 confirmation by the cluster\n *   'finalized': Transaction landed in a block which has been finalized by the cluster\n * 
\n */\nexport type TransactionConfirmationStatus =\n | 'processed'\n | 'confirmed'\n | 'finalized';\n\n/**\n * Signature status\n */\nexport type SignatureStatus = {\n /** when the transaction was processed */\n slot: number;\n /** the number of blocks that have been confirmed and voted on in the fork containing `slot` */\n confirmations: number | null;\n /** transaction error, if any */\n err: TransactionError | null;\n /** cluster confirmation status, if data available. Possible responses: `processed`, `confirmed`, `finalized` */\n confirmationStatus?: TransactionConfirmationStatus;\n};\n\n/**\n * A confirmed signature with its status\n */\nexport type ConfirmedSignatureInfo = {\n /** the transaction signature */\n signature: string;\n /** when the transaction was processed */\n slot: number;\n /** error, if any */\n err: TransactionError | null;\n /** memo associated with the transaction, if any */\n memo: string | null;\n /** The unix timestamp of when the transaction was processed */\n blockTime?: number | null;\n};\n\n/**\n * An object defining headers to be passed to the RPC server\n */\nexport type HttpHeaders = {[header: string]: string};\n\n/**\n * A callback used to augment the outgoing HTTP request\n */\nexport type FetchMiddleware = (\n url: string,\n options: any,\n fetch: (modifiedUrl: string, modifiedOptions: any) => void,\n) => void;\n\n/**\n * Configuration for instantiating a Connection\n */\nexport type ConnectionConfig = {\n /** Optional commitment level */\n commitment?: Commitment;\n /** Optional endpoint URL to the fullnode JSON RPC PubSub WebSocket Endpoint */\n wsEndpoint?: string;\n /** Optional HTTP headers object */\n httpHeaders?: HttpHeaders;\n /** Optional fetch middleware callback */\n fetchMiddleware?: FetchMiddleware;\n /** Optional Disable retring calls when server responds with HTTP 429 (Too Many Requests) */\n disableRetryOnRateLimit?: boolean;\n /** time to allow for the server to initially process a transaction (in milliseconds) */\n confirmTransactionInitialTimeout?: number;\n};\n\n/**\n * A connection to a fullnode JSON RPC endpoint\n */\nexport class Connection {\n /** @internal */ _commitment?: Commitment;\n /** @internal */ _confirmTransactionInitialTimeout?: number;\n /** @internal */ _rpcEndpoint: string;\n /** @internal */ _rpcWsEndpoint: string;\n /** @internal */ _rpcClient: RpcClient;\n /** @internal */ _rpcRequest: RpcRequest;\n /** @internal */ _rpcBatchRequest: RpcBatchRequest;\n /** @internal */ _rpcWebSocket: RpcWebSocketClient;\n /** @internal */ _rpcWebSocketConnected: boolean = false;\n /** @internal */ _rpcWebSocketHeartbeat: ReturnType<\n typeof setInterval\n > | null = null;\n /** @internal */ _rpcWebSocketIdleTimeout: ReturnType<\n typeof setTimeout\n > | null = null;\n\n /** @internal */ _disableBlockhashCaching: boolean = false;\n /** @internal */ _pollingBlockhash: boolean = false;\n /** @internal */ _blockhashInfo: {\n recentBlockhash: Blockhash | null;\n lastFetch: number;\n simulatedSignatures: Array;\n transactionSignatures: Array;\n } = {\n recentBlockhash: null,\n lastFetch: 0,\n transactionSignatures: [],\n simulatedSignatures: [],\n };\n\n /** @internal */ _accountChangeSubscriptionCounter: number = 0;\n /** @internal */ _accountChangeSubscriptions: {\n [id: number]: AccountSubscriptionInfo;\n } = {};\n\n /** @internal */ _programAccountChangeSubscriptionCounter: number = 0;\n /** @internal */ _programAccountChangeSubscriptions: {\n [id: number]: ProgramAccountSubscriptionInfo;\n } = {};\n\n /** @internal */ _rootSubscriptionCounter: number = 0;\n /** @internal */ _rootSubscriptions: {\n [id: number]: RootSubscriptionInfo;\n } = {};\n\n /** @internal */ _signatureSubscriptionCounter: number = 0;\n /** @internal */ _signatureSubscriptions: {\n [id: number]: SignatureSubscriptionInfo;\n } = {};\n\n /** @internal */ _slotSubscriptionCounter: number = 0;\n /** @internal */ _slotSubscriptions: {\n [id: number]: SlotSubscriptionInfo;\n } = {};\n\n /** @internal */ _logsSubscriptionCounter: number = 0;\n /** @internal */ _logsSubscriptions: {\n [id: number]: LogsSubscriptionInfo;\n } = {};\n\n /** @internal */ _slotUpdateSubscriptionCounter: number = 0;\n /** @internal */ _slotUpdateSubscriptions: {\n [id: number]: SlotUpdateSubscriptionInfo;\n } = {};\n\n /**\n * Establish a JSON RPC connection\n *\n * @param endpoint URL to the fullnode JSON RPC endpoint\n * @param commitmentOrConfig optional default commitment level or optional ConnectionConfig configuration object\n */\n constructor(\n endpoint: string,\n commitmentOrConfig?: Commitment | ConnectionConfig,\n ) {\n let url = new URL(endpoint);\n const useHttps = url.protocol === 'https:';\n\n let wsEndpoint;\n let httpHeaders;\n let fetchMiddleware;\n let disableRetryOnRateLimit;\n if (commitmentOrConfig && typeof commitmentOrConfig === 'string') {\n this._commitment = commitmentOrConfig;\n } else if (commitmentOrConfig) {\n this._commitment = commitmentOrConfig.commitment;\n this._confirmTransactionInitialTimeout =\n commitmentOrConfig.confirmTransactionInitialTimeout;\n wsEndpoint = commitmentOrConfig.wsEndpoint;\n httpHeaders = commitmentOrConfig.httpHeaders;\n fetchMiddleware = commitmentOrConfig.fetchMiddleware;\n disableRetryOnRateLimit = commitmentOrConfig.disableRetryOnRateLimit;\n }\n\n this._rpcEndpoint = endpoint;\n this._rpcWsEndpoint = wsEndpoint || makeWebsocketUrl(endpoint);\n\n this._rpcClient = createRpcClient(\n url.toString(),\n useHttps,\n httpHeaders,\n fetchMiddleware,\n disableRetryOnRateLimit,\n );\n this._rpcRequest = createRpcRequest(this._rpcClient);\n this._rpcBatchRequest = createRpcBatchRequest(this._rpcClient);\n\n this._rpcWebSocket = new RpcWebSocketClient(this._rpcWsEndpoint, {\n autoconnect: false,\n max_reconnects: Infinity,\n });\n this._rpcWebSocket.on('open', this._wsOnOpen.bind(this));\n this._rpcWebSocket.on('error', this._wsOnError.bind(this));\n this._rpcWebSocket.on('close', this._wsOnClose.bind(this));\n this._rpcWebSocket.on(\n 'accountNotification',\n this._wsOnAccountNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'programNotification',\n this._wsOnProgramAccountNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'slotNotification',\n this._wsOnSlotNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'slotsUpdatesNotification',\n this._wsOnSlotUpdatesNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'signatureNotification',\n this._wsOnSignatureNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'rootNotification',\n this._wsOnRootNotification.bind(this),\n );\n this._rpcWebSocket.on(\n 'logsNotification',\n this._wsOnLogsNotification.bind(this),\n );\n }\n\n /**\n * The default commitment used for requests\n */\n get commitment(): Commitment | undefined {\n return this._commitment;\n }\n\n /**\n * Fetch the balance for the specified public key, return with context\n */\n async getBalanceAndContext(\n publicKey: PublicKey,\n commitment?: Commitment,\n ): Promise> {\n const args = this._buildArgs([publicKey.toBase58()], commitment);\n const unsafeRes = await this._rpcRequest('getBalance', args);\n const res = create(unsafeRes, jsonRpcResultAndContext(number()));\n if ('error' in res) {\n throw new Error(\n 'failed to get balance for ' +\n publicKey.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch the balance for the specified public key\n */\n async getBalance(\n publicKey: PublicKey,\n commitment?: Commitment,\n ): Promise {\n return await this.getBalanceAndContext(publicKey, commitment)\n .then(x => x.value)\n .catch(e => {\n throw new Error(\n 'failed to get balance of account ' + publicKey.toBase58() + ': ' + e,\n );\n });\n }\n\n /**\n * Fetch the estimated production time of a block\n */\n async getBlockTime(slot: number): Promise {\n const unsafeRes = await this._rpcRequest('getBlockTime', [slot]);\n const res = create(unsafeRes, jsonRpcResult(nullable(number())));\n if ('error' in res) {\n throw new Error(\n 'failed to get block time for slot ' + slot + ': ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch the lowest slot that the node has information about in its ledger.\n * This value may increase over time if the node is configured to purge older ledger data\n */\n async getMinimumLedgerSlot(): Promise {\n const unsafeRes = await this._rpcRequest('minimumLedgerSlot', []);\n const res = create(unsafeRes, jsonRpcResult(number()));\n if ('error' in res) {\n throw new Error(\n 'failed to get minimum ledger slot: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch the slot of the lowest confirmed block that has not been purged from the ledger\n */\n async getFirstAvailableBlock(): Promise {\n const unsafeRes = await this._rpcRequest('getFirstAvailableBlock', []);\n const res = create(unsafeRes, SlotRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get first available block: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch information about the current supply\n */\n async getSupply(\n config?: GetSupplyConfig | Commitment,\n ): Promise> {\n let configArg: GetSupplyConfig = {};\n if (typeof config === 'string') {\n configArg = {commitment: config};\n } else if (config) {\n configArg = {\n ...config,\n commitment: (config && config.commitment) || this.commitment,\n };\n } else {\n configArg = {\n commitment: this.commitment,\n };\n }\n\n const unsafeRes = await this._rpcRequest('getSupply', [configArg]);\n const res = create(unsafeRes, GetSupplyRpcResult);\n if ('error' in res) {\n throw new Error('failed to get supply: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current supply of a token mint\n */\n async getTokenSupply(\n tokenMintAddress: PublicKey,\n commitment?: Commitment,\n ): Promise> {\n const args = this._buildArgs([tokenMintAddress.toBase58()], commitment);\n const unsafeRes = await this._rpcRequest('getTokenSupply', args);\n const res = create(unsafeRes, jsonRpcResultAndContext(TokenAmountResult));\n if ('error' in res) {\n throw new Error('failed to get token supply: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current balance of a token account\n */\n async getTokenAccountBalance(\n tokenAddress: PublicKey,\n commitment?: Commitment,\n ): Promise> {\n const args = this._buildArgs([tokenAddress.toBase58()], commitment);\n const unsafeRes = await this._rpcRequest('getTokenAccountBalance', args);\n const res = create(unsafeRes, jsonRpcResultAndContext(TokenAmountResult));\n if ('error' in res) {\n throw new Error(\n 'failed to get token account balance: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch all the token accounts owned by the specified account\n *\n * @return {Promise}>>>}\n */\n async getTokenAccountsByOwner(\n ownerAddress: PublicKey,\n filter: TokenAccountsFilter,\n commitment?: Commitment,\n ): Promise<\n RpcResponseAndContext<\n Array<{pubkey: PublicKey; account: AccountInfo}>\n >\n > {\n let _args: any[] = [ownerAddress.toBase58()];\n if ('mint' in filter) {\n _args.push({mint: filter.mint.toBase58()});\n } else {\n _args.push({programId: filter.programId.toBase58()});\n }\n\n const args = this._buildArgs(_args, commitment, 'base64');\n const unsafeRes = await this._rpcRequest('getTokenAccountsByOwner', args);\n const res = create(unsafeRes, GetTokenAccountsByOwner);\n if ('error' in res) {\n throw new Error(\n 'failed to get token accounts owned by account ' +\n ownerAddress.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch parsed token accounts owned by the specified account\n *\n * @return {Promise}>>>}\n */\n async getParsedTokenAccountsByOwner(\n ownerAddress: PublicKey,\n filter: TokenAccountsFilter,\n commitment?: Commitment,\n ): Promise<\n RpcResponseAndContext<\n Array<{pubkey: PublicKey; account: AccountInfo}>\n >\n > {\n let _args: any[] = [ownerAddress.toBase58()];\n if ('mint' in filter) {\n _args.push({mint: filter.mint.toBase58()});\n } else {\n _args.push({programId: filter.programId.toBase58()});\n }\n\n const args = this._buildArgs(_args, commitment, 'jsonParsed');\n const unsafeRes = await this._rpcRequest('getTokenAccountsByOwner', args);\n const res = create(unsafeRes, GetParsedTokenAccountsByOwner);\n if ('error' in res) {\n throw new Error(\n 'failed to get token accounts owned by account ' +\n ownerAddress.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch the 20 largest accounts with their current balances\n */\n async getLargestAccounts(\n config?: GetLargestAccountsConfig,\n ): Promise>> {\n const arg = {\n ...config,\n commitment: (config && config.commitment) || this.commitment,\n };\n const args = arg.filter || arg.commitment ? [arg] : [];\n const unsafeRes = await this._rpcRequest('getLargestAccounts', args);\n const res = create(unsafeRes, GetLargestAccountsRpcResult);\n if ('error' in res) {\n throw new Error('failed to get largest accounts: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the 20 largest token accounts with their current balances\n * for a given mint.\n */\n async getTokenLargestAccounts(\n mintAddress: PublicKey,\n commitment?: Commitment,\n ): Promise>> {\n const args = this._buildArgs([mintAddress.toBase58()], commitment);\n const unsafeRes = await this._rpcRequest('getTokenLargestAccounts', args);\n const res = create(unsafeRes, GetTokenLargestAccountsResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get token largest accounts: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch all the account info for the specified public key, return with context\n */\n async getAccountInfoAndContext(\n publicKey: PublicKey,\n commitment?: Commitment,\n ): Promise | null>> {\n const args = this._buildArgs([publicKey.toBase58()], commitment, 'base64');\n const unsafeRes = await this._rpcRequest('getAccountInfo', args);\n const res = create(\n unsafeRes,\n jsonRpcResultAndContext(nullable(AccountInfoResult)),\n );\n if ('error' in res) {\n throw new Error(\n 'failed to get info about account ' +\n publicKey.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch parsed account info for the specified public key\n */\n async getParsedAccountInfo(\n publicKey: PublicKey,\n commitment?: Commitment,\n ): Promise<\n RpcResponseAndContext | null>\n > {\n const args = this._buildArgs(\n [publicKey.toBase58()],\n commitment,\n 'jsonParsed',\n );\n const unsafeRes = await this._rpcRequest('getAccountInfo', args);\n const res = create(\n unsafeRes,\n jsonRpcResultAndContext(nullable(ParsedAccountInfoResult)),\n );\n if ('error' in res) {\n throw new Error(\n 'failed to get info about account ' +\n publicKey.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch all the account info for the specified public key\n */\n async getAccountInfo(\n publicKey: PublicKey,\n commitment?: Commitment,\n ): Promise | null> {\n try {\n const res = await this.getAccountInfoAndContext(publicKey, commitment);\n return res.value;\n } catch (e) {\n throw new Error(\n 'failed to get info about account ' + publicKey.toBase58() + ': ' + e,\n );\n }\n }\n\n /**\n * Fetch all the account info for multiple accounts specified by an array of public keys\n */\n async getMultipleAccountsInfo(\n publicKeys: PublicKey[],\n configOrCommitment?: GetMultipleAccountsConfig | Commitment,\n ): Promise<(AccountInfo | null)[]> {\n const keys = publicKeys.map(key => key.toBase58());\n\n let commitment;\n let encoding: 'base64' | 'jsonParsed' = 'base64';\n if (configOrCommitment) {\n if (typeof configOrCommitment === 'string') {\n commitment = configOrCommitment;\n encoding = 'base64';\n } else {\n commitment = configOrCommitment.commitment;\n encoding = configOrCommitment.encoding || 'base64';\n }\n }\n\n const args = this._buildArgs([keys], commitment, encoding);\n const unsafeRes = await this._rpcRequest('getMultipleAccounts', args);\n const res = create(\n unsafeRes,\n jsonRpcResultAndContext(array(nullable(ParsedAccountInfoResult))),\n );\n if ('error' in res) {\n throw new Error(\n 'failed to get info for accounts ' + keys + ': ' + res.error.message,\n );\n }\n return res.result.value;\n }\n\n /**\n * Returns epoch activation information for a stake account that has been delegated\n */\n async getStakeActivation(\n publicKey: PublicKey,\n commitment?: Commitment,\n epoch?: number,\n ): Promise {\n const args = this._buildArgs(\n [publicKey.toBase58()],\n commitment,\n undefined,\n epoch !== undefined ? {epoch} : undefined,\n );\n\n const unsafeRes = await this._rpcRequest('getStakeActivation', args);\n const res = create(unsafeRes, jsonRpcResult(StakeActivationResult));\n if ('error' in res) {\n throw new Error(\n `failed to get Stake Activation ${publicKey.toBase58()}: ${\n res.error.message\n }`,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch all the accounts owned by the specified program id\n *\n * @return {Promise}>>}\n */\n async getProgramAccounts(\n programId: PublicKey,\n configOrCommitment?: GetProgramAccountsConfig | Commitment,\n ): Promise}>> {\n const extra: Pick = {};\n\n let commitment;\n let encoding;\n if (configOrCommitment) {\n if (typeof configOrCommitment === 'string') {\n commitment = configOrCommitment;\n } else {\n commitment = configOrCommitment.commitment;\n encoding = configOrCommitment.encoding;\n\n if (configOrCommitment.dataSlice) {\n extra.dataSlice = configOrCommitment.dataSlice;\n }\n if (configOrCommitment.filters) {\n extra.filters = configOrCommitment.filters;\n }\n }\n }\n\n const args = this._buildArgs(\n [programId.toBase58()],\n commitment,\n encoding || 'base64',\n extra,\n );\n const unsafeRes = await this._rpcRequest('getProgramAccounts', args);\n const res = create(unsafeRes, jsonRpcResult(array(KeyedAccountInfoResult)));\n if ('error' in res) {\n throw new Error(\n 'failed to get accounts owned by program ' +\n programId.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch and parse all the accounts owned by the specified program id\n *\n * @return {Promise}>>}\n */\n async getParsedProgramAccounts(\n programId: PublicKey,\n configOrCommitment?: GetParsedProgramAccountsConfig | Commitment,\n ): Promise<\n Array<{\n pubkey: PublicKey;\n account: AccountInfo;\n }>\n > {\n const extra: Pick = {};\n\n let commitment;\n if (configOrCommitment) {\n if (typeof configOrCommitment === 'string') {\n commitment = configOrCommitment;\n } else {\n commitment = configOrCommitment.commitment;\n\n if (configOrCommitment.filters) {\n extra.filters = configOrCommitment.filters;\n }\n }\n }\n\n const args = this._buildArgs(\n [programId.toBase58()],\n commitment,\n 'jsonParsed',\n extra,\n );\n const unsafeRes = await this._rpcRequest('getProgramAccounts', args);\n const res = create(\n unsafeRes,\n jsonRpcResult(array(KeyedParsedAccountInfoResult)),\n );\n if ('error' in res) {\n throw new Error(\n 'failed to get accounts owned by program ' +\n programId.toBase58() +\n ': ' +\n res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Confirm the transaction identified by the specified signature.\n */\n async confirmTransaction(\n signature: TransactionSignature,\n commitment?: Commitment,\n ): Promise> {\n let decodedSignature;\n try {\n decodedSignature = bs58.decode(signature);\n } catch (err) {\n throw new Error('signature must be base58 encoded: ' + signature);\n }\n\n assert(decodedSignature.length === 64, 'signature has invalid length');\n\n const start = Date.now();\n const subscriptionCommitment = commitment || this.commitment;\n\n let subscriptionId;\n let response: RpcResponseAndContext | null = null;\n const confirmPromise = new Promise((resolve, reject) => {\n try {\n subscriptionId = this.onSignature(\n signature,\n (result: SignatureResult, context: Context) => {\n subscriptionId = undefined;\n response = {\n context,\n value: result,\n };\n resolve(null);\n },\n subscriptionCommitment,\n );\n } catch (err) {\n reject(err);\n }\n });\n\n let timeoutMs = this._confirmTransactionInitialTimeout || 60 * 1000;\n switch (subscriptionCommitment) {\n case 'processed':\n case 'recent':\n case 'single':\n case 'confirmed':\n case 'singleGossip': {\n timeoutMs = this._confirmTransactionInitialTimeout || 30 * 1000;\n break;\n }\n // exhaust enums to ensure full coverage\n case 'finalized':\n case 'max':\n case 'root':\n }\n\n try {\n await promiseTimeout(confirmPromise, timeoutMs);\n } finally {\n if (subscriptionId) {\n this.removeSignatureListener(subscriptionId);\n }\n }\n\n if (response === null) {\n const duration = (Date.now() - start) / 1000;\n throw new Error(\n `Transaction was not confirmed in ${duration.toFixed(\n 2,\n )} seconds. It is unknown if it succeeded or failed. Check signature ${signature} using the Solana Explorer or CLI tools.`,\n );\n }\n\n return response;\n }\n\n /**\n * Return the list of nodes that are currently participating in the cluster\n */\n async getClusterNodes(): Promise> {\n const unsafeRes = await this._rpcRequest('getClusterNodes', []);\n const res = create(unsafeRes, jsonRpcResult(array(ContactInfoResult)));\n if ('error' in res) {\n throw new Error('failed to get cluster nodes: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Return the list of nodes that are currently participating in the cluster\n */\n async getVoteAccounts(commitment?: Commitment): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getVoteAccounts', args);\n const res = create(unsafeRes, GetVoteAccounts);\n if ('error' in res) {\n throw new Error('failed to get vote accounts: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current slot that the node is processing\n */\n async getSlot(commitment?: Commitment): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getSlot', args);\n const res = create(unsafeRes, jsonRpcResult(number()));\n if ('error' in res) {\n throw new Error('failed to get slot: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current slot leader of the cluster\n */\n async getSlotLeader(commitment?: Commitment): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getSlotLeader', args);\n const res = create(unsafeRes, jsonRpcResult(string()));\n if ('error' in res) {\n throw new Error('failed to get slot leader: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch `limit` number of slot leaders starting from `startSlot`\n *\n * @param startSlot fetch slot leaders starting from this slot\n * @param limit number of slot leaders to return\n */\n async getSlotLeaders(\n startSlot: number,\n limit: number,\n ): Promise> {\n const args = [startSlot, limit];\n const unsafeRes = await this._rpcRequest('getSlotLeaders', args);\n const res = create(unsafeRes, jsonRpcResult(array(PublicKeyFromString)));\n if ('error' in res) {\n throw new Error('failed to get slot leaders: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current status of a signature\n */\n async getSignatureStatus(\n signature: TransactionSignature,\n config?: SignatureStatusConfig,\n ): Promise> {\n const {context, value: values} = await this.getSignatureStatuses(\n [signature],\n config,\n );\n assert(values.length === 1);\n const value = values[0];\n return {context, value};\n }\n\n /**\n * Fetch the current statuses of a batch of signatures\n */\n async getSignatureStatuses(\n signatures: Array,\n config?: SignatureStatusConfig,\n ): Promise>> {\n const params: any[] = [signatures];\n if (config) {\n params.push(config);\n }\n const unsafeRes = await this._rpcRequest('getSignatureStatuses', params);\n const res = create(unsafeRes, GetSignatureStatusesRpcResult);\n if ('error' in res) {\n throw new Error('failed to get signature status: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current transaction count of the cluster\n */\n async getTransactionCount(commitment?: Commitment): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getTransactionCount', args);\n const res = create(unsafeRes, jsonRpcResult(number()));\n if ('error' in res) {\n throw new Error('failed to get transaction count: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the current total currency supply of the cluster in lamports\n *\n * @deprecated Deprecated since v1.2.8. Please use {@link getSupply} instead.\n */\n async getTotalSupply(commitment?: Commitment): Promise {\n const result = await this.getSupply({\n commitment,\n excludeNonCirculatingAccountsList: true,\n });\n return result.value.total;\n }\n\n /**\n * Fetch the cluster InflationGovernor parameters\n */\n async getInflationGovernor(\n commitment?: Commitment,\n ): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getInflationGovernor', args);\n const res = create(unsafeRes, GetInflationGovernorRpcResult);\n if ('error' in res) {\n throw new Error('failed to get inflation: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the inflation reward for a list of addresses for an epoch\n */\n async getInflationReward(\n addresses: PublicKey[],\n epoch?: number,\n commitment?: Commitment,\n ): Promise<(InflationReward | null)[]> {\n const args = this._buildArgs(\n [addresses.map(pubkey => pubkey.toBase58())],\n commitment,\n undefined,\n {\n epoch,\n },\n );\n const unsafeRes = await this._rpcRequest('getInflationReward', args);\n const res = create(unsafeRes, GetInflationRewardResult);\n if ('error' in res) {\n throw new Error('failed to get inflation reward: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the Epoch Info parameters\n */\n async getEpochInfo(commitment?: Commitment): Promise {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getEpochInfo', args);\n const res = create(unsafeRes, GetEpochInfoRpcResult);\n if ('error' in res) {\n throw new Error('failed to get epoch info: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the Epoch Schedule parameters\n */\n async getEpochSchedule(): Promise {\n const unsafeRes = await this._rpcRequest('getEpochSchedule', []);\n const res = create(unsafeRes, GetEpochScheduleRpcResult);\n if ('error' in res) {\n throw new Error('failed to get epoch schedule: ' + res.error.message);\n }\n const epochSchedule = res.result;\n return new EpochSchedule(\n epochSchedule.slotsPerEpoch,\n epochSchedule.leaderScheduleSlotOffset,\n epochSchedule.warmup,\n epochSchedule.firstNormalEpoch,\n epochSchedule.firstNormalSlot,\n );\n }\n\n /**\n * Fetch the leader schedule for the current epoch\n * @return {Promise>}\n */\n async getLeaderSchedule(): Promise {\n const unsafeRes = await this._rpcRequest('getLeaderSchedule', []);\n const res = create(unsafeRes, GetLeaderScheduleRpcResult);\n if ('error' in res) {\n throw new Error('failed to get leader schedule: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the minimum balance needed to exempt an account of `dataLength`\n * size from rent\n */\n async getMinimumBalanceForRentExemption(\n dataLength: number,\n commitment?: Commitment,\n ): Promise {\n const args = this._buildArgs([dataLength], commitment);\n const unsafeRes = await this._rpcRequest(\n 'getMinimumBalanceForRentExemption',\n args,\n );\n const res = create(unsafeRes, GetMinimumBalanceForRentExemptionRpcResult);\n if ('error' in res) {\n console.warn('Unable to fetch minimum balance for rent exemption');\n return 0;\n }\n return res.result;\n }\n\n /**\n * Fetch a recent blockhash from the cluster, return with context\n * @return {Promise>}\n */\n async getRecentBlockhashAndContext(\n commitment?: Commitment,\n ): Promise<\n RpcResponseAndContext<{blockhash: Blockhash; feeCalculator: FeeCalculator}>\n > {\n const args = this._buildArgs([], commitment);\n const unsafeRes = await this._rpcRequest('getRecentBlockhash', args);\n const res = create(unsafeRes, GetRecentBlockhashAndContextRpcResult);\n if ('error' in res) {\n throw new Error('failed to get recent blockhash: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch recent performance samples\n * @return {Promise>}\n */\n async getRecentPerformanceSamples(\n limit?: number,\n ): Promise> {\n const args = this._buildArgs(limit ? [limit] : []);\n const unsafeRes = await this._rpcRequest(\n 'getRecentPerformanceSamples',\n args,\n );\n const res = create(unsafeRes, GetRecentPerformanceSamplesRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get recent performance samples: ' + res.error.message,\n );\n }\n\n return res.result;\n }\n\n /**\n * Fetch the fee calculator for a recent blockhash from the cluster, return with context\n */\n async getFeeCalculatorForBlockhash(\n blockhash: Blockhash,\n commitment?: Commitment,\n ): Promise> {\n const args = this._buildArgs([blockhash], commitment);\n const unsafeRes = await this._rpcRequest(\n 'getFeeCalculatorForBlockhash',\n args,\n );\n\n const res = create(unsafeRes, GetFeeCalculatorRpcResult);\n if ('error' in res) {\n throw new Error('failed to get fee calculator: ' + res.error.message);\n }\n const {context, value} = res.result;\n return {\n context,\n value: value !== null ? value.feeCalculator : null,\n };\n }\n\n /**\n * Fetch the fee for a message from the cluster, return with context\n */\n async getFeeForMessage(\n message: Message,\n commitment?: Commitment,\n ): Promise> {\n const wireMessage = message.serialize().toString('base64');\n const args = this._buildArgs([wireMessage], commitment);\n const unsafeRes = await this._rpcRequest('getFeeForMessage', args);\n\n const res = create(unsafeRes, jsonRpcResultAndContext(nullable(number())));\n if ('error' in res) {\n throw new Error('failed to get slot: ' + res.error.message);\n }\n if (res.result === null) {\n throw new Error('invalid blockhash');\n }\n return res.result as unknown as RpcResponseAndContext;\n }\n\n /**\n * Fetch a recent blockhash from the cluster\n * @return {Promise<{blockhash: Blockhash, feeCalculator: FeeCalculator}>}\n */\n async getRecentBlockhash(\n commitment?: Commitment,\n ): Promise<{blockhash: Blockhash; feeCalculator: FeeCalculator}> {\n try {\n const res = await this.getRecentBlockhashAndContext(commitment);\n return res.value;\n } catch (e) {\n throw new Error('failed to get recent blockhash: ' + e);\n }\n }\n\n /**\n * Fetch the node version\n */\n async getVersion(): Promise {\n const unsafeRes = await this._rpcRequest('getVersion', []);\n const res = create(unsafeRes, jsonRpcResult(VersionResult));\n if ('error' in res) {\n throw new Error('failed to get version: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch the genesis hash\n */\n async getGenesisHash(): Promise {\n const unsafeRes = await this._rpcRequest('getGenesisHash', []);\n const res = create(unsafeRes, jsonRpcResult(string()));\n if ('error' in res) {\n throw new Error('failed to get genesis hash: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch a processed block from the cluster.\n */\n async getBlock(\n slot: number,\n opts?: {commitment?: Finality},\n ): Promise {\n const args = this._buildArgsAtLeastConfirmed(\n [slot],\n opts && opts.commitment,\n );\n const unsafeRes = await this._rpcRequest('getConfirmedBlock', args);\n const res = create(unsafeRes, GetConfirmedBlockRpcResult);\n\n if ('error' in res) {\n throw new Error('failed to get confirmed block: ' + res.error.message);\n }\n\n const result = res.result;\n if (!result) return result;\n\n return {\n ...result,\n transactions: result.transactions.map(({transaction, meta}) => {\n const message = new Message(transaction.message);\n return {\n meta,\n transaction: {\n ...transaction,\n message,\n },\n };\n }),\n };\n }\n\n /**\n * Fetch a processed transaction from the cluster.\n */\n async getTransaction(\n signature: string,\n opts?: {commitment?: Finality},\n ): Promise {\n const args = this._buildArgsAtLeastConfirmed(\n [signature],\n opts && opts.commitment,\n );\n const unsafeRes = await this._rpcRequest('getConfirmedTransaction', args);\n const res = create(unsafeRes, GetConfirmedTransactionRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get confirmed transaction: ' + res.error.message,\n );\n }\n\n const result = res.result;\n if (!result) return result;\n\n return {\n ...result,\n transaction: {\n ...result.transaction,\n message: new Message(result.transaction.message),\n },\n };\n }\n\n /**\n * Fetch a list of Transactions and transaction statuses from the cluster\n * for a confirmed block.\n *\n * @deprecated Deprecated since v1.13.0. Please use {@link getBlock} instead.\n */\n async getConfirmedBlock(\n slot: number,\n commitment?: Finality,\n ): Promise {\n const result = await this.getBlock(slot, {commitment});\n if (!result) {\n throw new Error('Confirmed block ' + slot + ' not found');\n }\n\n return {\n ...result,\n transactions: result.transactions.map(({transaction, meta}) => {\n return {\n meta,\n transaction: Transaction.populate(\n transaction.message,\n transaction.signatures,\n ),\n };\n }),\n };\n }\n\n /**\n * Fetch confirmed blocks between two slots\n */\n async getBlocks(\n startSlot: number,\n endSlot?: number,\n commitment?: Finality,\n ): Promise> {\n const args = this._buildArgsAtLeastConfirmed(\n endSlot !== undefined ? [startSlot, endSlot] : [startSlot],\n commitment,\n );\n const unsafeRes = await this._rpcRequest('getConfirmedBlocks', args);\n const res = create(unsafeRes, jsonRpcResult(array(number())));\n if ('error' in res) {\n throw new Error('failed to get blocks: ' + res.error.message);\n }\n return res.result;\n }\n\n /**\n * Fetch a list of Signatures from the cluster for a confirmed block, excluding rewards\n */\n async getConfirmedBlockSignatures(\n slot: number,\n commitment?: Finality,\n ): Promise {\n const args = this._buildArgsAtLeastConfirmed(\n [slot],\n commitment,\n undefined,\n {\n transactionDetails: 'signatures',\n rewards: false,\n },\n );\n const unsafeRes = await this._rpcRequest('getConfirmedBlock', args);\n const res = create(unsafeRes, GetConfirmedBlockSignaturesRpcResult);\n if ('error' in res) {\n throw new Error('failed to get confirmed block: ' + res.error.message);\n }\n const result = res.result;\n if (!result) {\n throw new Error('Confirmed block ' + slot + ' not found');\n }\n return result;\n }\n\n /**\n * Fetch a transaction details for a confirmed transaction\n */\n async getConfirmedTransaction(\n signature: TransactionSignature,\n commitment?: Finality,\n ): Promise {\n const result = await this.getTransaction(signature, {commitment});\n if (!result) return result;\n const {message, signatures} = result.transaction;\n return {\n ...result,\n transaction: Transaction.populate(message, signatures),\n };\n }\n\n /**\n * Fetch parsed transaction details for a confirmed transaction\n */\n async getParsedConfirmedTransaction(\n signature: TransactionSignature,\n commitment?: Finality,\n ): Promise {\n const args = this._buildArgsAtLeastConfirmed(\n [signature],\n commitment,\n 'jsonParsed',\n );\n const unsafeRes = await this._rpcRequest('getConfirmedTransaction', args);\n const res = create(unsafeRes, GetParsedConfirmedTransactionRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get confirmed transaction: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch parsed transaction details for a batch of confirmed transactions\n */\n async getParsedConfirmedTransactions(\n signatures: TransactionSignature[],\n commitment?: Finality,\n ): Promise<(ParsedConfirmedTransaction | null)[]> {\n const batch = signatures.map(signature => {\n const args = this._buildArgsAtLeastConfirmed(\n [signature],\n commitment,\n 'jsonParsed',\n );\n return {\n methodName: 'getConfirmedTransaction',\n args,\n };\n });\n\n const unsafeRes = await this._rpcBatchRequest(batch);\n const res = unsafeRes.map((unsafeRes: any) => {\n const res = create(unsafeRes, GetParsedConfirmedTransactionRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get confirmed transactions: ' + res.error.message,\n );\n }\n return res.result;\n });\n\n return res;\n }\n\n /**\n * Fetch a list of all the confirmed signatures for transactions involving an address\n * within a specified slot range. Max range allowed is 10,000 slots.\n *\n * @deprecated Deprecated since v1.3. Please use {@link getConfirmedSignaturesForAddress2} instead.\n *\n * @param address queried address\n * @param startSlot start slot, inclusive\n * @param endSlot end slot, inclusive\n */\n async getConfirmedSignaturesForAddress(\n address: PublicKey,\n startSlot: number,\n endSlot: number,\n ): Promise> {\n let options: any = {};\n\n let firstAvailableBlock = await this.getFirstAvailableBlock();\n while (!('until' in options)) {\n startSlot--;\n if (startSlot <= 0 || startSlot < firstAvailableBlock) {\n break;\n }\n\n try {\n const block = await this.getConfirmedBlockSignatures(\n startSlot,\n 'finalized',\n );\n if (block.signatures.length > 0) {\n options.until =\n block.signatures[block.signatures.length - 1].toString();\n }\n } catch (err) {\n if (err instanceof Error && err.message.includes('skipped')) {\n continue;\n } else {\n throw err;\n }\n }\n }\n\n let highestConfirmedRoot = await this.getSlot('finalized');\n while (!('before' in options)) {\n endSlot++;\n if (endSlot > highestConfirmedRoot) {\n break;\n }\n\n try {\n const block = await this.getConfirmedBlockSignatures(endSlot);\n if (block.signatures.length > 0) {\n options.before =\n block.signatures[block.signatures.length - 1].toString();\n }\n } catch (err) {\n if (err instanceof Error && err.message.includes('skipped')) {\n continue;\n } else {\n throw err;\n }\n }\n }\n\n const confirmedSignatureInfo = await this.getConfirmedSignaturesForAddress2(\n address,\n options,\n );\n return confirmedSignatureInfo.map(info => info.signature);\n }\n\n /**\n * Returns confirmed signatures for transactions involving an\n * address backwards in time from the provided signature or most recent confirmed block\n *\n *\n * @param address queried address\n * @param options\n */\n async getConfirmedSignaturesForAddress2(\n address: PublicKey,\n options?: ConfirmedSignaturesForAddress2Options,\n commitment?: Finality,\n ): Promise> {\n const args = this._buildArgsAtLeastConfirmed(\n [address.toBase58()],\n commitment,\n undefined,\n options,\n );\n const unsafeRes = await this._rpcRequest(\n 'getConfirmedSignaturesForAddress2',\n args,\n );\n const res = create(unsafeRes, GetConfirmedSignaturesForAddress2RpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get confirmed signatures for address: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Returns confirmed signatures for transactions involving an\n * address backwards in time from the provided signature or most recent confirmed block\n *\n *\n * @param address queried address\n * @param options\n */\n async getSignaturesForAddress(\n address: PublicKey,\n options?: SignaturesForAddressOptions,\n commitment?: Finality,\n ): Promise> {\n const args = this._buildArgsAtLeastConfirmed(\n [address.toBase58()],\n commitment,\n undefined,\n options,\n );\n const unsafeRes = await this._rpcRequest('getSignaturesForAddress', args);\n const res = create(unsafeRes, GetSignaturesForAddressRpcResult);\n if ('error' in res) {\n throw new Error(\n 'failed to get signatures for address: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * Fetch the contents of a Nonce account from the cluster, return with context\n */\n async getNonceAndContext(\n nonceAccount: PublicKey,\n commitment?: Commitment,\n ): Promise> {\n const {context, value: accountInfo} = await this.getAccountInfoAndContext(\n nonceAccount,\n commitment,\n );\n\n let value = null;\n if (accountInfo !== null) {\n value = NonceAccount.fromAccountData(accountInfo.data);\n }\n\n return {\n context,\n value,\n };\n }\n\n /**\n * Fetch the contents of a Nonce account from the cluster\n */\n async getNonce(\n nonceAccount: PublicKey,\n commitment?: Commitment,\n ): Promise {\n return await this.getNonceAndContext(nonceAccount, commitment)\n .then(x => x.value)\n .catch(e => {\n throw new Error(\n 'failed to get nonce for account ' +\n nonceAccount.toBase58() +\n ': ' +\n e,\n );\n });\n }\n\n /**\n * Request an allocation of lamports to the specified address\n *\n * ```typescript\n * import { Connection, PublicKey, LAMPORTS_PER_SOL } from \"@solana/web3.js\";\n *\n * (async () => {\n * const connection = new Connection(\"https://api.testnet.solana.com\", \"confirmed\");\n * const myAddress = new PublicKey(\"2nr1bHFT86W9tGnyvmYW4vcHKsQB3sVQfnddasz4kExM\");\n * const signature = await connection.requestAirdrop(myAddress, LAMPORTS_PER_SOL);\n * await connection.confirmTransaction(signature);\n * })();\n * ```\n */\n async requestAirdrop(\n to: PublicKey,\n lamports: number,\n ): Promise {\n const unsafeRes = await this._rpcRequest('requestAirdrop', [\n to.toBase58(),\n lamports,\n ]);\n const res = create(unsafeRes, RequestAirdropRpcResult);\n if ('error' in res) {\n throw new Error(\n 'airdrop to ' + to.toBase58() + ' failed: ' + res.error.message,\n );\n }\n return res.result;\n }\n\n /**\n * @internal\n */\n async _recentBlockhash(disableCache: boolean): Promise {\n if (!disableCache) {\n // Wait for polling to finish\n while (this._pollingBlockhash) {\n await sleep(100);\n }\n const timeSinceFetch = Date.now() - this._blockhashInfo.lastFetch;\n const expired = timeSinceFetch >= BLOCKHASH_CACHE_TIMEOUT_MS;\n if (this._blockhashInfo.recentBlockhash !== null && !expired) {\n return this._blockhashInfo.recentBlockhash;\n }\n }\n\n return await this._pollNewBlockhash();\n }\n\n /**\n * @internal\n */\n async _pollNewBlockhash(): Promise {\n this._pollingBlockhash = true;\n try {\n const startTime = Date.now();\n for (let i = 0; i < 50; i++) {\n const {blockhash} = await this.getRecentBlockhash('finalized');\n\n if (this._blockhashInfo.recentBlockhash != blockhash) {\n this._blockhashInfo = {\n recentBlockhash: blockhash,\n lastFetch: Date.now(),\n transactionSignatures: [],\n simulatedSignatures: [],\n };\n return blockhash;\n }\n\n // Sleep for approximately half a slot\n await sleep(MS_PER_SLOT / 2);\n }\n\n throw new Error(\n `Unable to obtain a new blockhash after ${Date.now() - startTime}ms`,\n );\n } finally {\n this._pollingBlockhash = false;\n }\n }\n\n /**\n * Simulate a transaction\n */\n async simulateTransaction(\n transactionOrMessage: Transaction | Message,\n signers?: Array,\n includeAccounts?: boolean | Array,\n ): Promise> {\n let transaction;\n if (transactionOrMessage instanceof Transaction) {\n transaction = transactionOrMessage;\n } else {\n transaction = Transaction.populate(transactionOrMessage);\n }\n\n if (transaction.nonceInfo && signers) {\n transaction.sign(...signers);\n } else {\n let disableCache = this._disableBlockhashCaching;\n for (;;) {\n transaction.recentBlockhash = await this._recentBlockhash(disableCache);\n\n if (!signers) break;\n\n transaction.sign(...signers);\n if (!transaction.signature) {\n throw new Error('!signature'); // should never happen\n }\n\n const signature = transaction.signature.toString('base64');\n if (\n !this._blockhashInfo.simulatedSignatures.includes(signature) &&\n !this._blockhashInfo.transactionSignatures.includes(signature)\n ) {\n // The signature of this transaction has not been seen before with the\n // current recentBlockhash, all done. Let's break\n this._blockhashInfo.simulatedSignatures.push(signature);\n break;\n } else {\n // This transaction would be treated as duplicate (its derived signature\n // matched to one of already recorded signatures).\n // So, we must fetch a new blockhash for a different signature by disabling\n // our cache not to wait for the cache expiration (BLOCKHASH_CACHE_TIMEOUT_MS).\n disableCache = true;\n }\n }\n }\n\n const message = transaction._compile();\n const signData = message.serialize();\n const wireTransaction = transaction._serialize(signData);\n const encodedTransaction = wireTransaction.toString('base64');\n const config: any = {\n encoding: 'base64',\n commitment: this.commitment,\n };\n\n if (includeAccounts) {\n const addresses = (\n Array.isArray(includeAccounts)\n ? includeAccounts\n : message.nonProgramIds()\n ).map(key => key.toBase58());\n\n config['accounts'] = {\n encoding: 'base64',\n addresses,\n };\n }\n\n if (signers) {\n config.sigVerify = true;\n }\n\n const args = [encodedTransaction, config];\n const unsafeRes = await this._rpcRequest('simulateTransaction', args);\n const res = create(unsafeRes, SimulatedTransactionResponseStruct);\n if ('error' in res) {\n let logs;\n if ('data' in res.error) {\n logs = res.error.data.logs;\n if (logs && Array.isArray(logs)) {\n const traceIndent = '\\n ';\n const logTrace = traceIndent + logs.join(traceIndent);\n console.error(res.error.message, logTrace);\n }\n }\n throw new SendTransactionError(\n 'failed to simulate transaction: ' + res.error.message,\n logs,\n );\n }\n return res.result;\n }\n\n /**\n * Sign and send a transaction\n */\n async sendTransaction(\n transaction: Transaction,\n signers: Array,\n options?: SendOptions,\n ): Promise {\n if (transaction.nonceInfo) {\n transaction.sign(...signers);\n } else {\n let disableCache = this._disableBlockhashCaching;\n for (;;) {\n transaction.recentBlockhash = await this._recentBlockhash(disableCache);\n transaction.sign(...signers);\n if (!transaction.signature) {\n throw new Error('!signature'); // should never happen\n }\n\n const signature = transaction.signature.toString('base64');\n if (!this._blockhashInfo.transactionSignatures.includes(signature)) {\n // The signature of this transaction has not been seen before with the\n // current recentBlockhash, all done. Let's break\n this._blockhashInfo.transactionSignatures.push(signature);\n break;\n } else {\n // This transaction would be treated as duplicate (its derived signature\n // matched to one of already recorded signatures).\n // So, we must fetch a new blockhash for a different signature by disabling\n // our cache not to wait for the cache expiration (BLOCKHASH_CACHE_TIMEOUT_MS).\n disableCache = true;\n }\n }\n }\n\n const wireTransaction = transaction.serialize();\n return await this.sendRawTransaction(wireTransaction, options);\n }\n\n /**\n * Send a transaction that has already been signed and serialized into the\n * wire format\n */\n async sendRawTransaction(\n rawTransaction: Buffer | Uint8Array | Array,\n options?: SendOptions,\n ): Promise {\n const encodedTransaction = toBuffer(rawTransaction).toString('base64');\n const result = await this.sendEncodedTransaction(\n encodedTransaction,\n options,\n );\n return result;\n }\n\n /**\n * Send a transaction that has already been signed, serialized into the\n * wire format, and encoded as a base64 string\n */\n async sendEncodedTransaction(\n encodedTransaction: string,\n options?: SendOptions,\n ): Promise {\n const config: any = {encoding: 'base64'};\n const skipPreflight = options && options.skipPreflight;\n const preflightCommitment =\n (options && options.preflightCommitment) || this.commitment;\n\n if (skipPreflight) {\n config.skipPreflight = skipPreflight;\n }\n if (preflightCommitment) {\n config.preflightCommitment = preflightCommitment;\n }\n\n const args = [encodedTransaction, config];\n const unsafeRes = await this._rpcRequest('sendTransaction', args);\n const res = create(unsafeRes, SendTransactionRpcResult);\n if ('error' in res) {\n let logs;\n if ('data' in res.error) {\n logs = res.error.data.logs;\n if (logs && Array.isArray(logs)) {\n const traceIndent = '\\n ';\n const logTrace = traceIndent + logs.join(traceIndent);\n console.error(res.error.message, logTrace);\n }\n }\n throw new SendTransactionError(\n 'failed to send transaction: ' + res.error.message,\n logs,\n );\n }\n return res.result;\n }\n\n /**\n * @internal\n */\n _wsOnOpen() {\n this._rpcWebSocketConnected = true;\n this._rpcWebSocketHeartbeat = setInterval(() => {\n // Ping server every 5s to prevent idle timeouts\n this._rpcWebSocket.notify('ping').catch(() => {});\n }, 5000);\n this._updateSubscriptions();\n }\n\n /**\n * @internal\n */\n _wsOnError(err: Error) {\n console.error('ws error:', err.message);\n }\n\n /**\n * @internal\n */\n _wsOnClose(code: number) {\n if (this._rpcWebSocketHeartbeat) {\n clearInterval(this._rpcWebSocketHeartbeat);\n this._rpcWebSocketHeartbeat = null;\n }\n\n if (code === 1000) {\n // explicit close, check if any subscriptions have been made since close\n this._updateSubscriptions();\n return;\n }\n\n // implicit close, prepare subscriptions for auto-reconnect\n this._resetSubscriptions();\n }\n\n /**\n * @internal\n */\n async _subscribe(\n sub: {subscriptionId: SubscriptionId | null},\n rpcMethod: string,\n rpcArgs: IWSRequestParams,\n ) {\n if (sub.subscriptionId == null) {\n sub.subscriptionId = 'subscribing';\n try {\n const id = await this._rpcWebSocket.call(rpcMethod, rpcArgs);\n if (typeof id === 'number' && sub.subscriptionId === 'subscribing') {\n // eslint-disable-next-line require-atomic-updates\n sub.subscriptionId = id;\n }\n } catch (err) {\n if (sub.subscriptionId === 'subscribing') {\n // eslint-disable-next-line require-atomic-updates\n sub.subscriptionId = null;\n }\n if (err instanceof Error) {\n console.error(\n `${rpcMethod} error for argument`,\n rpcArgs,\n err.message,\n );\n }\n }\n }\n }\n\n /**\n * @internal\n */\n async _unsubscribe(\n sub: {subscriptionId: SubscriptionId | null},\n rpcMethod: string,\n ) {\n const subscriptionId = sub.subscriptionId;\n if (subscriptionId != null && typeof subscriptionId != 'string') {\n const unsubscribeId: number = subscriptionId;\n try {\n await this._rpcWebSocket.call(rpcMethod, [unsubscribeId]);\n } catch (err) {\n if (err instanceof Error) {\n console.error(`${rpcMethod} error:`, err.message);\n }\n }\n }\n }\n\n /**\n * @internal\n */\n _resetSubscriptions() {\n Object.values(this._accountChangeSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n Object.values(this._programAccountChangeSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n Object.values(this._rootSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n Object.values(this._signatureSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n Object.values(this._slotSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n Object.values(this._slotUpdateSubscriptions).forEach(\n s => (s.subscriptionId = null),\n );\n }\n\n /**\n * @internal\n */\n _updateSubscriptions() {\n const accountKeys = Object.keys(this._accountChangeSubscriptions).map(\n Number,\n );\n const programKeys = Object.keys(\n this._programAccountChangeSubscriptions,\n ).map(Number);\n const slotKeys = Object.keys(this._slotSubscriptions).map(Number);\n const slotUpdateKeys = Object.keys(this._slotUpdateSubscriptions).map(\n Number,\n );\n const signatureKeys = Object.keys(this._signatureSubscriptions).map(Number);\n const rootKeys = Object.keys(this._rootSubscriptions).map(Number);\n const logsKeys = Object.keys(this._logsSubscriptions).map(Number);\n if (\n accountKeys.length === 0 &&\n programKeys.length === 0 &&\n slotKeys.length === 0 &&\n slotUpdateKeys.length === 0 &&\n signatureKeys.length === 0 &&\n rootKeys.length === 0 &&\n logsKeys.length === 0\n ) {\n if (this._rpcWebSocketConnected) {\n this._rpcWebSocketConnected = false;\n this._rpcWebSocketIdleTimeout = setTimeout(() => {\n this._rpcWebSocketIdleTimeout = null;\n this._rpcWebSocket.close();\n }, 500);\n }\n return;\n }\n\n if (this._rpcWebSocketIdleTimeout !== null) {\n clearTimeout(this._rpcWebSocketIdleTimeout);\n this._rpcWebSocketIdleTimeout = null;\n this._rpcWebSocketConnected = true;\n }\n\n if (!this._rpcWebSocketConnected) {\n this._rpcWebSocket.connect();\n return;\n }\n\n for (let id of accountKeys) {\n const sub = this._accountChangeSubscriptions[id];\n this._subscribe(\n sub,\n 'accountSubscribe',\n this._buildArgs([sub.publicKey], sub.commitment, 'base64'),\n );\n }\n\n for (let id of programKeys) {\n const sub = this._programAccountChangeSubscriptions[id];\n this._subscribe(\n sub,\n 'programSubscribe',\n this._buildArgs([sub.programId], sub.commitment, 'base64', {\n filters: sub.filters,\n }),\n );\n }\n\n for (let id of slotKeys) {\n const sub = this._slotSubscriptions[id];\n this._subscribe(sub, 'slotSubscribe', []);\n }\n\n for (let id of slotUpdateKeys) {\n const sub = this._slotUpdateSubscriptions[id];\n this._subscribe(sub, 'slotsUpdatesSubscribe', []);\n }\n\n for (let id of signatureKeys) {\n const sub = this._signatureSubscriptions[id];\n const args: any[] = [sub.signature];\n if (sub.options) args.push(sub.options);\n this._subscribe(sub, 'signatureSubscribe', args);\n }\n\n for (let id of rootKeys) {\n const sub = this._rootSubscriptions[id];\n this._subscribe(sub, 'rootSubscribe', []);\n }\n\n for (let id of logsKeys) {\n const sub = this._logsSubscriptions[id];\n let filter;\n if (typeof sub.filter === 'object') {\n filter = {mentions: [sub.filter.toString()]};\n } else {\n filter = sub.filter;\n }\n this._subscribe(\n sub,\n 'logsSubscribe',\n this._buildArgs([filter], sub.commitment),\n );\n }\n }\n\n /**\n * @internal\n */\n _wsOnAccountNotification(notification: object) {\n const res = create(notification, AccountNotificationResult);\n for (const sub of Object.values(this._accountChangeSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n sub.callback(res.result.value, res.result.context);\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked whenever the specified account changes\n *\n * @param publicKey Public key of the account to monitor\n * @param callback Function to invoke whenever the account is changed\n * @param commitment Specify the commitment level account changes must reach before notification\n * @return subscription id\n */\n onAccountChange(\n publicKey: PublicKey,\n callback: AccountChangeCallback,\n commitment?: Commitment,\n ): number {\n const id = ++this._accountChangeSubscriptionCounter;\n this._accountChangeSubscriptions[id] = {\n publicKey: publicKey.toBase58(),\n callback,\n commitment,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister an account notification callback\n *\n * @param id subscription id to deregister\n */\n async removeAccountChangeListener(id: number): Promise {\n if (this._accountChangeSubscriptions[id]) {\n const subInfo = this._accountChangeSubscriptions[id];\n delete this._accountChangeSubscriptions[id];\n await this._unsubscribe(subInfo, 'accountUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown account change id: ${id}`);\n }\n }\n\n /**\n * @internal\n */\n _wsOnProgramAccountNotification(notification: Object) {\n const res = create(notification, ProgramAccountNotificationResult);\n for (const sub of Object.values(this._programAccountChangeSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n const {value, context} = res.result;\n sub.callback(\n {\n accountId: value.pubkey,\n accountInfo: value.account,\n },\n context,\n );\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked whenever accounts owned by the\n * specified program change\n *\n * @param programId Public key of the program to monitor\n * @param callback Function to invoke whenever the account is changed\n * @param commitment Specify the commitment level account changes must reach before notification\n * @param filters The program account filters to pass into the RPC method\n * @return subscription id\n */\n onProgramAccountChange(\n programId: PublicKey,\n callback: ProgramAccountChangeCallback,\n commitment?: Commitment,\n filters?: GetProgramAccountsFilter[],\n ): number {\n const id = ++this._programAccountChangeSubscriptionCounter;\n this._programAccountChangeSubscriptions[id] = {\n programId: programId.toBase58(),\n callback,\n commitment,\n subscriptionId: null,\n filters,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister an account notification callback\n *\n * @param id subscription id to deregister\n */\n async removeProgramAccountChangeListener(id: number): Promise {\n if (this._programAccountChangeSubscriptions[id]) {\n const subInfo = this._programAccountChangeSubscriptions[id];\n delete this._programAccountChangeSubscriptions[id];\n await this._unsubscribe(subInfo, 'programUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown program account change id: ${id}`);\n }\n }\n\n /**\n * Registers a callback to be invoked whenever logs are emitted.\n */\n onLogs(\n filter: LogsFilter,\n callback: LogsCallback,\n commitment?: Commitment,\n ): number {\n const id = ++this._logsSubscriptionCounter;\n this._logsSubscriptions[id] = {\n filter,\n callback,\n commitment,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister a logs callback.\n *\n * @param id subscription id to deregister.\n */\n async removeOnLogsListener(id: number): Promise {\n if (!this._logsSubscriptions[id]) {\n throw new Error(`Unknown logs id: ${id}`);\n }\n const subInfo = this._logsSubscriptions[id];\n delete this._logsSubscriptions[id];\n await this._unsubscribe(subInfo, 'logsUnsubscribe');\n this._updateSubscriptions();\n }\n\n /**\n * @internal\n */\n _wsOnLogsNotification(notification: Object) {\n const res = create(notification, LogsNotificationResult);\n const keys = Object.keys(this._logsSubscriptions).map(Number);\n for (let id of keys) {\n const sub = this._logsSubscriptions[id];\n if (sub.subscriptionId === res.subscription) {\n sub.callback(res.result.value, res.result.context);\n return;\n }\n }\n }\n\n /**\n * @internal\n */\n _wsOnSlotNotification(notification: Object) {\n const res = create(notification, SlotNotificationResult);\n for (const sub of Object.values(this._slotSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n sub.callback(res.result);\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked upon slot changes\n *\n * @param callback Function to invoke whenever the slot changes\n * @return subscription id\n */\n onSlotChange(callback: SlotChangeCallback): number {\n const id = ++this._slotSubscriptionCounter;\n this._slotSubscriptions[id] = {\n callback,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister a slot notification callback\n *\n * @param id subscription id to deregister\n */\n async removeSlotChangeListener(id: number): Promise {\n if (this._slotSubscriptions[id]) {\n const subInfo = this._slotSubscriptions[id];\n delete this._slotSubscriptions[id];\n await this._unsubscribe(subInfo, 'slotUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown slot change id: ${id}`);\n }\n }\n\n /**\n * @internal\n */\n _wsOnSlotUpdatesNotification(notification: Object) {\n const res = create(notification, SlotUpdateNotificationResult);\n for (const sub of Object.values(this._slotUpdateSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n sub.callback(res.result);\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked upon slot updates. {@link SlotUpdate}'s\n * may be useful to track live progress of a cluster.\n *\n * @param callback Function to invoke whenever the slot updates\n * @return subscription id\n */\n onSlotUpdate(callback: SlotUpdateCallback): number {\n const id = ++this._slotUpdateSubscriptionCounter;\n this._slotUpdateSubscriptions[id] = {\n callback,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister a slot update notification callback\n *\n * @param id subscription id to deregister\n */\n async removeSlotUpdateListener(id: number): Promise {\n if (this._slotUpdateSubscriptions[id]) {\n const subInfo = this._slotUpdateSubscriptions[id];\n delete this._slotUpdateSubscriptions[id];\n await this._unsubscribe(subInfo, 'slotsUpdatesUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown slot update id: ${id}`);\n }\n }\n\n _buildArgs(\n args: Array,\n override?: Commitment,\n encoding?: 'jsonParsed' | 'base64',\n extra?: any,\n ): Array {\n const commitment = override || this._commitment;\n if (commitment || encoding || extra) {\n let options: any = {};\n if (encoding) {\n options.encoding = encoding;\n }\n if (commitment) {\n options.commitment = commitment;\n }\n if (extra) {\n options = Object.assign(options, extra);\n }\n args.push(options);\n }\n return args;\n }\n\n /**\n * @internal\n */\n _buildArgsAtLeastConfirmed(\n args: Array,\n override?: Finality,\n encoding?: 'jsonParsed' | 'base64',\n extra?: any,\n ): Array {\n const commitment = override || this._commitment;\n if (commitment && !['confirmed', 'finalized'].includes(commitment)) {\n throw new Error(\n 'Using Connection with default commitment: `' +\n this._commitment +\n '`, but method requires at least `confirmed`',\n );\n }\n return this._buildArgs(args, override, encoding, extra);\n }\n\n /**\n * @internal\n */\n _wsOnSignatureNotification(notification: Object) {\n const res = create(notification, SignatureNotificationResult);\n for (const [id, sub] of Object.entries(this._signatureSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n if (res.result.value === 'receivedSignature') {\n sub.callback(\n {\n type: 'received',\n },\n res.result.context,\n );\n } else {\n // Signatures subscriptions are auto-removed by the RPC service so\n // no need to explicitly send an unsubscribe message\n delete this._signatureSubscriptions[Number(id)];\n this._updateSubscriptions();\n sub.callback(\n {\n type: 'status',\n result: res.result.value,\n },\n res.result.context,\n );\n }\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked upon signature updates\n *\n * @param signature Transaction signature string in base 58\n * @param callback Function to invoke on signature notifications\n * @param commitment Specify the commitment level signature must reach before notification\n * @return subscription id\n */\n onSignature(\n signature: TransactionSignature,\n callback: SignatureResultCallback,\n commitment?: Commitment,\n ): number {\n const id = ++this._signatureSubscriptionCounter;\n this._signatureSubscriptions[id] = {\n signature,\n callback: (notification, context) => {\n if (notification.type === 'status') {\n callback(notification.result, context);\n }\n },\n options: {commitment},\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Register a callback to be invoked when a transaction is\n * received and/or processed.\n *\n * @param signature Transaction signature string in base 58\n * @param callback Function to invoke on signature notifications\n * @param options Enable received notifications and set the commitment\n * level that signature must reach before notification\n * @return subscription id\n */\n onSignatureWithOptions(\n signature: TransactionSignature,\n callback: SignatureSubscriptionCallback,\n options?: SignatureSubscriptionOptions,\n ): number {\n const id = ++this._signatureSubscriptionCounter;\n this._signatureSubscriptions[id] = {\n signature,\n callback,\n options,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister a signature notification callback\n *\n * @param id subscription id to deregister\n */\n async removeSignatureListener(id: number): Promise {\n if (this._signatureSubscriptions[id]) {\n const subInfo = this._signatureSubscriptions[id];\n delete this._signatureSubscriptions[id];\n await this._unsubscribe(subInfo, 'signatureUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown signature result id: ${id}`);\n }\n }\n\n /**\n * @internal\n */\n _wsOnRootNotification(notification: Object) {\n const res = create(notification, RootNotificationResult);\n for (const sub of Object.values(this._rootSubscriptions)) {\n if (sub.subscriptionId === res.subscription) {\n sub.callback(res.result);\n return;\n }\n }\n }\n\n /**\n * Register a callback to be invoked upon root changes\n *\n * @param callback Function to invoke whenever the root changes\n * @return subscription id\n */\n onRootChange(callback: RootChangeCallback): number {\n const id = ++this._rootSubscriptionCounter;\n this._rootSubscriptions[id] = {\n callback,\n subscriptionId: null,\n };\n this._updateSubscriptions();\n return id;\n }\n\n /**\n * Deregister a root notification callback\n *\n * @param id subscription id to deregister\n */\n async removeRootChangeListener(id: number): Promise {\n if (this._rootSubscriptions[id]) {\n const subInfo = this._rootSubscriptions[id];\n delete this._rootSubscriptions[id];\n await this._unsubscribe(subInfo, 'rootUnsubscribe');\n this._updateSubscriptions();\n } else {\n throw new Error(`Unknown root change id: ${id}`);\n }\n }\n}\n","export function makeWebsocketUrl(endpoint: string) {\n let url = new URL(endpoint);\n const useHttps = url.protocol === 'https:';\n\n url.protocol = useHttps ? 'wss:' : 'ws:';\n url.host = '';\n\n // Only shift the port by +1 as a convention for ws(s) only if given endpoint\n // is explictly specifying the endpoint port (HTTP-based RPC), assuming\n // we're directly trying to connect to solana-validator's ws listening port.\n // When the endpoint omits the port, we're connecting to the protocol\n // default ports: http(80) or https(443) and it's assumed we're behind a reverse\n // proxy which manages WebSocket upgrade and backend port redirection.\n if (url.port !== '') {\n url.port = String(Number(url.port) + 1);\n }\n return url.toString();\n}\n","import nacl from 'tweetnacl';\n\nimport {PublicKey} from './publickey';\n\n/**\n * Keypair signer interface\n */\nexport interface Signer {\n publicKey: PublicKey;\n secretKey: Uint8Array;\n}\n\n/**\n * Ed25519 Keypair\n */\nexport interface Ed25519Keypair {\n publicKey: Uint8Array;\n secretKey: Uint8Array;\n}\n\n/**\n * An account keypair used for signing transactions.\n */\nexport class Keypair {\n private _keypair: Ed25519Keypair;\n\n /**\n * Create a new keypair instance.\n * Generate random keypair if no {@link Ed25519Keypair} is provided.\n *\n * @param keypair ed25519 keypair\n */\n constructor(keypair?: Ed25519Keypair) {\n if (keypair) {\n this._keypair = keypair;\n } else {\n this._keypair = nacl.sign.keyPair();\n }\n }\n\n /**\n * Generate a new random keypair\n */\n static generate(): Keypair {\n return new Keypair(nacl.sign.keyPair());\n }\n\n /**\n * Create a keypair from a raw secret key byte array.\n *\n * This method should only be used to recreate a keypair from a previously\n * generated secret key. Generating keypairs from a random seed should be done\n * with the {@link Keypair.fromSeed} method.\n *\n * @throws error if the provided secret key is invalid and validation is not skipped.\n *\n * @param secretKey secret key byte array\n * @param options: skip secret key validation\n */\n static fromSecretKey(\n secretKey: Uint8Array,\n options?: {skipValidation?: boolean},\n ): Keypair {\n const keypair = nacl.sign.keyPair.fromSecretKey(secretKey);\n if (!options || !options.skipValidation) {\n const encoder = new TextEncoder();\n const signData = encoder.encode('@solana/web3.js-validation-v1');\n const signature = nacl.sign.detached(signData, keypair.secretKey);\n if (!nacl.sign.detached.verify(signData, signature, keypair.publicKey)) {\n throw new Error('provided secretKey is invalid');\n }\n }\n return new Keypair(keypair);\n }\n\n /**\n * Generate a keypair from a 32 byte seed.\n *\n * @param seed seed byte array\n */\n static fromSeed(seed: Uint8Array): Keypair {\n return new Keypair(nacl.sign.keyPair.fromSeed(seed));\n }\n\n /**\n * The public key for this keypair\n */\n get publicKey(): PublicKey {\n return new PublicKey(this._keypair.publicKey);\n }\n\n /**\n * The raw secret key for this keypair\n */\n get secretKey(): Uint8Array {\n return this._keypair.secretKey;\n }\n}\n","import {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\nimport nacl from 'tweetnacl';\n\nimport {Keypair} from './keypair';\nimport {PublicKey} from './publickey';\nimport {TransactionInstruction} from './transaction';\nimport assert from './util/assert';\n\nconst PRIVATE_KEY_BYTES = 64;\nconst PUBLIC_KEY_BYTES = 32;\nconst SIGNATURE_BYTES = 64;\n\n/**\n * Params for creating an ed25519 instruction using a public key\n */\nexport type CreateEd25519InstructionWithPublicKeyParams = {\n publicKey: Uint8Array;\n message: Uint8Array;\n signature: Uint8Array;\n instructionIndex?: number;\n};\n\n/**\n * Params for creating an ed25519 instruction using a private key\n */\nexport type CreateEd25519InstructionWithPrivateKeyParams = {\n privateKey: Uint8Array;\n message: Uint8Array;\n instructionIndex?: number;\n};\n\nconst ED25519_INSTRUCTION_LAYOUT = BufferLayout.struct([\n BufferLayout.u8('numSignatures'),\n BufferLayout.u8('padding'),\n BufferLayout.u16('signatureOffset'),\n BufferLayout.u16('signatureInstructionIndex'),\n BufferLayout.u16('publicKeyOffset'),\n BufferLayout.u16('publicKeyInstructionIndex'),\n BufferLayout.u16('messageDataOffset'),\n BufferLayout.u16('messageDataSize'),\n BufferLayout.u16('messageInstructionIndex'),\n]);\n\nexport class Ed25519Program {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Public key that identifies the ed25519 program\n */\n static programId: PublicKey = new PublicKey(\n 'Ed25519SigVerify111111111111111111111111111',\n );\n\n /**\n * Create an ed25519 instruction with a public key and signature. The\n * public key must be a buffer that is 32 bytes long, and the signature\n * must be a buffer of 64 bytes.\n */\n static createInstructionWithPublicKey(\n params: CreateEd25519InstructionWithPublicKeyParams,\n ): TransactionInstruction {\n const {publicKey, message, signature, instructionIndex} = params;\n\n assert(\n publicKey.length === PUBLIC_KEY_BYTES,\n `Public Key must be ${PUBLIC_KEY_BYTES} bytes but received ${publicKey.length} bytes`,\n );\n\n assert(\n signature.length === SIGNATURE_BYTES,\n `Signature must be ${SIGNATURE_BYTES} bytes but received ${signature.length} bytes`,\n );\n\n const publicKeyOffset = ED25519_INSTRUCTION_LAYOUT.span;\n const signatureOffset = publicKeyOffset + publicKey.length;\n const messageDataOffset = signatureOffset + signature.length;\n const numSignatures = 1;\n\n const instructionData = Buffer.alloc(messageDataOffset + message.length);\n\n ED25519_INSTRUCTION_LAYOUT.encode(\n {\n numSignatures,\n padding: 0,\n signatureOffset,\n signatureInstructionIndex: instructionIndex,\n publicKeyOffset,\n publicKeyInstructionIndex: instructionIndex,\n messageDataOffset,\n messageDataSize: message.length,\n messageInstructionIndex: instructionIndex,\n },\n instructionData,\n );\n\n instructionData.fill(publicKey, publicKeyOffset);\n instructionData.fill(signature, signatureOffset);\n instructionData.fill(message, messageDataOffset);\n\n return new TransactionInstruction({\n keys: [],\n programId: Ed25519Program.programId,\n data: instructionData,\n });\n }\n\n /**\n * Create an ed25519 instruction with a private key. The private key\n * must be a buffer that is 64 bytes long.\n */\n static createInstructionWithPrivateKey(\n params: CreateEd25519InstructionWithPrivateKeyParams,\n ): TransactionInstruction {\n const {privateKey, message, instructionIndex} = params;\n\n assert(\n privateKey.length === PRIVATE_KEY_BYTES,\n `Private key must be ${PRIVATE_KEY_BYTES} bytes but received ${privateKey.length} bytes`,\n );\n\n try {\n const keypair = Keypair.fromSecretKey(privateKey);\n const publicKey = keypair.publicKey.toBytes();\n const signature = nacl.sign.detached(message, keypair.secretKey);\n\n return this.createInstructionWithPublicKey({\n publicKey,\n message,\n signature,\n instructionIndex,\n });\n } catch (error) {\n throw new Error(`Error creating instruction; ${error}`);\n }\n }\n}\n","import * as BufferLayout from '@solana/buffer-layout';\n\nimport {encodeData, decodeData, InstructionType} from './instruction';\nimport * as Layout from './layout';\nimport {PublicKey} from './publickey';\nimport {SystemProgram} from './system-program';\nimport {\n SYSVAR_CLOCK_PUBKEY,\n SYSVAR_RENT_PUBKEY,\n SYSVAR_STAKE_HISTORY_PUBKEY,\n} from './sysvar';\nimport {Transaction, TransactionInstruction} from './transaction';\nimport {toBuffer} from './util/to-buffer';\n\n/**\n * Address of the stake config account which configures the rate\n * of stake warmup and cooldown as well as the slashing penalty.\n */\nexport const STAKE_CONFIG_ID = new PublicKey(\n 'StakeConfig11111111111111111111111111111111',\n);\n\n/**\n * Stake account authority info\n */\nexport class Authorized {\n /** stake authority */\n staker: PublicKey;\n /** withdraw authority */\n withdrawer: PublicKey;\n\n /**\n * Create a new Authorized object\n * @param staker the stake authority\n * @param withdrawer the withdraw authority\n */\n constructor(staker: PublicKey, withdrawer: PublicKey) {\n this.staker = staker;\n this.withdrawer = withdrawer;\n }\n}\n\n/**\n * Stake account lockup info\n */\nexport class Lockup {\n /** Unix timestamp of lockup expiration */\n unixTimestamp: number;\n /** Epoch of lockup expiration */\n epoch: number;\n /** Lockup custodian authority */\n custodian: PublicKey;\n\n /**\n * Create a new Lockup object\n */\n constructor(unixTimestamp: number, epoch: number, custodian: PublicKey) {\n this.unixTimestamp = unixTimestamp;\n this.epoch = epoch;\n this.custodian = custodian;\n }\n\n /**\n * Default, inactive Lockup value\n */\n static default: Lockup = new Lockup(0, 0, PublicKey.default);\n}\n\n/**\n * Create stake account transaction params\n */\nexport type CreateStakeAccountParams = {\n /** Address of the account which will fund creation */\n fromPubkey: PublicKey;\n /** Address of the new stake account */\n stakePubkey: PublicKey;\n /** Authorities of the new stake account */\n authorized: Authorized;\n /** Lockup of the new stake account */\n lockup?: Lockup;\n /** Funding amount */\n lamports: number;\n};\n\n/**\n * Create stake account with seed transaction params\n */\nexport type CreateStakeAccountWithSeedParams = {\n fromPubkey: PublicKey;\n stakePubkey: PublicKey;\n basePubkey: PublicKey;\n seed: string;\n authorized: Authorized;\n lockup?: Lockup;\n lamports: number;\n};\n\n/**\n * Initialize stake instruction params\n */\nexport type InitializeStakeParams = {\n stakePubkey: PublicKey;\n authorized: Authorized;\n lockup?: Lockup;\n};\n\n/**\n * Delegate stake instruction params\n */\nexport type DelegateStakeParams = {\n stakePubkey: PublicKey;\n authorizedPubkey: PublicKey;\n votePubkey: PublicKey;\n};\n\n/**\n * Authorize stake instruction params\n */\nexport type AuthorizeStakeParams = {\n stakePubkey: PublicKey;\n authorizedPubkey: PublicKey;\n newAuthorizedPubkey: PublicKey;\n stakeAuthorizationType: StakeAuthorizationType;\n custodianPubkey?: PublicKey;\n};\n\n/**\n * Authorize stake instruction params using a derived key\n */\nexport type AuthorizeWithSeedStakeParams = {\n stakePubkey: PublicKey;\n authorityBase: PublicKey;\n authoritySeed: string;\n authorityOwner: PublicKey;\n newAuthorizedPubkey: PublicKey;\n stakeAuthorizationType: StakeAuthorizationType;\n custodianPubkey?: PublicKey;\n};\n\n/**\n * Split stake instruction params\n */\nexport type SplitStakeParams = {\n stakePubkey: PublicKey;\n authorizedPubkey: PublicKey;\n splitStakePubkey: PublicKey;\n lamports: number;\n};\n\n/**\n * Withdraw stake instruction params\n */\nexport type WithdrawStakeParams = {\n stakePubkey: PublicKey;\n authorizedPubkey: PublicKey;\n toPubkey: PublicKey;\n lamports: number;\n custodianPubkey?: PublicKey;\n};\n\n/**\n * Deactivate stake instruction params\n */\nexport type DeactivateStakeParams = {\n stakePubkey: PublicKey;\n authorizedPubkey: PublicKey;\n};\n\n/**\n * Merge stake instruction params\n */\nexport type MergeStakeParams = {\n stakePubkey: PublicKey;\n sourceStakePubKey: PublicKey;\n authorizedPubkey: PublicKey;\n};\n\n/**\n * Stake Instruction class\n */\nexport class StakeInstruction {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Decode a stake instruction and retrieve the instruction type.\n */\n static decodeInstructionType(\n instruction: TransactionInstruction,\n ): StakeInstructionType {\n this.checkProgramId(instruction.programId);\n\n const instructionTypeLayout = BufferLayout.u32('instruction');\n const typeIndex = instructionTypeLayout.decode(instruction.data);\n\n let type: StakeInstructionType | undefined;\n for (const [ixType, layout] of Object.entries(STAKE_INSTRUCTION_LAYOUTS)) {\n if (layout.index == typeIndex) {\n type = ixType as StakeInstructionType;\n break;\n }\n }\n\n if (!type) {\n throw new Error('Instruction type incorrect; not a StakeInstruction');\n }\n\n return type;\n }\n\n /**\n * Decode a initialize stake instruction and retrieve the instruction params.\n */\n static decodeInitialize(\n instruction: TransactionInstruction,\n ): InitializeStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {authorized, lockup} = decodeData(\n STAKE_INSTRUCTION_LAYOUTS.Initialize,\n instruction.data,\n );\n\n return {\n stakePubkey: instruction.keys[0].pubkey,\n authorized: new Authorized(\n new PublicKey(authorized.staker),\n new PublicKey(authorized.withdrawer),\n ),\n lockup: new Lockup(\n lockup.unixTimestamp,\n lockup.epoch,\n new PublicKey(lockup.custodian),\n ),\n };\n }\n\n /**\n * Decode a delegate stake instruction and retrieve the instruction params.\n */\n static decodeDelegate(\n instruction: TransactionInstruction,\n ): DelegateStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 6);\n decodeData(STAKE_INSTRUCTION_LAYOUTS.Delegate, instruction.data);\n\n return {\n stakePubkey: instruction.keys[0].pubkey,\n votePubkey: instruction.keys[1].pubkey,\n authorizedPubkey: instruction.keys[5].pubkey,\n };\n }\n\n /**\n * Decode an authorize stake instruction and retrieve the instruction params.\n */\n static decodeAuthorize(\n instruction: TransactionInstruction,\n ): AuthorizeStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n const {newAuthorized, stakeAuthorizationType} = decodeData(\n STAKE_INSTRUCTION_LAYOUTS.Authorize,\n instruction.data,\n );\n\n const o: AuthorizeStakeParams = {\n stakePubkey: instruction.keys[0].pubkey,\n authorizedPubkey: instruction.keys[2].pubkey,\n newAuthorizedPubkey: new PublicKey(newAuthorized),\n stakeAuthorizationType: {\n index: stakeAuthorizationType,\n },\n };\n if (instruction.keys.length > 3) {\n o.custodianPubkey = instruction.keys[3].pubkey;\n }\n return o;\n }\n\n /**\n * Decode an authorize-with-seed stake instruction and retrieve the instruction params.\n */\n static decodeAuthorizeWithSeed(\n instruction: TransactionInstruction,\n ): AuthorizeWithSeedStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 2);\n\n const {\n newAuthorized,\n stakeAuthorizationType,\n authoritySeed,\n authorityOwner,\n } = decodeData(\n STAKE_INSTRUCTION_LAYOUTS.AuthorizeWithSeed,\n instruction.data,\n );\n\n const o: AuthorizeWithSeedStakeParams = {\n stakePubkey: instruction.keys[0].pubkey,\n authorityBase: instruction.keys[1].pubkey,\n authoritySeed: authoritySeed,\n authorityOwner: new PublicKey(authorityOwner),\n newAuthorizedPubkey: new PublicKey(newAuthorized),\n stakeAuthorizationType: {\n index: stakeAuthorizationType,\n },\n };\n if (instruction.keys.length > 3) {\n o.custodianPubkey = instruction.keys[3].pubkey;\n }\n return o;\n }\n\n /**\n * Decode a split stake instruction and retrieve the instruction params.\n */\n static decodeSplit(instruction: TransactionInstruction): SplitStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n const {lamports} = decodeData(\n STAKE_INSTRUCTION_LAYOUTS.Split,\n instruction.data,\n );\n\n return {\n stakePubkey: instruction.keys[0].pubkey,\n splitStakePubkey: instruction.keys[1].pubkey,\n authorizedPubkey: instruction.keys[2].pubkey,\n lamports,\n };\n }\n\n /**\n * Decode a merge stake instruction and retrieve the instruction params.\n */\n static decodeMerge(instruction: TransactionInstruction): MergeStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n decodeData(STAKE_INSTRUCTION_LAYOUTS.Merge, instruction.data);\n\n return {\n stakePubkey: instruction.keys[0].pubkey,\n sourceStakePubKey: instruction.keys[1].pubkey,\n authorizedPubkey: instruction.keys[4].pubkey,\n };\n }\n\n /**\n * Decode a withdraw stake instruction and retrieve the instruction params.\n */\n static decodeWithdraw(\n instruction: TransactionInstruction,\n ): WithdrawStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 5);\n const {lamports} = decodeData(\n STAKE_INSTRUCTION_LAYOUTS.Withdraw,\n instruction.data,\n );\n\n const o: WithdrawStakeParams = {\n stakePubkey: instruction.keys[0].pubkey,\n toPubkey: instruction.keys[1].pubkey,\n authorizedPubkey: instruction.keys[4].pubkey,\n lamports,\n };\n if (instruction.keys.length > 5) {\n o.custodianPubkey = instruction.keys[5].pubkey;\n }\n return o;\n }\n\n /**\n * Decode a deactivate stake instruction and retrieve the instruction params.\n */\n static decodeDeactivate(\n instruction: TransactionInstruction,\n ): DeactivateStakeParams {\n this.checkProgramId(instruction.programId);\n this.checkKeyLength(instruction.keys, 3);\n decodeData(STAKE_INSTRUCTION_LAYOUTS.Deactivate, instruction.data);\n\n return {\n stakePubkey: instruction.keys[0].pubkey,\n authorizedPubkey: instruction.keys[2].pubkey,\n };\n }\n\n /**\n * @internal\n */\n static checkProgramId(programId: PublicKey) {\n if (!programId.equals(StakeProgram.programId)) {\n throw new Error('invalid instruction; programId is not StakeProgram');\n }\n }\n\n /**\n * @internal\n */\n static checkKeyLength(keys: Array, expectedLength: number) {\n if (keys.length < expectedLength) {\n throw new Error(\n `invalid instruction; found ${keys.length} keys, expected at least ${expectedLength}`,\n );\n }\n }\n}\n\n/**\n * An enumeration of valid StakeInstructionType's\n */\nexport type StakeInstructionType =\n | 'AuthorizeWithSeed'\n | 'Authorize'\n | 'Deactivate'\n | 'Delegate'\n | 'Initialize'\n | 'Split'\n | 'Withdraw'\n | 'Merge';\n\n/**\n * An enumeration of valid stake InstructionType's\n * @internal\n */\nexport const STAKE_INSTRUCTION_LAYOUTS: {\n [type in StakeInstructionType]: InstructionType;\n} = Object.freeze({\n Initialize: {\n index: 0,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.authorized(),\n Layout.lockup(),\n ]),\n },\n Authorize: {\n index: 1,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('newAuthorized'),\n BufferLayout.u32('stakeAuthorizationType'),\n ]),\n },\n Delegate: {\n index: 2,\n layout: BufferLayout.struct([BufferLayout.u32('instruction')]),\n },\n Split: {\n index: 3,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n ]),\n },\n Withdraw: {\n index: 4,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n BufferLayout.ns64('lamports'),\n ]),\n },\n Deactivate: {\n index: 5,\n layout: BufferLayout.struct([BufferLayout.u32('instruction')]),\n },\n Merge: {\n index: 7,\n layout: BufferLayout.struct([BufferLayout.u32('instruction')]),\n },\n AuthorizeWithSeed: {\n index: 8,\n layout: BufferLayout.struct([\n BufferLayout.u32('instruction'),\n Layout.publicKey('newAuthorized'),\n BufferLayout.u32('stakeAuthorizationType'),\n Layout.rustString('authoritySeed'),\n Layout.publicKey('authorityOwner'),\n ]),\n },\n});\n\n/**\n * Stake authorization type\n */\nexport type StakeAuthorizationType = {\n /** The Stake Authorization index (from solana-stake-program) */\n index: number;\n};\n\n/**\n * An enumeration of valid StakeAuthorizationLayout's\n */\nexport const StakeAuthorizationLayout = Object.freeze({\n Staker: {\n index: 0,\n },\n Withdrawer: {\n index: 1,\n },\n});\n\n/**\n * Factory class for transactions to interact with the Stake program\n */\nexport class StakeProgram {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Public key that identifies the Stake program\n */\n static programId: PublicKey = new PublicKey(\n 'Stake11111111111111111111111111111111111111',\n );\n\n /**\n * Max space of a Stake account\n *\n * This is generated from the solana-stake-program StakeState struct as\n * `std::mem::size_of::()`:\n * https://docs.rs/solana-stake-program/1.4.4/solana_stake_program/stake_state/enum.StakeState.html\n */\n static space: number = 200;\n\n /**\n * Generate an Initialize instruction to add to a Stake Create transaction\n */\n static initialize(params: InitializeStakeParams): TransactionInstruction {\n const {stakePubkey, authorized, lockup: maybeLockup} = params;\n const lockup: Lockup = maybeLockup || Lockup.default;\n const type = STAKE_INSTRUCTION_LAYOUTS.Initialize;\n const data = encodeData(type, {\n authorized: {\n staker: toBuffer(authorized.staker.toBuffer()),\n withdrawer: toBuffer(authorized.withdrawer.toBuffer()),\n },\n lockup: {\n unixTimestamp: lockup.unixTimestamp,\n epoch: lockup.epoch,\n custodian: toBuffer(lockup.custodian.toBuffer()),\n },\n });\n const instructionData = {\n keys: [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: SYSVAR_RENT_PUBKEY, isSigner: false, isWritable: false},\n ],\n programId: this.programId,\n data,\n };\n return new TransactionInstruction(instructionData);\n }\n\n /**\n * Generate a Transaction that creates a new Stake account at\n * an address generated with `from`, a seed, and the Stake programId\n */\n static createAccountWithSeed(\n params: CreateStakeAccountWithSeedParams,\n ): Transaction {\n const transaction = new Transaction();\n transaction.add(\n SystemProgram.createAccountWithSeed({\n fromPubkey: params.fromPubkey,\n newAccountPubkey: params.stakePubkey,\n basePubkey: params.basePubkey,\n seed: params.seed,\n lamports: params.lamports,\n space: this.space,\n programId: this.programId,\n }),\n );\n\n const {stakePubkey, authorized, lockup} = params;\n return transaction.add(this.initialize({stakePubkey, authorized, lockup}));\n }\n\n /**\n * Generate a Transaction that creates a new Stake account\n */\n static createAccount(params: CreateStakeAccountParams): Transaction {\n const transaction = new Transaction();\n transaction.add(\n SystemProgram.createAccount({\n fromPubkey: params.fromPubkey,\n newAccountPubkey: params.stakePubkey,\n lamports: params.lamports,\n space: this.space,\n programId: this.programId,\n }),\n );\n\n const {stakePubkey, authorized, lockup} = params;\n return transaction.add(this.initialize({stakePubkey, authorized, lockup}));\n }\n\n /**\n * Generate a Transaction that delegates Stake tokens to a validator\n * Vote PublicKey. This transaction can also be used to redelegate Stake\n * to a new validator Vote PublicKey.\n */\n static delegate(params: DelegateStakeParams): Transaction {\n const {stakePubkey, authorizedPubkey, votePubkey} = params;\n\n const type = STAKE_INSTRUCTION_LAYOUTS.Delegate;\n const data = encodeData(type);\n\n return new Transaction().add({\n keys: [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: votePubkey, isSigner: false, isWritable: false},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: false},\n {\n pubkey: SYSVAR_STAKE_HISTORY_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: STAKE_CONFIG_ID, isSigner: false, isWritable: false},\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that authorizes a new PublicKey as Staker\n * or Withdrawer on the Stake account.\n */\n static authorize(params: AuthorizeStakeParams): Transaction {\n const {\n stakePubkey,\n authorizedPubkey,\n newAuthorizedPubkey,\n stakeAuthorizationType,\n custodianPubkey,\n } = params;\n\n const type = STAKE_INSTRUCTION_LAYOUTS.Authorize;\n const data = encodeData(type, {\n newAuthorized: toBuffer(newAuthorizedPubkey.toBuffer()),\n stakeAuthorizationType: stakeAuthorizationType.index,\n });\n\n const keys = [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: true},\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ];\n if (custodianPubkey) {\n keys.push({pubkey: custodianPubkey, isSigner: false, isWritable: false});\n }\n return new Transaction().add({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that authorizes a new PublicKey as Staker\n * or Withdrawer on the Stake account.\n */\n static authorizeWithSeed(params: AuthorizeWithSeedStakeParams): Transaction {\n const {\n stakePubkey,\n authorityBase,\n authoritySeed,\n authorityOwner,\n newAuthorizedPubkey,\n stakeAuthorizationType,\n custodianPubkey,\n } = params;\n\n const type = STAKE_INSTRUCTION_LAYOUTS.AuthorizeWithSeed;\n const data = encodeData(type, {\n newAuthorized: toBuffer(newAuthorizedPubkey.toBuffer()),\n stakeAuthorizationType: stakeAuthorizationType.index,\n authoritySeed: authoritySeed,\n authorityOwner: toBuffer(authorityOwner.toBuffer()),\n });\n\n const keys = [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: authorityBase, isSigner: true, isWritable: false},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: false},\n ];\n if (custodianPubkey) {\n keys.push({pubkey: custodianPubkey, isSigner: false, isWritable: false});\n }\n return new Transaction().add({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that splits Stake tokens into another stake account\n */\n static split(params: SplitStakeParams): Transaction {\n const {stakePubkey, authorizedPubkey, splitStakePubkey, lamports} = params;\n\n const transaction = new Transaction();\n transaction.add(\n SystemProgram.createAccount({\n fromPubkey: authorizedPubkey,\n newAccountPubkey: splitStakePubkey,\n lamports: 0,\n space: this.space,\n programId: this.programId,\n }),\n );\n const type = STAKE_INSTRUCTION_LAYOUTS.Split;\n const data = encodeData(type, {lamports});\n\n return transaction.add({\n keys: [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: splitStakePubkey, isSigner: false, isWritable: true},\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that merges Stake accounts.\n */\n static merge(params: MergeStakeParams): Transaction {\n const {stakePubkey, sourceStakePubKey, authorizedPubkey} = params;\n const type = STAKE_INSTRUCTION_LAYOUTS.Merge;\n const data = encodeData(type);\n\n return new Transaction().add({\n keys: [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: sourceStakePubKey, isSigner: false, isWritable: true},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: false},\n {\n pubkey: SYSVAR_STAKE_HISTORY_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that withdraws deactivated Stake tokens.\n */\n static withdraw(params: WithdrawStakeParams): Transaction {\n const {stakePubkey, authorizedPubkey, toPubkey, lamports, custodianPubkey} =\n params;\n const type = STAKE_INSTRUCTION_LAYOUTS.Withdraw;\n const data = encodeData(type, {lamports});\n\n const keys = [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: toPubkey, isSigner: false, isWritable: true},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: false},\n {\n pubkey: SYSVAR_STAKE_HISTORY_PUBKEY,\n isSigner: false,\n isWritable: false,\n },\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ];\n if (custodianPubkey) {\n keys.push({pubkey: custodianPubkey, isSigner: false, isWritable: false});\n }\n return new Transaction().add({\n keys,\n programId: this.programId,\n data,\n });\n }\n\n /**\n * Generate a Transaction that deactivates Stake tokens.\n */\n static deactivate(params: DeactivateStakeParams): Transaction {\n const {stakePubkey, authorizedPubkey} = params;\n const type = STAKE_INSTRUCTION_LAYOUTS.Deactivate;\n const data = encodeData(type);\n\n return new Transaction().add({\n keys: [\n {pubkey: stakePubkey, isSigner: false, isWritable: true},\n {pubkey: SYSVAR_CLOCK_PUBKEY, isSigner: false, isWritable: false},\n {pubkey: authorizedPubkey, isSigner: true, isWritable: false},\n ],\n programId: this.programId,\n data,\n });\n }\n}\n","import {Buffer} from 'buffer';\nimport * as BufferLayout from '@solana/buffer-layout';\nimport secp256k1 from 'secp256k1';\nimport sha3 from 'js-sha3';\n\nimport {PublicKey} from './publickey';\nimport {TransactionInstruction} from './transaction';\nimport assert from './util/assert';\nimport {toBuffer} from './util/to-buffer';\n\nconst {publicKeyCreate, ecdsaSign} = secp256k1;\n\nconst PRIVATE_KEY_BYTES = 32;\nconst ETHEREUM_ADDRESS_BYTES = 20;\nconst PUBLIC_KEY_BYTES = 64;\nconst SIGNATURE_OFFSETS_SERIALIZED_SIZE = 11;\n\n/**\n * Params for creating an secp256k1 instruction using a public key\n */\nexport type CreateSecp256k1InstructionWithPublicKeyParams = {\n publicKey: Buffer | Uint8Array | Array;\n message: Buffer | Uint8Array | Array;\n signature: Buffer | Uint8Array | Array;\n recoveryId: number;\n instructionIndex?: number;\n};\n\n/**\n * Params for creating an secp256k1 instruction using an Ethereum address\n */\nexport type CreateSecp256k1InstructionWithEthAddressParams = {\n ethAddress: Buffer | Uint8Array | Array | string;\n message: Buffer | Uint8Array | Array;\n signature: Buffer | Uint8Array | Array;\n recoveryId: number;\n instructionIndex?: number;\n};\n\n/**\n * Params for creating an secp256k1 instruction using a private key\n */\nexport type CreateSecp256k1InstructionWithPrivateKeyParams = {\n privateKey: Buffer | Uint8Array | Array;\n message: Buffer | Uint8Array | Array;\n instructionIndex?: number;\n};\n\nconst SECP256K1_INSTRUCTION_LAYOUT = BufferLayout.struct([\n BufferLayout.u8('numSignatures'),\n BufferLayout.u16('signatureOffset'),\n BufferLayout.u8('signatureInstructionIndex'),\n BufferLayout.u16('ethAddressOffset'),\n BufferLayout.u8('ethAddressInstructionIndex'),\n BufferLayout.u16('messageDataOffset'),\n BufferLayout.u16('messageDataSize'),\n BufferLayout.u8('messageInstructionIndex'),\n BufferLayout.blob(20, 'ethAddress'),\n BufferLayout.blob(64, 'signature'),\n BufferLayout.u8('recoveryId'),\n]);\n\nexport class Secp256k1Program {\n /**\n * @internal\n */\n constructor() {}\n\n /**\n * Public key that identifies the secp256k1 program\n */\n static programId: PublicKey = new PublicKey(\n 'KeccakSecp256k11111111111111111111111111111',\n );\n\n /**\n * Construct an Ethereum address from a secp256k1 public key buffer.\n * @param {Buffer} publicKey a 64 byte secp256k1 public key buffer\n */\n static publicKeyToEthAddress(\n publicKey: Buffer | Uint8Array | Array,\n ): Buffer {\n assert(\n publicKey.length === PUBLIC_KEY_BYTES,\n `Public key must be ${PUBLIC_KEY_BYTES} bytes but received ${publicKey.length} bytes`,\n );\n\n try {\n return Buffer.from(\n sha3.keccak_256.update(toBuffer(publicKey)).digest(),\n ).slice(-ETHEREUM_ADDRESS_BYTES);\n } catch (error) {\n throw new Error(`Error constructing Ethereum address: ${error}`);\n }\n }\n\n /**\n * Create an secp256k1 instruction with a public key. The public key\n * must be a buffer that is 64 bytes long.\n */\n static createInstructionWithPublicKey(\n params: CreateSecp256k1InstructionWithPublicKeyParams,\n ): TransactionInstruction {\n const {publicKey, message, signature, recoveryId, instructionIndex} =\n params;\n return Secp256k1Program.createInstructionWithEthAddress({\n ethAddress: Secp256k1Program.publicKeyToEthAddress(publicKey),\n message,\n signature,\n recoveryId,\n instructionIndex,\n });\n }\n\n /**\n * Create an secp256k1 instruction with an Ethereum address. The address\n * must be a hex string or a buffer that is 20 bytes long.\n */\n static createInstructionWithEthAddress(\n params: CreateSecp256k1InstructionWithEthAddressParams,\n ): TransactionInstruction {\n const {\n ethAddress: rawAddress,\n message,\n signature,\n recoveryId,\n instructionIndex = 0,\n } = params;\n\n let ethAddress;\n if (typeof rawAddress === 'string') {\n if (rawAddress.startsWith('0x')) {\n ethAddress = Buffer.from(rawAddress.substr(2), 'hex');\n } else {\n ethAddress = Buffer.from(rawAddress, 'hex');\n }\n } else {\n ethAddress = rawAddress;\n }\n\n assert(\n ethAddress.length === ETHEREUM_ADDRESS_BYTES,\n `Address must be ${ETHEREUM_ADDRESS_BYTES} bytes but received ${ethAddress.length} bytes`,\n );\n\n const dataStart = 1 + SIGNATURE_OFFSETS_SERIALIZED_SIZE;\n const ethAddressOffset = dataStart;\n const signatureOffset = dataStart + ethAddress.length;\n const messageDataOffset = signatureOffset + signature.length + 1;\n const numSignatures = 1;\n\n const instructionData = Buffer.alloc(\n SECP256K1_INSTRUCTION_LAYOUT.span + message.length,\n );\n\n SECP256K1_INSTRUCTION_LAYOUT.encode(\n {\n numSignatures,\n signatureOffset,\n signatureInstructionIndex: instructionIndex,\n ethAddressOffset,\n ethAddressInstructionIndex: instructionIndex,\n messageDataOffset,\n messageDataSize: message.length,\n messageInstructionIndex: instructionIndex,\n signature: toBuffer(signature),\n ethAddress: toBuffer(ethAddress),\n recoveryId,\n },\n instructionData,\n );\n\n instructionData.fill(toBuffer(message), SECP256K1_INSTRUCTION_LAYOUT.span);\n\n return new TransactionInstruction({\n keys: [],\n programId: Secp256k1Program.programId,\n data: instructionData,\n });\n }\n\n /**\n * Create an secp256k1 instruction with a private key. The private key\n * must be a buffer that is 32 bytes long.\n */\n static createInstructionWithPrivateKey(\n params: CreateSecp256k1InstructionWithPrivateKeyParams,\n ): TransactionInstruction {\n const {privateKey: pkey, message, instructionIndex} = params;\n\n assert(\n pkey.length === PRIVATE_KEY_BYTES,\n `Private key must be ${PRIVATE_KEY_BYTES} bytes but received ${pkey.length} bytes`,\n );\n\n try {\n const privateKey = toBuffer(pkey);\n const publicKey = publicKeyCreate(privateKey, false).slice(1); // throw away leading byte\n const messageHash = Buffer.from(\n sha3.keccak_256.update(toBuffer(message)).digest(),\n );\n const {signature, recid: recoveryId} = ecdsaSign(messageHash, privateKey);\n\n return this.createInstructionWithPublicKey({\n publicKey,\n message,\n signature,\n recoveryId,\n instructionIndex,\n });\n } catch (error) {\n throw new Error(`Error creating instruction; ${error}`);\n }\n }\n}\n","import {Buffer} from 'buffer';\nimport {\n assert as assertType,\n optional,\n string,\n type as pick,\n} from 'superstruct';\n\nimport * as Layout from './layout';\nimport * as shortvec from './util/shortvec-encoding';\nimport {PublicKey} from './publickey';\n\nexport const VALIDATOR_INFO_KEY = new PublicKey(\n 'Va1idator1nfo111111111111111111111111111111',\n);\n\n/**\n * @internal\n */\ntype ConfigKey = {\n publicKey: PublicKey;\n isSigner: boolean;\n};\n\n/**\n * Info used to identity validators.\n */\nexport type Info = {\n /** validator name */\n name: string;\n /** optional, validator website */\n website?: string;\n /** optional, extra information the validator chose to share */\n details?: string;\n /** optional, used to identify validators on keybase.io */\n keybaseUsername?: string;\n};\n\nconst InfoString = pick({\n name: string(),\n website: optional(string()),\n details: optional(string()),\n keybaseUsername: optional(string()),\n});\n\n/**\n * ValidatorInfo class\n */\nexport class ValidatorInfo {\n /**\n * validator public key\n */\n key: PublicKey;\n /**\n * validator information\n */\n info: Info;\n\n /**\n * Construct a valid ValidatorInfo\n *\n * @param key validator public key\n * @param info validator information\n */\n constructor(key: PublicKey, info: Info) {\n this.key = key;\n this.info = info;\n }\n\n /**\n * Deserialize ValidatorInfo from the config account data. Exactly two config\n * keys are required in the data.\n *\n * @param buffer config account data\n * @return null if info was not found\n */\n static fromConfigData(\n buffer: Buffer | Uint8Array | Array,\n ): ValidatorInfo | null {\n const PUBKEY_LENGTH = 32;\n\n let byteArray = [...buffer];\n const configKeyCount = shortvec.decodeLength(byteArray);\n if (configKeyCount !== 2) return null;\n\n const configKeys: Array = [];\n for (let i = 0; i < 2; i++) {\n const publicKey = new PublicKey(byteArray.slice(0, PUBKEY_LENGTH));\n byteArray = byteArray.slice(PUBKEY_LENGTH);\n const isSigner = byteArray.slice(0, 1)[0] === 1;\n byteArray = byteArray.slice(1);\n configKeys.push({publicKey, isSigner});\n }\n\n if (configKeys[0].publicKey.equals(VALIDATOR_INFO_KEY)) {\n if (configKeys[1].isSigner) {\n const rawInfo: any = Layout.rustString().decode(Buffer.from(byteArray));\n const info = JSON.parse(rawInfo as string);\n assertType(info, InfoString);\n return new ValidatorInfo(configKeys[1].publicKey, info);\n }\n }\n\n return null;\n }\n}\n","import * as BufferLayout from '@solana/buffer-layout';\nimport type {Buffer} from 'buffer';\n\nimport * as Layout from './layout';\nimport {PublicKey} from './publickey';\nimport {toBuffer} from './util/to-buffer';\n\nexport const VOTE_PROGRAM_ID = new PublicKey(\n 'Vote111111111111111111111111111111111111111',\n);\n\nexport type Lockout = {\n slot: number;\n confirmationCount: number;\n};\n\n/**\n * History of how many credits earned by the end of each epoch\n */\nexport type EpochCredits = {\n epoch: number;\n credits: number;\n prevCredits: number;\n};\n\nexport type AuthorizedVoter = {\n epoch: number;\n authorizedVoter: PublicKey;\n};\n\nexport type PriorVoter = {\n authorizedPubkey: PublicKey;\n epochOfLastAuthorizedSwitch: number;\n targetEpoch: number;\n};\n\nexport type BlockTimestamp = {\n slot: number;\n timetamp: number;\n};\n\n/**\n * See https://github.com/solana-labs/solana/blob/8a12ed029cfa38d4a45400916c2463fb82bbec8c/programs/vote_api/src/vote_state.rs#L68-L88\n *\n * @internal\n */\nconst VoteAccountLayout = BufferLayout.struct([\n Layout.publicKey('nodePubkey'),\n Layout.publicKey('authorizedWithdrawer'),\n BufferLayout.u8('commission'),\n BufferLayout.nu64(), // votes.length\n BufferLayout.seq(\n BufferLayout.struct([\n BufferLayout.nu64('slot'),\n BufferLayout.u32('confirmationCount'),\n ]),\n BufferLayout.offset(BufferLayout.u32(), -8),\n 'votes',\n ),\n BufferLayout.u8('rootSlotValid'),\n BufferLayout.nu64('rootSlot'),\n BufferLayout.nu64(), // authorizedVoters.length\n BufferLayout.seq(\n BufferLayout.struct([\n BufferLayout.nu64('epoch'),\n Layout.publicKey('authorizedVoter'),\n ]),\n BufferLayout.offset(BufferLayout.u32(), -8),\n 'authorizedVoters',\n ),\n BufferLayout.struct(\n [\n BufferLayout.seq(\n BufferLayout.struct([\n Layout.publicKey('authorizedPubkey'),\n BufferLayout.nu64('epochOfLastAuthorizedSwitch'),\n BufferLayout.nu64('targetEpoch'),\n ]),\n 32,\n 'buf',\n ),\n BufferLayout.nu64('idx'),\n BufferLayout.u8('isEmpty'),\n ],\n 'priorVoters',\n ),\n BufferLayout.nu64(), // epochCredits.length\n BufferLayout.seq(\n BufferLayout.struct([\n BufferLayout.nu64('epoch'),\n BufferLayout.nu64('credits'),\n BufferLayout.nu64('prevCredits'),\n ]),\n BufferLayout.offset(BufferLayout.u32(), -8),\n 'epochCredits',\n ),\n BufferLayout.struct(\n [BufferLayout.nu64('slot'), BufferLayout.nu64('timestamp')],\n 'lastTimestamp',\n ),\n]);\n\ntype VoteAccountArgs = {\n nodePubkey: PublicKey;\n authorizedWithdrawer: PublicKey;\n commission: number;\n rootSlot: number | null;\n votes: Lockout[];\n authorizedVoters: AuthorizedVoter[];\n priorVoters: PriorVoter[];\n epochCredits: EpochCredits[];\n lastTimestamp: BlockTimestamp;\n};\n\n/**\n * VoteAccount class\n */\nexport class VoteAccount {\n nodePubkey: PublicKey;\n authorizedWithdrawer: PublicKey;\n commission: number;\n rootSlot: number | null;\n votes: Lockout[];\n authorizedVoters: AuthorizedVoter[];\n priorVoters: PriorVoter[];\n epochCredits: EpochCredits[];\n lastTimestamp: BlockTimestamp;\n\n /**\n * @internal\n */\n constructor(args: VoteAccountArgs) {\n this.nodePubkey = args.nodePubkey;\n this.authorizedWithdrawer = args.authorizedWithdrawer;\n this.commission = args.commission;\n this.rootSlot = args.rootSlot;\n this.votes = args.votes;\n this.authorizedVoters = args.authorizedVoters;\n this.priorVoters = args.priorVoters;\n this.epochCredits = args.epochCredits;\n this.lastTimestamp = args.lastTimestamp;\n }\n\n /**\n * Deserialize VoteAccount from the account data.\n *\n * @param buffer account data\n * @return VoteAccount\n */\n static fromAccountData(\n buffer: Buffer | Uint8Array | Array,\n ): VoteAccount {\n const versionOffset = 4;\n const va = VoteAccountLayout.decode(toBuffer(buffer), versionOffset);\n\n let rootSlot: number | null = va.rootSlot;\n if (!va.rootSlotValid) {\n rootSlot = null;\n }\n\n return new VoteAccount({\n nodePubkey: new PublicKey(va.nodePubkey),\n authorizedWithdrawer: new PublicKey(va.authorizedWithdrawer),\n commission: va.commission,\n votes: va.votes,\n rootSlot,\n authorizedVoters: va.authorizedVoters.map(parseAuthorizedVoter),\n priorVoters: getPriorVoters(va.priorVoters),\n epochCredits: va.epochCredits,\n lastTimestamp: va.lastTimestamp,\n });\n }\n}\n\nfunction parseAuthorizedVoter({epoch, authorizedVoter}: AuthorizedVoter) {\n return {\n epoch,\n authorizedVoter: new PublicKey(authorizedVoter),\n };\n}\n\nfunction parsePriorVoters({\n authorizedPubkey,\n epochOfLastAuthorizedSwitch,\n targetEpoch,\n}: PriorVoter) {\n return {\n authorizedPubkey: new PublicKey(authorizedPubkey),\n epochOfLastAuthorizedSwitch,\n targetEpoch,\n };\n}\n\nfunction getPriorVoters({\n buf,\n idx,\n isEmpty,\n}: {\n buf: PriorVoter[];\n idx: number;\n isEmpty: boolean;\n}): PriorVoter[] {\n if (isEmpty) {\n return [];\n }\n\n return [...buf.slice(idx + 1).map(parsePriorVoters), ...buf.slice(0, idx)];\n}\n","import type {Buffer} from 'buffer';\n\nimport {Connection} from '../connection';\nimport type {TransactionSignature} from '../transaction';\nimport type {ConfirmOptions} from '../connection';\n\n/**\n * Send and confirm a raw transaction\n *\n * If `commitment` option is not specified, defaults to 'max' commitment.\n *\n * @param {Connection} connection\n * @param {Buffer} rawTransaction\n * @param {ConfirmOptions} [options]\n * @returns {Promise}\n */\nexport async function sendAndConfirmRawTransaction(\n connection: Connection,\n rawTransaction: Buffer,\n options?: ConfirmOptions,\n): Promise {\n const sendOptions = options && {\n skipPreflight: options.skipPreflight,\n preflightCommitment: options.preflightCommitment || options.commitment,\n };\n\n const signature = await connection.sendRawTransaction(\n rawTransaction,\n sendOptions,\n );\n\n const status = (\n await connection.confirmTransaction(\n signature,\n options && options.commitment,\n )\n ).value;\n\n if (status.err) {\n throw new Error(\n `Raw transaction ${signature} failed (${JSON.stringify(status)})`,\n );\n }\n\n return signature;\n}\n","const endpoint = {\n http: {\n devnet: 'http://api.devnet.solana.com',\n testnet: 'http://api.testnet.solana.com',\n 'mainnet-beta': 'http://api.mainnet-beta.solana.com',\n },\n https: {\n devnet: 'https://api.devnet.solana.com',\n testnet: 'https://api.testnet.solana.com',\n 'mainnet-beta': 'https://api.mainnet-beta.solana.com',\n },\n};\n\nexport type Cluster = 'devnet' | 'testnet' | 'mainnet-beta';\n\n/**\n * Retrieves the RPC API URL for the specified cluster\n */\nexport function clusterApiUrl(cluster?: Cluster, tls?: boolean): string {\n const key = tls === false ? 'http' : 'https';\n\n if (!cluster) {\n return endpoint[key]['devnet'];\n }\n\n const url = endpoint[key][cluster];\n if (!url) {\n throw new Error(`Unknown ${key} cluster: ${cluster}`);\n }\n return url;\n}\n","import { dotCase, Options } from \"dot-case\";\n\nexport { Options };\n\nexport function snakeCase(input: string, options: Options = {}) {\n return dotCase(input, {\n delimiter: \"_\",\n ...options,\n });\n}\n","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nexport default function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n\n var F = function F() {};\n\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export { default as BN } from \"bn.js\";\nimport * as web3_1 from \"@solana/web3.js\";\nexport { web3_1 as web3 };\nexport { default as Provider, getProvider, setProvider, NodeWallet as Wallet, } from \"./provider\";\nexport { default as Coder, InstructionCoder, EventCoder, StateCoder, AccountsCoder, } from \"./coder\";\nexport * from \"./error\";\nexport { default as workspace } from \"./workspace\";\nimport * as utils_1 from \"./utils\";\nexport { utils_1 as utils };\nexport * from \"./program\";\n//# sourceMappingURL=index.js.map","var basex = require('base-x')\nvar ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'\n\nmodule.exports = basex(ALPHABET)\n","import { PublicKey } from \"@solana/web3.js\";\nexport function parseIdlErrors(idl) {\n const errors = new Map();\n if (idl.errors) {\n idl.errors.forEach((e) => {\n var _a;\n let msg = (_a = e.msg) !== null && _a !== void 0 ? _a : e.name;\n errors.set(e.code, msg);\n });\n }\n return errors;\n}\n// Allow either IdLInstruction or IdlStateMethod since the types share fields.\nexport function toInstruction(idlIx, ...args) {\n if (idlIx.args.length != args.length) {\n throw new Error(\"Invalid argument length\");\n }\n const ix = {};\n let idx = 0;\n idlIx.args.forEach((ixArg) => {\n ix[ixArg.name] = args[idx];\n idx += 1;\n });\n return ix;\n}\n// Throws error if any account required for the `ix` is not given.\nexport function validateAccounts(ixAccounts, accounts = {}) {\n ixAccounts.forEach((acc) => {\n if (\"accounts\" in acc) {\n validateAccounts(acc.accounts, accounts[acc.name]);\n }\n else {\n if (accounts[acc.name] === undefined) {\n throw new Error(`Invalid arguments: ${acc.name} not provided.`);\n }\n }\n });\n}\n// Translates an address to a Pubkey.\nexport function translateAddress(address) {\n if (typeof address === \"string\") {\n const pk = new PublicKey(address);\n return pk;\n }\n else {\n return address;\n }\n}\n//# sourceMappingURL=common.js.map","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","'use strict';\n\nconst preserveCamelCase = string => {\n\tlet isLastCharLower = false;\n\tlet isLastCharUpper = false;\n\tlet isLastLastCharUpper = false;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst character = string[i];\n\n\t\tif (isLastCharLower && /[a-zA-Z]/.test(character) && character.toUpperCase() === character) {\n\t\t\tstring = string.slice(0, i) + '-' + string.slice(i);\n\t\t\tisLastCharLower = false;\n\t\t\tisLastLastCharUpper = isLastCharUpper;\n\t\t\tisLastCharUpper = true;\n\t\t\ti++;\n\t\t} else if (isLastCharUpper && isLastLastCharUpper && /[a-zA-Z]/.test(character) && character.toLowerCase() === character) {\n\t\t\tstring = string.slice(0, i - 1) + '-' + string.slice(i - 1);\n\t\t\tisLastLastCharUpper = isLastCharUpper;\n\t\t\tisLastCharUpper = false;\n\t\t\tisLastCharLower = true;\n\t\t} else {\n\t\t\tisLastCharLower = character.toLowerCase() === character && character.toUpperCase() !== character;\n\t\t\tisLastLastCharUpper = isLastCharUpper;\n\t\t\tisLastCharUpper = character.toUpperCase() === character && character.toLowerCase() !== character;\n\t\t}\n\t}\n\n\treturn string;\n};\n\nconst camelCase = (input, options) => {\n\tif (!(typeof input === 'string' || Array.isArray(input))) {\n\t\tthrow new TypeError('Expected the input to be `string | string[]`');\n\t}\n\n\toptions = Object.assign({\n\t\tpascalCase: false\n\t}, options);\n\n\tconst postProcess = x => options.pascalCase ? x.charAt(0).toUpperCase() + x.slice(1) : x;\n\n\tif (Array.isArray(input)) {\n\t\tinput = input.map(x => x.trim())\n\t\t\t.filter(x => x.length)\n\t\t\t.join('-');\n\t} else {\n\t\tinput = input.trim();\n\t}\n\n\tif (input.length === 0) {\n\t\treturn '';\n\t}\n\n\tif (input.length === 1) {\n\t\treturn options.pascalCase ? input.toUpperCase() : input.toLowerCase();\n\t}\n\n\tconst hasUpperCase = input !== input.toLowerCase();\n\n\tif (hasUpperCase) {\n\t\tinput = preserveCamelCase(input);\n\t}\n\n\tinput = input\n\t\t.replace(/^[_.\\- ]+/, '')\n\t\t.toLowerCase()\n\t\t.replace(/[_.\\- ]+(\\w|$)/g, (_, p1) => p1.toUpperCase())\n\t\t.replace(/\\d+(\\w|$)/g, m => m.toUpperCase());\n\n\treturn postProcess(input);\n};\n\nmodule.exports = camelCase;\n// TODO: Remove this for the next major release\nmodule.exports.default = camelCase;\n","import { InstructionCoder } from \"./instruction\";\nimport { AccountsCoder } from \"./accounts\";\nimport { EventCoder } from \"./event\";\nimport { StateCoder } from \"./state\";\nimport { sighash } from \"./common\";\nexport { accountSize } from \"./common\";\nexport { InstructionCoder } from \"./instruction\";\nexport { AccountsCoder, ACCOUNT_DISCRIMINATOR_SIZE } from \"./accounts\";\nexport { EventCoder, eventDiscriminator } from \"./event\";\nexport { StateCoder, stateDiscriminator } from \"./state\";\n/**\n * Coder provides a facade for encoding and decoding all IDL related objects.\n */\nexport default class Coder {\n constructor(idl) {\n this.instruction = new InstructionCoder(idl);\n this.accounts = new AccountsCoder(idl);\n this.events = new EventCoder(idl);\n if (idl.state) {\n this.state = new StateCoder(idl);\n }\n }\n sighash(nameSpace, ixName) {\n return sighash(nameSpace, ixName);\n }\n}\n//# sourceMappingURL=index.js.map","export class IdlError extends Error {\n constructor(message) {\n super(message);\n this.name = \"IdlError\";\n }\n}\n// An error from a user defined program.\nexport class ProgramError extends Error {\n constructor(code, msg, ...params) {\n super(...params);\n this.code = code;\n this.msg = msg;\n }\n static parse(err, idlErrors) {\n // TODO: don't rely on the error string. web3.js should preserve the error\n // code information instead of giving us an untyped string.\n let components = err.toString().split(\"custom program error: \");\n if (components.length !== 2) {\n return null;\n }\n let errorCode;\n try {\n errorCode = parseInt(components[1]);\n }\n catch (parseErr) {\n return null;\n }\n // Parse user error.\n let errorMsg = idlErrors.get(errorCode);\n if (errorMsg !== undefined) {\n return new ProgramError(errorCode, errorMsg, errorCode + \": \" + errorMsg);\n }\n // Parse framework internal error.\n errorMsg = LangErrorMessage.get(errorCode);\n if (errorMsg !== undefined) {\n return new ProgramError(errorCode, errorMsg, errorCode + \": \" + errorMsg);\n }\n // Unable to parse the error. Just return the untranslated error.\n return null;\n }\n toString() {\n return this.msg;\n }\n}\nconst LangErrorCode = {\n // Instructions.\n InstructionMissing: 100,\n InstructionFallbackNotFound: 101,\n InstructionDidNotDeserialize: 102,\n InstructionDidNotSerialize: 103,\n // IDL instructions.\n IdlInstructionStub: 120,\n IdlInstructionInvalidProgram: 121,\n // Constraints.\n ConstraintMut: 140,\n ConstraintHasOne: 141,\n ConstraintSigner: 142,\n ConstraintRaw: 143,\n ConstraintOwner: 144,\n ConstraintRentExempt: 145,\n ConstraintSeeds: 146,\n ConstraintExecutable: 147,\n ConstraintState: 148,\n ConstraintAssociated: 149,\n ConstraintAssociatedInit: 150,\n ConstraintClose: 151,\n ConstraintAddress: 152,\n // Accounts.\n AccountDiscriminatorAlreadySet: 160,\n AccountDiscriminatorNotFound: 161,\n AccountDiscriminatorMismatch: 162,\n AccountDidNotDeserialize: 163,\n AccountDidNotSerialize: 164,\n AccountNotEnoughKeys: 165,\n AccountNotMutable: 166,\n AccountNotProgramOwned: 167,\n InvalidProgramId: 168,\n InvalidProgramExecutable: 169,\n AccountNotSigner: 170,\n AccountNotSystemOwned: 171,\n // State.\n StateInvalidAddress: 180,\n // Used for APIs that shouldn't be used anymore.\n Deprecated: 299,\n};\nconst LangErrorMessage = new Map([\n // Instructions.\n [\n LangErrorCode.InstructionMissing,\n \"8 byte instruction identifier not provided\",\n ],\n [\n LangErrorCode.InstructionFallbackNotFound,\n \"Fallback functions are not supported\",\n ],\n [\n LangErrorCode.InstructionDidNotDeserialize,\n \"The program could not deserialize the given instruction\",\n ],\n [\n LangErrorCode.InstructionDidNotSerialize,\n \"The program could not serialize the given instruction\",\n ],\n // Idl instructions.\n [\n LangErrorCode.IdlInstructionStub,\n \"The program was compiled without idl instructions\",\n ],\n [\n LangErrorCode.IdlInstructionInvalidProgram,\n \"The transaction was given an invalid program for the IDL instruction\",\n ],\n // Constraints.\n [LangErrorCode.ConstraintMut, \"A mut constraint was violated\"],\n [LangErrorCode.ConstraintHasOne, \"A has_one constraint was violated\"],\n [LangErrorCode.ConstraintSigner, \"A signer constraint was violated\"],\n [LangErrorCode.ConstraintRaw, \"A raw constraint was violated\"],\n [LangErrorCode.ConstraintOwner, \"An owner constraint was violated\"],\n [LangErrorCode.ConstraintRentExempt, \"A rent exempt constraint was violated\"],\n [LangErrorCode.ConstraintSeeds, \"A seeds constraint was violated\"],\n [LangErrorCode.ConstraintExecutable, \"An executable constraint was violated\"],\n [LangErrorCode.ConstraintState, \"A state constraint was violated\"],\n [LangErrorCode.ConstraintAssociated, \"An associated constraint was violated\"],\n [\n LangErrorCode.ConstraintAssociatedInit,\n \"An associated init constraint was violated\",\n ],\n [LangErrorCode.ConstraintClose, \"A close constraint was violated\"],\n [LangErrorCode.ConstraintAddress, \"An address constraint was violated\"],\n // Accounts.\n [\n LangErrorCode.AccountDiscriminatorAlreadySet,\n \"The account discriminator was already set on this account\",\n ],\n [\n LangErrorCode.AccountDiscriminatorNotFound,\n \"No 8 byte discriminator was found on the account\",\n ],\n [\n LangErrorCode.AccountDiscriminatorMismatch,\n \"8 byte discriminator did not match what was expected\",\n ],\n [LangErrorCode.AccountDidNotDeserialize, \"Failed to deserialize the account\"],\n [LangErrorCode.AccountDidNotSerialize, \"Failed to serialize the account\"],\n [\n LangErrorCode.AccountNotEnoughKeys,\n \"Not enough account keys given to the instruction\",\n ],\n [LangErrorCode.AccountNotMutable, \"The given account is not mutable\"],\n [\n LangErrorCode.AccountNotProgramOwned,\n \"The given account is not owned by the executing program\",\n ],\n [LangErrorCode.InvalidProgramId, \"Program ID was not as expected\"],\n [LangErrorCode.InvalidProgramExecutable, \"Program account is not executable\"],\n [LangErrorCode.AccountNotSigner, \"The given account did not sign\"],\n [\n LangErrorCode.AccountNotSystemOwned,\n \"The given account is not owned by the system program\",\n ],\n // State.\n [\n LangErrorCode.StateInvalidAddress,\n \"The given state account does not have the correct address\",\n ],\n // Misc.\n [\n LangErrorCode.Deprecated,\n \"The API being used is deprecated and should no longer be used\",\n ],\n]);\n//# sourceMappingURL=error.js.map","/**\n * [js-sha256]{@link https://github.com/emn178/js-sha256}\n *\n * @version 0.9.0\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2014-2017\n * @license MIT\n */\n/*jslint bitwise: true */\n(function () {\n 'use strict';\n\n var ERROR = 'input is invalid type';\n var WINDOW = typeof window === 'object';\n var root = WINDOW ? window : {};\n if (root.JS_SHA256_NO_WINDOW) {\n WINDOW = false;\n }\n var WEB_WORKER = !WINDOW && typeof self === 'object';\n var NODE_JS = !root.JS_SHA256_NO_NODE_JS && typeof process === 'object' && process.versions && process.versions.node;\n if (NODE_JS) {\n root = global;\n } else if (WEB_WORKER) {\n root = self;\n }\n var COMMON_JS = !root.JS_SHA256_NO_COMMON_JS && typeof module === 'object' && module.exports;\n var AMD = typeof define === 'function' && define.amd;\n var ARRAY_BUFFER = !root.JS_SHA256_NO_ARRAY_BUFFER && typeof ArrayBuffer !== 'undefined';\n var HEX_CHARS = '0123456789abcdef'.split('');\n var EXTRA = [-2147483648, 8388608, 32768, 128];\n var SHIFT = [24, 16, 8, 0];\n var K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n ];\n var OUTPUT_TYPES = ['hex', 'array', 'digest', 'arrayBuffer'];\n\n var blocks = [];\n\n if (root.JS_SHA256_NO_NODE_JS || !Array.isArray) {\n Array.isArray = function (obj) {\n return Object.prototype.toString.call(obj) === '[object Array]';\n };\n }\n\n if (ARRAY_BUFFER && (root.JS_SHA256_NO_ARRAY_BUFFER_IS_VIEW || !ArrayBuffer.isView)) {\n ArrayBuffer.isView = function (obj) {\n return typeof obj === 'object' && obj.buffer && obj.buffer.constructor === ArrayBuffer;\n };\n }\n\n var createOutputMethod = function (outputType, is224) {\n return function (message) {\n return new Sha256(is224, true).update(message)[outputType]();\n };\n };\n\n var createMethod = function (is224) {\n var method = createOutputMethod('hex', is224);\n if (NODE_JS) {\n method = nodeWrap(method, is224);\n }\n method.create = function () {\n return new Sha256(is224);\n };\n method.update = function (message) {\n return method.create().update(message);\n };\n for (var i = 0; i < OUTPUT_TYPES.length; ++i) {\n var type = OUTPUT_TYPES[i];\n method[type] = createOutputMethod(type, is224);\n }\n return method;\n };\n\n var nodeWrap = function (method, is224) {\n var crypto = eval(\"require('crypto')\");\n var Buffer = eval(\"require('buffer').Buffer\");\n var algorithm = is224 ? 'sha224' : 'sha256';\n var nodeMethod = function (message) {\n if (typeof message === 'string') {\n return crypto.createHash(algorithm).update(message, 'utf8').digest('hex');\n } else {\n if (message === null || message === undefined) {\n throw new Error(ERROR);\n } else if (message.constructor === ArrayBuffer) {\n message = new Uint8Array(message);\n }\n }\n if (Array.isArray(message) || ArrayBuffer.isView(message) ||\n message.constructor === Buffer) {\n return crypto.createHash(algorithm).update(new Buffer(message)).digest('hex');\n } else {\n return method(message);\n }\n };\n return nodeMethod;\n };\n\n var createHmacOutputMethod = function (outputType, is224) {\n return function (key, message) {\n return new HmacSha256(key, is224, true).update(message)[outputType]();\n };\n };\n\n var createHmacMethod = function (is224) {\n var method = createHmacOutputMethod('hex', is224);\n method.create = function (key) {\n return new HmacSha256(key, is224);\n };\n method.update = function (key, message) {\n return method.create(key).update(message);\n };\n for (var i = 0; i < OUTPUT_TYPES.length; ++i) {\n var type = OUTPUT_TYPES[i];\n method[type] = createHmacOutputMethod(type, is224);\n }\n return method;\n };\n\n function Sha256(is224, sharedMemory) {\n if (sharedMemory) {\n blocks[0] = blocks[16] = blocks[1] = blocks[2] = blocks[3] =\n blocks[4] = blocks[5] = blocks[6] = blocks[7] =\n blocks[8] = blocks[9] = blocks[10] = blocks[11] =\n blocks[12] = blocks[13] = blocks[14] = blocks[15] = 0;\n this.blocks = blocks;\n } else {\n this.blocks = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n }\n\n if (is224) {\n this.h0 = 0xc1059ed8;\n this.h1 = 0x367cd507;\n this.h2 = 0x3070dd17;\n this.h3 = 0xf70e5939;\n this.h4 = 0xffc00b31;\n this.h5 = 0x68581511;\n this.h6 = 0x64f98fa7;\n this.h7 = 0xbefa4fa4;\n } else { // 256\n this.h0 = 0x6a09e667;\n this.h1 = 0xbb67ae85;\n this.h2 = 0x3c6ef372;\n this.h3 = 0xa54ff53a;\n this.h4 = 0x510e527f;\n this.h5 = 0x9b05688c;\n this.h6 = 0x1f83d9ab;\n this.h7 = 0x5be0cd19;\n }\n\n this.block = this.start = this.bytes = this.hBytes = 0;\n this.finalized = this.hashed = false;\n this.first = true;\n this.is224 = is224;\n }\n\n Sha256.prototype.update = function (message) {\n if (this.finalized) {\n return;\n }\n var notString, type = typeof message;\n if (type !== 'string') {\n if (type === 'object') {\n if (message === null) {\n throw new Error(ERROR);\n } else if (ARRAY_BUFFER && message.constructor === ArrayBuffer) {\n message = new Uint8Array(message);\n } else if (!Array.isArray(message)) {\n if (!ARRAY_BUFFER || !ArrayBuffer.isView(message)) {\n throw new Error(ERROR);\n }\n }\n } else {\n throw new Error(ERROR);\n }\n notString = true;\n }\n var code, index = 0, i, length = message.length, blocks = this.blocks;\n\n while (index < length) {\n if (this.hashed) {\n this.hashed = false;\n blocks[0] = this.block;\n blocks[16] = blocks[1] = blocks[2] = blocks[3] =\n blocks[4] = blocks[5] = blocks[6] = blocks[7] =\n blocks[8] = blocks[9] = blocks[10] = blocks[11] =\n blocks[12] = blocks[13] = blocks[14] = blocks[15] = 0;\n }\n\n if (notString) {\n for (i = this.start; index < length && i < 64; ++index) {\n blocks[i >> 2] |= message[index] << SHIFT[i++ & 3];\n }\n } else {\n for (i = this.start; index < length && i < 64; ++index) {\n code = message.charCodeAt(index);\n if (code < 0x80) {\n blocks[i >> 2] |= code << SHIFT[i++ & 3];\n } else if (code < 0x800) {\n blocks[i >> 2] |= (0xc0 | (code >> 6)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n } else if (code < 0xd800 || code >= 0xe000) {\n blocks[i >> 2] |= (0xe0 | (code >> 12)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 6) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n } else {\n code = 0x10000 + (((code & 0x3ff) << 10) | (message.charCodeAt(++index) & 0x3ff));\n blocks[i >> 2] |= (0xf0 | (code >> 18)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 12) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 6) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n }\n }\n }\n\n this.lastByteIndex = i;\n this.bytes += i - this.start;\n if (i >= 64) {\n this.block = blocks[16];\n this.start = i - 64;\n this.hash();\n this.hashed = true;\n } else {\n this.start = i;\n }\n }\n if (this.bytes > 4294967295) {\n this.hBytes += this.bytes / 4294967296 << 0;\n this.bytes = this.bytes % 4294967296;\n }\n return this;\n };\n\n Sha256.prototype.finalize = function () {\n if (this.finalized) {\n return;\n }\n this.finalized = true;\n var blocks = this.blocks, i = this.lastByteIndex;\n blocks[16] = this.block;\n blocks[i >> 2] |= EXTRA[i & 3];\n this.block = blocks[16];\n if (i >= 56) {\n if (!this.hashed) {\n this.hash();\n }\n blocks[0] = this.block;\n blocks[16] = blocks[1] = blocks[2] = blocks[3] =\n blocks[4] = blocks[5] = blocks[6] = blocks[7] =\n blocks[8] = blocks[9] = blocks[10] = blocks[11] =\n blocks[12] = blocks[13] = blocks[14] = blocks[15] = 0;\n }\n blocks[14] = this.hBytes << 3 | this.bytes >>> 29;\n blocks[15] = this.bytes << 3;\n this.hash();\n };\n\n Sha256.prototype.hash = function () {\n var a = this.h0, b = this.h1, c = this.h2, d = this.h3, e = this.h4, f = this.h5, g = this.h6,\n h = this.h7, blocks = this.blocks, j, s0, s1, maj, t1, t2, ch, ab, da, cd, bc;\n\n for (j = 16; j < 64; ++j) {\n // rightrotate\n t1 = blocks[j - 15];\n s0 = ((t1 >>> 7) | (t1 << 25)) ^ ((t1 >>> 18) | (t1 << 14)) ^ (t1 >>> 3);\n t1 = blocks[j - 2];\n s1 = ((t1 >>> 17) | (t1 << 15)) ^ ((t1 >>> 19) | (t1 << 13)) ^ (t1 >>> 10);\n blocks[j] = blocks[j - 16] + s0 + blocks[j - 7] + s1 << 0;\n }\n\n bc = b & c;\n for (j = 0; j < 64; j += 4) {\n if (this.first) {\n if (this.is224) {\n ab = 300032;\n t1 = blocks[0] - 1413257819;\n h = t1 - 150054599 << 0;\n d = t1 + 24177077 << 0;\n } else {\n ab = 704751109;\n t1 = blocks[0] - 210244248;\n h = t1 - 1521486534 << 0;\n d = t1 + 143694565 << 0;\n }\n this.first = false;\n } else {\n s0 = ((a >>> 2) | (a << 30)) ^ ((a >>> 13) | (a << 19)) ^ ((a >>> 22) | (a << 10));\n s1 = ((e >>> 6) | (e << 26)) ^ ((e >>> 11) | (e << 21)) ^ ((e >>> 25) | (e << 7));\n ab = a & b;\n maj = ab ^ (a & c) ^ bc;\n ch = (e & f) ^ (~e & g);\n t1 = h + s1 + ch + K[j] + blocks[j];\n t2 = s0 + maj;\n h = d + t1 << 0;\n d = t1 + t2 << 0;\n }\n s0 = ((d >>> 2) | (d << 30)) ^ ((d >>> 13) | (d << 19)) ^ ((d >>> 22) | (d << 10));\n s1 = ((h >>> 6) | (h << 26)) ^ ((h >>> 11) | (h << 21)) ^ ((h >>> 25) | (h << 7));\n da = d & a;\n maj = da ^ (d & b) ^ ab;\n ch = (h & e) ^ (~h & f);\n t1 = g + s1 + ch + K[j + 1] + blocks[j + 1];\n t2 = s0 + maj;\n g = c + t1 << 0;\n c = t1 + t2 << 0;\n s0 = ((c >>> 2) | (c << 30)) ^ ((c >>> 13) | (c << 19)) ^ ((c >>> 22) | (c << 10));\n s1 = ((g >>> 6) | (g << 26)) ^ ((g >>> 11) | (g << 21)) ^ ((g >>> 25) | (g << 7));\n cd = c & d;\n maj = cd ^ (c & a) ^ da;\n ch = (g & h) ^ (~g & e);\n t1 = f + s1 + ch + K[j + 2] + blocks[j + 2];\n t2 = s0 + maj;\n f = b + t1 << 0;\n b = t1 + t2 << 0;\n s0 = ((b >>> 2) | (b << 30)) ^ ((b >>> 13) | (b << 19)) ^ ((b >>> 22) | (b << 10));\n s1 = ((f >>> 6) | (f << 26)) ^ ((f >>> 11) | (f << 21)) ^ ((f >>> 25) | (f << 7));\n bc = b & c;\n maj = bc ^ (b & d) ^ cd;\n ch = (f & g) ^ (~f & h);\n t1 = e + s1 + ch + K[j + 3] + blocks[j + 3];\n t2 = s0 + maj;\n e = a + t1 << 0;\n a = t1 + t2 << 0;\n }\n\n this.h0 = this.h0 + a << 0;\n this.h1 = this.h1 + b << 0;\n this.h2 = this.h2 + c << 0;\n this.h3 = this.h3 + d << 0;\n this.h4 = this.h4 + e << 0;\n this.h5 = this.h5 + f << 0;\n this.h6 = this.h6 + g << 0;\n this.h7 = this.h7 + h << 0;\n };\n\n Sha256.prototype.hex = function () {\n this.finalize();\n\n var h0 = this.h0, h1 = this.h1, h2 = this.h2, h3 = this.h3, h4 = this.h4, h5 = this.h5,\n h6 = this.h6, h7 = this.h7;\n\n var hex = HEX_CHARS[(h0 >> 28) & 0x0F] + HEX_CHARS[(h0 >> 24) & 0x0F] +\n HEX_CHARS[(h0 >> 20) & 0x0F] + HEX_CHARS[(h0 >> 16) & 0x0F] +\n HEX_CHARS[(h0 >> 12) & 0x0F] + HEX_CHARS[(h0 >> 8) & 0x0F] +\n HEX_CHARS[(h0 >> 4) & 0x0F] + HEX_CHARS[h0 & 0x0F] +\n HEX_CHARS[(h1 >> 28) & 0x0F] + HEX_CHARS[(h1 >> 24) & 0x0F] +\n HEX_CHARS[(h1 >> 20) & 0x0F] + HEX_CHARS[(h1 >> 16) & 0x0F] +\n HEX_CHARS[(h1 >> 12) & 0x0F] + HEX_CHARS[(h1 >> 8) & 0x0F] +\n HEX_CHARS[(h1 >> 4) & 0x0F] + HEX_CHARS[h1 & 0x0F] +\n HEX_CHARS[(h2 >> 28) & 0x0F] + HEX_CHARS[(h2 >> 24) & 0x0F] +\n HEX_CHARS[(h2 >> 20) & 0x0F] + HEX_CHARS[(h2 >> 16) & 0x0F] +\n HEX_CHARS[(h2 >> 12) & 0x0F] + HEX_CHARS[(h2 >> 8) & 0x0F] +\n HEX_CHARS[(h2 >> 4) & 0x0F] + HEX_CHARS[h2 & 0x0F] +\n HEX_CHARS[(h3 >> 28) & 0x0F] + HEX_CHARS[(h3 >> 24) & 0x0F] +\n HEX_CHARS[(h3 >> 20) & 0x0F] + HEX_CHARS[(h3 >> 16) & 0x0F] +\n HEX_CHARS[(h3 >> 12) & 0x0F] + HEX_CHARS[(h3 >> 8) & 0x0F] +\n HEX_CHARS[(h3 >> 4) & 0x0F] + HEX_CHARS[h3 & 0x0F] +\n HEX_CHARS[(h4 >> 28) & 0x0F] + HEX_CHARS[(h4 >> 24) & 0x0F] +\n HEX_CHARS[(h4 >> 20) & 0x0F] + HEX_CHARS[(h4 >> 16) & 0x0F] +\n HEX_CHARS[(h4 >> 12) & 0x0F] + HEX_CHARS[(h4 >> 8) & 0x0F] +\n HEX_CHARS[(h4 >> 4) & 0x0F] + HEX_CHARS[h4 & 0x0F] +\n HEX_CHARS[(h5 >> 28) & 0x0F] + HEX_CHARS[(h5 >> 24) & 0x0F] +\n HEX_CHARS[(h5 >> 20) & 0x0F] + HEX_CHARS[(h5 >> 16) & 0x0F] +\n HEX_CHARS[(h5 >> 12) & 0x0F] + HEX_CHARS[(h5 >> 8) & 0x0F] +\n HEX_CHARS[(h5 >> 4) & 0x0F] + HEX_CHARS[h5 & 0x0F] +\n HEX_CHARS[(h6 >> 28) & 0x0F] + HEX_CHARS[(h6 >> 24) & 0x0F] +\n HEX_CHARS[(h6 >> 20) & 0x0F] + HEX_CHARS[(h6 >> 16) & 0x0F] +\n HEX_CHARS[(h6 >> 12) & 0x0F] + HEX_CHARS[(h6 >> 8) & 0x0F] +\n HEX_CHARS[(h6 >> 4) & 0x0F] + HEX_CHARS[h6 & 0x0F];\n if (!this.is224) {\n hex += HEX_CHARS[(h7 >> 28) & 0x0F] + HEX_CHARS[(h7 >> 24) & 0x0F] +\n HEX_CHARS[(h7 >> 20) & 0x0F] + HEX_CHARS[(h7 >> 16) & 0x0F] +\n HEX_CHARS[(h7 >> 12) & 0x0F] + HEX_CHARS[(h7 >> 8) & 0x0F] +\n HEX_CHARS[(h7 >> 4) & 0x0F] + HEX_CHARS[h7 & 0x0F];\n }\n return hex;\n };\n\n Sha256.prototype.toString = Sha256.prototype.hex;\n\n Sha256.prototype.digest = function () {\n this.finalize();\n\n var h0 = this.h0, h1 = this.h1, h2 = this.h2, h3 = this.h3, h4 = this.h4, h5 = this.h5,\n h6 = this.h6, h7 = this.h7;\n\n var arr = [\n (h0 >> 24) & 0xFF, (h0 >> 16) & 0xFF, (h0 >> 8) & 0xFF, h0 & 0xFF,\n (h1 >> 24) & 0xFF, (h1 >> 16) & 0xFF, (h1 >> 8) & 0xFF, h1 & 0xFF,\n (h2 >> 24) & 0xFF, (h2 >> 16) & 0xFF, (h2 >> 8) & 0xFF, h2 & 0xFF,\n (h3 >> 24) & 0xFF, (h3 >> 16) & 0xFF, (h3 >> 8) & 0xFF, h3 & 0xFF,\n (h4 >> 24) & 0xFF, (h4 >> 16) & 0xFF, (h4 >> 8) & 0xFF, h4 & 0xFF,\n (h5 >> 24) & 0xFF, (h5 >> 16) & 0xFF, (h5 >> 8) & 0xFF, h5 & 0xFF,\n (h6 >> 24) & 0xFF, (h6 >> 16) & 0xFF, (h6 >> 8) & 0xFF, h6 & 0xFF\n ];\n if (!this.is224) {\n arr.push((h7 >> 24) & 0xFF, (h7 >> 16) & 0xFF, (h7 >> 8) & 0xFF, h7 & 0xFF);\n }\n return arr;\n };\n\n Sha256.prototype.array = Sha256.prototype.digest;\n\n Sha256.prototype.arrayBuffer = function () {\n this.finalize();\n\n var buffer = new ArrayBuffer(this.is224 ? 28 : 32);\n var dataView = new DataView(buffer);\n dataView.setUint32(0, this.h0);\n dataView.setUint32(4, this.h1);\n dataView.setUint32(8, this.h2);\n dataView.setUint32(12, this.h3);\n dataView.setUint32(16, this.h4);\n dataView.setUint32(20, this.h5);\n dataView.setUint32(24, this.h6);\n if (!this.is224) {\n dataView.setUint32(28, this.h7);\n }\n return buffer;\n };\n\n function HmacSha256(key, is224, sharedMemory) {\n var i, type = typeof key;\n if (type === 'string') {\n var bytes = [], length = key.length, index = 0, code;\n for (i = 0; i < length; ++i) {\n code = key.charCodeAt(i);\n if (code < 0x80) {\n bytes[index++] = code;\n } else if (code < 0x800) {\n bytes[index++] = (0xc0 | (code >> 6));\n bytes[index++] = (0x80 | (code & 0x3f));\n } else if (code < 0xd800 || code >= 0xe000) {\n bytes[index++] = (0xe0 | (code >> 12));\n bytes[index++] = (0x80 | ((code >> 6) & 0x3f));\n bytes[index++] = (0x80 | (code & 0x3f));\n } else {\n code = 0x10000 + (((code & 0x3ff) << 10) | (key.charCodeAt(++i) & 0x3ff));\n bytes[index++] = (0xf0 | (code >> 18));\n bytes[index++] = (0x80 | ((code >> 12) & 0x3f));\n bytes[index++] = (0x80 | ((code >> 6) & 0x3f));\n bytes[index++] = (0x80 | (code & 0x3f));\n }\n }\n key = bytes;\n } else {\n if (type === 'object') {\n if (key === null) {\n throw new Error(ERROR);\n } else if (ARRAY_BUFFER && key.constructor === ArrayBuffer) {\n key = new Uint8Array(key);\n } else if (!Array.isArray(key)) {\n if (!ARRAY_BUFFER || !ArrayBuffer.isView(key)) {\n throw new Error(ERROR);\n }\n }\n } else {\n throw new Error(ERROR);\n }\n }\n\n if (key.length > 64) {\n key = (new Sha256(is224, true)).update(key).array();\n }\n\n var oKeyPad = [], iKeyPad = [];\n for (i = 0; i < 64; ++i) {\n var b = key[i] || 0;\n oKeyPad[i] = 0x5c ^ b;\n iKeyPad[i] = 0x36 ^ b;\n }\n\n Sha256.call(this, is224, sharedMemory);\n\n this.update(iKeyPad);\n this.oKeyPad = oKeyPad;\n this.inner = true;\n this.sharedMemory = sharedMemory;\n }\n HmacSha256.prototype = new Sha256();\n\n HmacSha256.prototype.finalize = function () {\n Sha256.prototype.finalize.call(this);\n if (this.inner) {\n this.inner = false;\n var innerHash = this.array();\n Sha256.call(this, this.is224, this.sharedMemory);\n this.update(this.oKeyPad);\n this.update(innerHash);\n Sha256.prototype.finalize.call(this);\n }\n };\n\n var exports = createMethod();\n exports.sha256 = exports;\n exports.sha224 = createMethod(true);\n exports.sha256.hmac = createHmacMethod();\n exports.sha224.hmac = createHmacMethod(true);\n\n if (COMMON_JS) {\n module.exports = exports;\n } else {\n root.sha256 = exports.sha256;\n root.sha224 = exports.sha224;\n if (AMD) {\n define(function () {\n return exports;\n });\n }\n }\n})();\n","(function(nacl) {\n'use strict';\n\n// Ported in 2014 by Dmitry Chestnykh and Devi Mandiri.\n// Public domain.\n//\n// Implementation derived from TweetNaCl version 20140427.\n// See for details: http://tweetnacl.cr.yp.to/\n\nvar gf = function(init) {\n var i, r = new Float64Array(16);\n if (init) for (i = 0; i < init.length; i++) r[i] = init[i];\n return r;\n};\n\n// Pluggable, initialized in high-level API below.\nvar randombytes = function(/* x, n */) { throw new Error('no PRNG'); };\n\nvar _0 = new Uint8Array(16);\nvar _9 = new Uint8Array(32); _9[0] = 9;\n\nvar gf0 = gf(),\n gf1 = gf([1]),\n _121665 = gf([0xdb41, 1]),\n D = gf([0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070, 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]),\n D2 = gf([0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0, 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]),\n X = gf([0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c, 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]),\n Y = gf([0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]),\n I = gf([0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43, 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n\nfunction ts64(x, i, h, l) {\n x[i] = (h >> 24) & 0xff;\n x[i+1] = (h >> 16) & 0xff;\n x[i+2] = (h >> 8) & 0xff;\n x[i+3] = h & 0xff;\n x[i+4] = (l >> 24) & 0xff;\n x[i+5] = (l >> 16) & 0xff;\n x[i+6] = (l >> 8) & 0xff;\n x[i+7] = l & 0xff;\n}\n\nfunction vn(x, xi, y, yi, n) {\n var i,d = 0;\n for (i = 0; i < n; i++) d |= x[xi+i]^y[yi+i];\n return (1 & ((d - 1) >>> 8)) - 1;\n}\n\nfunction crypto_verify_16(x, xi, y, yi) {\n return vn(x,xi,y,yi,16);\n}\n\nfunction crypto_verify_32(x, xi, y, yi) {\n return vn(x,xi,y,yi,32);\n}\n\nfunction core_salsa20(o, p, k, c) {\n var j0 = c[ 0] & 0xff | (c[ 1] & 0xff)<<8 | (c[ 2] & 0xff)<<16 | (c[ 3] & 0xff)<<24,\n j1 = k[ 0] & 0xff | (k[ 1] & 0xff)<<8 | (k[ 2] & 0xff)<<16 | (k[ 3] & 0xff)<<24,\n j2 = k[ 4] & 0xff | (k[ 5] & 0xff)<<8 | (k[ 6] & 0xff)<<16 | (k[ 7] & 0xff)<<24,\n j3 = k[ 8] & 0xff | (k[ 9] & 0xff)<<8 | (k[10] & 0xff)<<16 | (k[11] & 0xff)<<24,\n j4 = k[12] & 0xff | (k[13] & 0xff)<<8 | (k[14] & 0xff)<<16 | (k[15] & 0xff)<<24,\n j5 = c[ 4] & 0xff | (c[ 5] & 0xff)<<8 | (c[ 6] & 0xff)<<16 | (c[ 7] & 0xff)<<24,\n j6 = p[ 0] & 0xff | (p[ 1] & 0xff)<<8 | (p[ 2] & 0xff)<<16 | (p[ 3] & 0xff)<<24,\n j7 = p[ 4] & 0xff | (p[ 5] & 0xff)<<8 | (p[ 6] & 0xff)<<16 | (p[ 7] & 0xff)<<24,\n j8 = p[ 8] & 0xff | (p[ 9] & 0xff)<<8 | (p[10] & 0xff)<<16 | (p[11] & 0xff)<<24,\n j9 = p[12] & 0xff | (p[13] & 0xff)<<8 | (p[14] & 0xff)<<16 | (p[15] & 0xff)<<24,\n j10 = c[ 8] & 0xff | (c[ 9] & 0xff)<<8 | (c[10] & 0xff)<<16 | (c[11] & 0xff)<<24,\n j11 = k[16] & 0xff | (k[17] & 0xff)<<8 | (k[18] & 0xff)<<16 | (k[19] & 0xff)<<24,\n j12 = k[20] & 0xff | (k[21] & 0xff)<<8 | (k[22] & 0xff)<<16 | (k[23] & 0xff)<<24,\n j13 = k[24] & 0xff | (k[25] & 0xff)<<8 | (k[26] & 0xff)<<16 | (k[27] & 0xff)<<24,\n j14 = k[28] & 0xff | (k[29] & 0xff)<<8 | (k[30] & 0xff)<<16 | (k[31] & 0xff)<<24,\n j15 = c[12] & 0xff | (c[13] & 0xff)<<8 | (c[14] & 0xff)<<16 | (c[15] & 0xff)<<24;\n\n var x0 = j0, x1 = j1, x2 = j2, x3 = j3, x4 = j4, x5 = j5, x6 = j6, x7 = j7,\n x8 = j8, x9 = j9, x10 = j10, x11 = j11, x12 = j12, x13 = j13, x14 = j14,\n x15 = j15, u;\n\n for (var i = 0; i < 20; i += 2) {\n u = x0 + x12 | 0;\n x4 ^= u<<7 | u>>>(32-7);\n u = x4 + x0 | 0;\n x8 ^= u<<9 | u>>>(32-9);\n u = x8 + x4 | 0;\n x12 ^= u<<13 | u>>>(32-13);\n u = x12 + x8 | 0;\n x0 ^= u<<18 | u>>>(32-18);\n\n u = x5 + x1 | 0;\n x9 ^= u<<7 | u>>>(32-7);\n u = x9 + x5 | 0;\n x13 ^= u<<9 | u>>>(32-9);\n u = x13 + x9 | 0;\n x1 ^= u<<13 | u>>>(32-13);\n u = x1 + x13 | 0;\n x5 ^= u<<18 | u>>>(32-18);\n\n u = x10 + x6 | 0;\n x14 ^= u<<7 | u>>>(32-7);\n u = x14 + x10 | 0;\n x2 ^= u<<9 | u>>>(32-9);\n u = x2 + x14 | 0;\n x6 ^= u<<13 | u>>>(32-13);\n u = x6 + x2 | 0;\n x10 ^= u<<18 | u>>>(32-18);\n\n u = x15 + x11 | 0;\n x3 ^= u<<7 | u>>>(32-7);\n u = x3 + x15 | 0;\n x7 ^= u<<9 | u>>>(32-9);\n u = x7 + x3 | 0;\n x11 ^= u<<13 | u>>>(32-13);\n u = x11 + x7 | 0;\n x15 ^= u<<18 | u>>>(32-18);\n\n u = x0 + x3 | 0;\n x1 ^= u<<7 | u>>>(32-7);\n u = x1 + x0 | 0;\n x2 ^= u<<9 | u>>>(32-9);\n u = x2 + x1 | 0;\n x3 ^= u<<13 | u>>>(32-13);\n u = x3 + x2 | 0;\n x0 ^= u<<18 | u>>>(32-18);\n\n u = x5 + x4 | 0;\n x6 ^= u<<7 | u>>>(32-7);\n u = x6 + x5 | 0;\n x7 ^= u<<9 | u>>>(32-9);\n u = x7 + x6 | 0;\n x4 ^= u<<13 | u>>>(32-13);\n u = x4 + x7 | 0;\n x5 ^= u<<18 | u>>>(32-18);\n\n u = x10 + x9 | 0;\n x11 ^= u<<7 | u>>>(32-7);\n u = x11 + x10 | 0;\n x8 ^= u<<9 | u>>>(32-9);\n u = x8 + x11 | 0;\n x9 ^= u<<13 | u>>>(32-13);\n u = x9 + x8 | 0;\n x10 ^= u<<18 | u>>>(32-18);\n\n u = x15 + x14 | 0;\n x12 ^= u<<7 | u>>>(32-7);\n u = x12 + x15 | 0;\n x13 ^= u<<9 | u>>>(32-9);\n u = x13 + x12 | 0;\n x14 ^= u<<13 | u>>>(32-13);\n u = x14 + x13 | 0;\n x15 ^= u<<18 | u>>>(32-18);\n }\n x0 = x0 + j0 | 0;\n x1 = x1 + j1 | 0;\n x2 = x2 + j2 | 0;\n x3 = x3 + j3 | 0;\n x4 = x4 + j4 | 0;\n x5 = x5 + j5 | 0;\n x6 = x6 + j6 | 0;\n x7 = x7 + j7 | 0;\n x8 = x8 + j8 | 0;\n x9 = x9 + j9 | 0;\n x10 = x10 + j10 | 0;\n x11 = x11 + j11 | 0;\n x12 = x12 + j12 | 0;\n x13 = x13 + j13 | 0;\n x14 = x14 + j14 | 0;\n x15 = x15 + j15 | 0;\n\n o[ 0] = x0 >>> 0 & 0xff;\n o[ 1] = x0 >>> 8 & 0xff;\n o[ 2] = x0 >>> 16 & 0xff;\n o[ 3] = x0 >>> 24 & 0xff;\n\n o[ 4] = x1 >>> 0 & 0xff;\n o[ 5] = x1 >>> 8 & 0xff;\n o[ 6] = x1 >>> 16 & 0xff;\n o[ 7] = x1 >>> 24 & 0xff;\n\n o[ 8] = x2 >>> 0 & 0xff;\n o[ 9] = x2 >>> 8 & 0xff;\n o[10] = x2 >>> 16 & 0xff;\n o[11] = x2 >>> 24 & 0xff;\n\n o[12] = x3 >>> 0 & 0xff;\n o[13] = x3 >>> 8 & 0xff;\n o[14] = x3 >>> 16 & 0xff;\n o[15] = x3 >>> 24 & 0xff;\n\n o[16] = x4 >>> 0 & 0xff;\n o[17] = x4 >>> 8 & 0xff;\n o[18] = x4 >>> 16 & 0xff;\n o[19] = x4 >>> 24 & 0xff;\n\n o[20] = x5 >>> 0 & 0xff;\n o[21] = x5 >>> 8 & 0xff;\n o[22] = x5 >>> 16 & 0xff;\n o[23] = x5 >>> 24 & 0xff;\n\n o[24] = x6 >>> 0 & 0xff;\n o[25] = x6 >>> 8 & 0xff;\n o[26] = x6 >>> 16 & 0xff;\n o[27] = x6 >>> 24 & 0xff;\n\n o[28] = x7 >>> 0 & 0xff;\n o[29] = x7 >>> 8 & 0xff;\n o[30] = x7 >>> 16 & 0xff;\n o[31] = x7 >>> 24 & 0xff;\n\n o[32] = x8 >>> 0 & 0xff;\n o[33] = x8 >>> 8 & 0xff;\n o[34] = x8 >>> 16 & 0xff;\n o[35] = x8 >>> 24 & 0xff;\n\n o[36] = x9 >>> 0 & 0xff;\n o[37] = x9 >>> 8 & 0xff;\n o[38] = x9 >>> 16 & 0xff;\n o[39] = x9 >>> 24 & 0xff;\n\n o[40] = x10 >>> 0 & 0xff;\n o[41] = x10 >>> 8 & 0xff;\n o[42] = x10 >>> 16 & 0xff;\n o[43] = x10 >>> 24 & 0xff;\n\n o[44] = x11 >>> 0 & 0xff;\n o[45] = x11 >>> 8 & 0xff;\n o[46] = x11 >>> 16 & 0xff;\n o[47] = x11 >>> 24 & 0xff;\n\n o[48] = x12 >>> 0 & 0xff;\n o[49] = x12 >>> 8 & 0xff;\n o[50] = x12 >>> 16 & 0xff;\n o[51] = x12 >>> 24 & 0xff;\n\n o[52] = x13 >>> 0 & 0xff;\n o[53] = x13 >>> 8 & 0xff;\n o[54] = x13 >>> 16 & 0xff;\n o[55] = x13 >>> 24 & 0xff;\n\n o[56] = x14 >>> 0 & 0xff;\n o[57] = x14 >>> 8 & 0xff;\n o[58] = x14 >>> 16 & 0xff;\n o[59] = x14 >>> 24 & 0xff;\n\n o[60] = x15 >>> 0 & 0xff;\n o[61] = x15 >>> 8 & 0xff;\n o[62] = x15 >>> 16 & 0xff;\n o[63] = x15 >>> 24 & 0xff;\n}\n\nfunction core_hsalsa20(o,p,k,c) {\n var j0 = c[ 0] & 0xff | (c[ 1] & 0xff)<<8 | (c[ 2] & 0xff)<<16 | (c[ 3] & 0xff)<<24,\n j1 = k[ 0] & 0xff | (k[ 1] & 0xff)<<8 | (k[ 2] & 0xff)<<16 | (k[ 3] & 0xff)<<24,\n j2 = k[ 4] & 0xff | (k[ 5] & 0xff)<<8 | (k[ 6] & 0xff)<<16 | (k[ 7] & 0xff)<<24,\n j3 = k[ 8] & 0xff | (k[ 9] & 0xff)<<8 | (k[10] & 0xff)<<16 | (k[11] & 0xff)<<24,\n j4 = k[12] & 0xff | (k[13] & 0xff)<<8 | (k[14] & 0xff)<<16 | (k[15] & 0xff)<<24,\n j5 = c[ 4] & 0xff | (c[ 5] & 0xff)<<8 | (c[ 6] & 0xff)<<16 | (c[ 7] & 0xff)<<24,\n j6 = p[ 0] & 0xff | (p[ 1] & 0xff)<<8 | (p[ 2] & 0xff)<<16 | (p[ 3] & 0xff)<<24,\n j7 = p[ 4] & 0xff | (p[ 5] & 0xff)<<8 | (p[ 6] & 0xff)<<16 | (p[ 7] & 0xff)<<24,\n j8 = p[ 8] & 0xff | (p[ 9] & 0xff)<<8 | (p[10] & 0xff)<<16 | (p[11] & 0xff)<<24,\n j9 = p[12] & 0xff | (p[13] & 0xff)<<8 | (p[14] & 0xff)<<16 | (p[15] & 0xff)<<24,\n j10 = c[ 8] & 0xff | (c[ 9] & 0xff)<<8 | (c[10] & 0xff)<<16 | (c[11] & 0xff)<<24,\n j11 = k[16] & 0xff | (k[17] & 0xff)<<8 | (k[18] & 0xff)<<16 | (k[19] & 0xff)<<24,\n j12 = k[20] & 0xff | (k[21] & 0xff)<<8 | (k[22] & 0xff)<<16 | (k[23] & 0xff)<<24,\n j13 = k[24] & 0xff | (k[25] & 0xff)<<8 | (k[26] & 0xff)<<16 | (k[27] & 0xff)<<24,\n j14 = k[28] & 0xff | (k[29] & 0xff)<<8 | (k[30] & 0xff)<<16 | (k[31] & 0xff)<<24,\n j15 = c[12] & 0xff | (c[13] & 0xff)<<8 | (c[14] & 0xff)<<16 | (c[15] & 0xff)<<24;\n\n var x0 = j0, x1 = j1, x2 = j2, x3 = j3, x4 = j4, x5 = j5, x6 = j6, x7 = j7,\n x8 = j8, x9 = j9, x10 = j10, x11 = j11, x12 = j12, x13 = j13, x14 = j14,\n x15 = j15, u;\n\n for (var i = 0; i < 20; i += 2) {\n u = x0 + x12 | 0;\n x4 ^= u<<7 | u>>>(32-7);\n u = x4 + x0 | 0;\n x8 ^= u<<9 | u>>>(32-9);\n u = x8 + x4 | 0;\n x12 ^= u<<13 | u>>>(32-13);\n u = x12 + x8 | 0;\n x0 ^= u<<18 | u>>>(32-18);\n\n u = x5 + x1 | 0;\n x9 ^= u<<7 | u>>>(32-7);\n u = x9 + x5 | 0;\n x13 ^= u<<9 | u>>>(32-9);\n u = x13 + x9 | 0;\n x1 ^= u<<13 | u>>>(32-13);\n u = x1 + x13 | 0;\n x5 ^= u<<18 | u>>>(32-18);\n\n u = x10 + x6 | 0;\n x14 ^= u<<7 | u>>>(32-7);\n u = x14 + x10 | 0;\n x2 ^= u<<9 | u>>>(32-9);\n u = x2 + x14 | 0;\n x6 ^= u<<13 | u>>>(32-13);\n u = x6 + x2 | 0;\n x10 ^= u<<18 | u>>>(32-18);\n\n u = x15 + x11 | 0;\n x3 ^= u<<7 | u>>>(32-7);\n u = x3 + x15 | 0;\n x7 ^= u<<9 | u>>>(32-9);\n u = x7 + x3 | 0;\n x11 ^= u<<13 | u>>>(32-13);\n u = x11 + x7 | 0;\n x15 ^= u<<18 | u>>>(32-18);\n\n u = x0 + x3 | 0;\n x1 ^= u<<7 | u>>>(32-7);\n u = x1 + x0 | 0;\n x2 ^= u<<9 | u>>>(32-9);\n u = x2 + x1 | 0;\n x3 ^= u<<13 | u>>>(32-13);\n u = x3 + x2 | 0;\n x0 ^= u<<18 | u>>>(32-18);\n\n u = x5 + x4 | 0;\n x6 ^= u<<7 | u>>>(32-7);\n u = x6 + x5 | 0;\n x7 ^= u<<9 | u>>>(32-9);\n u = x7 + x6 | 0;\n x4 ^= u<<13 | u>>>(32-13);\n u = x4 + x7 | 0;\n x5 ^= u<<18 | u>>>(32-18);\n\n u = x10 + x9 | 0;\n x11 ^= u<<7 | u>>>(32-7);\n u = x11 + x10 | 0;\n x8 ^= u<<9 | u>>>(32-9);\n u = x8 + x11 | 0;\n x9 ^= u<<13 | u>>>(32-13);\n u = x9 + x8 | 0;\n x10 ^= u<<18 | u>>>(32-18);\n\n u = x15 + x14 | 0;\n x12 ^= u<<7 | u>>>(32-7);\n u = x12 + x15 | 0;\n x13 ^= u<<9 | u>>>(32-9);\n u = x13 + x12 | 0;\n x14 ^= u<<13 | u>>>(32-13);\n u = x14 + x13 | 0;\n x15 ^= u<<18 | u>>>(32-18);\n }\n\n o[ 0] = x0 >>> 0 & 0xff;\n o[ 1] = x0 >>> 8 & 0xff;\n o[ 2] = x0 >>> 16 & 0xff;\n o[ 3] = x0 >>> 24 & 0xff;\n\n o[ 4] = x5 >>> 0 & 0xff;\n o[ 5] = x5 >>> 8 & 0xff;\n o[ 6] = x5 >>> 16 & 0xff;\n o[ 7] = x5 >>> 24 & 0xff;\n\n o[ 8] = x10 >>> 0 & 0xff;\n o[ 9] = x10 >>> 8 & 0xff;\n o[10] = x10 >>> 16 & 0xff;\n o[11] = x10 >>> 24 & 0xff;\n\n o[12] = x15 >>> 0 & 0xff;\n o[13] = x15 >>> 8 & 0xff;\n o[14] = x15 >>> 16 & 0xff;\n o[15] = x15 >>> 24 & 0xff;\n\n o[16] = x6 >>> 0 & 0xff;\n o[17] = x6 >>> 8 & 0xff;\n o[18] = x6 >>> 16 & 0xff;\n o[19] = x6 >>> 24 & 0xff;\n\n o[20] = x7 >>> 0 & 0xff;\n o[21] = x7 >>> 8 & 0xff;\n o[22] = x7 >>> 16 & 0xff;\n o[23] = x7 >>> 24 & 0xff;\n\n o[24] = x8 >>> 0 & 0xff;\n o[25] = x8 >>> 8 & 0xff;\n o[26] = x8 >>> 16 & 0xff;\n o[27] = x8 >>> 24 & 0xff;\n\n o[28] = x9 >>> 0 & 0xff;\n o[29] = x9 >>> 8 & 0xff;\n o[30] = x9 >>> 16 & 0xff;\n o[31] = x9 >>> 24 & 0xff;\n}\n\nfunction crypto_core_salsa20(out,inp,k,c) {\n core_salsa20(out,inp,k,c);\n}\n\nfunction crypto_core_hsalsa20(out,inp,k,c) {\n core_hsalsa20(out,inp,k,c);\n}\n\nvar sigma = new Uint8Array([101, 120, 112, 97, 110, 100, 32, 51, 50, 45, 98, 121, 116, 101, 32, 107]);\n // \"expand 32-byte k\"\n\nfunction crypto_stream_salsa20_xor(c,cpos,m,mpos,b,n,k) {\n var z = new Uint8Array(16), x = new Uint8Array(64);\n var u, i;\n for (i = 0; i < 16; i++) z[i] = 0;\n for (i = 0; i < 8; i++) z[i] = n[i];\n while (b >= 64) {\n crypto_core_salsa20(x,z,k,sigma);\n for (i = 0; i < 64; i++) c[cpos+i] = m[mpos+i] ^ x[i];\n u = 1;\n for (i = 8; i < 16; i++) {\n u = u + (z[i] & 0xff) | 0;\n z[i] = u & 0xff;\n u >>>= 8;\n }\n b -= 64;\n cpos += 64;\n mpos += 64;\n }\n if (b > 0) {\n crypto_core_salsa20(x,z,k,sigma);\n for (i = 0; i < b; i++) c[cpos+i] = m[mpos+i] ^ x[i];\n }\n return 0;\n}\n\nfunction crypto_stream_salsa20(c,cpos,b,n,k) {\n var z = new Uint8Array(16), x = new Uint8Array(64);\n var u, i;\n for (i = 0; i < 16; i++) z[i] = 0;\n for (i = 0; i < 8; i++) z[i] = n[i];\n while (b >= 64) {\n crypto_core_salsa20(x,z,k,sigma);\n for (i = 0; i < 64; i++) c[cpos+i] = x[i];\n u = 1;\n for (i = 8; i < 16; i++) {\n u = u + (z[i] & 0xff) | 0;\n z[i] = u & 0xff;\n u >>>= 8;\n }\n b -= 64;\n cpos += 64;\n }\n if (b > 0) {\n crypto_core_salsa20(x,z,k,sigma);\n for (i = 0; i < b; i++) c[cpos+i] = x[i];\n }\n return 0;\n}\n\nfunction crypto_stream(c,cpos,d,n,k) {\n var s = new Uint8Array(32);\n crypto_core_hsalsa20(s,n,k,sigma);\n var sn = new Uint8Array(8);\n for (var i = 0; i < 8; i++) sn[i] = n[i+16];\n return crypto_stream_salsa20(c,cpos,d,sn,s);\n}\n\nfunction crypto_stream_xor(c,cpos,m,mpos,d,n,k) {\n var s = new Uint8Array(32);\n crypto_core_hsalsa20(s,n,k,sigma);\n var sn = new Uint8Array(8);\n for (var i = 0; i < 8; i++) sn[i] = n[i+16];\n return crypto_stream_salsa20_xor(c,cpos,m,mpos,d,sn,s);\n}\n\n/*\n* Port of Andrew Moon's Poly1305-donna-16. Public domain.\n* https://github.com/floodyberry/poly1305-donna\n*/\n\nvar poly1305 = function(key) {\n this.buffer = new Uint8Array(16);\n this.r = new Uint16Array(10);\n this.h = new Uint16Array(10);\n this.pad = new Uint16Array(8);\n this.leftover = 0;\n this.fin = 0;\n\n var t0, t1, t2, t3, t4, t5, t6, t7;\n\n t0 = key[ 0] & 0xff | (key[ 1] & 0xff) << 8; this.r[0] = ( t0 ) & 0x1fff;\n t1 = key[ 2] & 0xff | (key[ 3] & 0xff) << 8; this.r[1] = ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n t2 = key[ 4] & 0xff | (key[ 5] & 0xff) << 8; this.r[2] = ((t1 >>> 10) | (t2 << 6)) & 0x1f03;\n t3 = key[ 6] & 0xff | (key[ 7] & 0xff) << 8; this.r[3] = ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n t4 = key[ 8] & 0xff | (key[ 9] & 0xff) << 8; this.r[4] = ((t3 >>> 4) | (t4 << 12)) & 0x00ff;\n this.r[5] = ((t4 >>> 1)) & 0x1ffe;\n t5 = key[10] & 0xff | (key[11] & 0xff) << 8; this.r[6] = ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n t6 = key[12] & 0xff | (key[13] & 0xff) << 8; this.r[7] = ((t5 >>> 11) | (t6 << 5)) & 0x1f81;\n t7 = key[14] & 0xff | (key[15] & 0xff) << 8; this.r[8] = ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n this.r[9] = ((t7 >>> 5)) & 0x007f;\n\n this.pad[0] = key[16] & 0xff | (key[17] & 0xff) << 8;\n this.pad[1] = key[18] & 0xff | (key[19] & 0xff) << 8;\n this.pad[2] = key[20] & 0xff | (key[21] & 0xff) << 8;\n this.pad[3] = key[22] & 0xff | (key[23] & 0xff) << 8;\n this.pad[4] = key[24] & 0xff | (key[25] & 0xff) << 8;\n this.pad[5] = key[26] & 0xff | (key[27] & 0xff) << 8;\n this.pad[6] = key[28] & 0xff | (key[29] & 0xff) << 8;\n this.pad[7] = key[30] & 0xff | (key[31] & 0xff) << 8;\n};\n\npoly1305.prototype.blocks = function(m, mpos, bytes) {\n var hibit = this.fin ? 0 : (1 << 11);\n var t0, t1, t2, t3, t4, t5, t6, t7, c;\n var d0, d1, d2, d3, d4, d5, d6, d7, d8, d9;\n\n var h0 = this.h[0],\n h1 = this.h[1],\n h2 = this.h[2],\n h3 = this.h[3],\n h4 = this.h[4],\n h5 = this.h[5],\n h6 = this.h[6],\n h7 = this.h[7],\n h8 = this.h[8],\n h9 = this.h[9];\n\n var r0 = this.r[0],\n r1 = this.r[1],\n r2 = this.r[2],\n r3 = this.r[3],\n r4 = this.r[4],\n r5 = this.r[5],\n r6 = this.r[6],\n r7 = this.r[7],\n r8 = this.r[8],\n r9 = this.r[9];\n\n while (bytes >= 16) {\n t0 = m[mpos+ 0] & 0xff | (m[mpos+ 1] & 0xff) << 8; h0 += ( t0 ) & 0x1fff;\n t1 = m[mpos+ 2] & 0xff | (m[mpos+ 3] & 0xff) << 8; h1 += ((t0 >>> 13) | (t1 << 3)) & 0x1fff;\n t2 = m[mpos+ 4] & 0xff | (m[mpos+ 5] & 0xff) << 8; h2 += ((t1 >>> 10) | (t2 << 6)) & 0x1fff;\n t3 = m[mpos+ 6] & 0xff | (m[mpos+ 7] & 0xff) << 8; h3 += ((t2 >>> 7) | (t3 << 9)) & 0x1fff;\n t4 = m[mpos+ 8] & 0xff | (m[mpos+ 9] & 0xff) << 8; h4 += ((t3 >>> 4) | (t4 << 12)) & 0x1fff;\n h5 += ((t4 >>> 1)) & 0x1fff;\n t5 = m[mpos+10] & 0xff | (m[mpos+11] & 0xff) << 8; h6 += ((t4 >>> 14) | (t5 << 2)) & 0x1fff;\n t6 = m[mpos+12] & 0xff | (m[mpos+13] & 0xff) << 8; h7 += ((t5 >>> 11) | (t6 << 5)) & 0x1fff;\n t7 = m[mpos+14] & 0xff | (m[mpos+15] & 0xff) << 8; h8 += ((t6 >>> 8) | (t7 << 8)) & 0x1fff;\n h9 += ((t7 >>> 5)) | hibit;\n\n c = 0;\n\n d0 = c;\n d0 += h0 * r0;\n d0 += h1 * (5 * r9);\n d0 += h2 * (5 * r8);\n d0 += h3 * (5 * r7);\n d0 += h4 * (5 * r6);\n c = (d0 >>> 13); d0 &= 0x1fff;\n d0 += h5 * (5 * r5);\n d0 += h6 * (5 * r4);\n d0 += h7 * (5 * r3);\n d0 += h8 * (5 * r2);\n d0 += h9 * (5 * r1);\n c += (d0 >>> 13); d0 &= 0x1fff;\n\n d1 = c;\n d1 += h0 * r1;\n d1 += h1 * r0;\n d1 += h2 * (5 * r9);\n d1 += h3 * (5 * r8);\n d1 += h4 * (5 * r7);\n c = (d1 >>> 13); d1 &= 0x1fff;\n d1 += h5 * (5 * r6);\n d1 += h6 * (5 * r5);\n d1 += h7 * (5 * r4);\n d1 += h8 * (5 * r3);\n d1 += h9 * (5 * r2);\n c += (d1 >>> 13); d1 &= 0x1fff;\n\n d2 = c;\n d2 += h0 * r2;\n d2 += h1 * r1;\n d2 += h2 * r0;\n d2 += h3 * (5 * r9);\n d2 += h4 * (5 * r8);\n c = (d2 >>> 13); d2 &= 0x1fff;\n d2 += h5 * (5 * r7);\n d2 += h6 * (5 * r6);\n d2 += h7 * (5 * r5);\n d2 += h8 * (5 * r4);\n d2 += h9 * (5 * r3);\n c += (d2 >>> 13); d2 &= 0x1fff;\n\n d3 = c;\n d3 += h0 * r3;\n d3 += h1 * r2;\n d3 += h2 * r1;\n d3 += h3 * r0;\n d3 += h4 * (5 * r9);\n c = (d3 >>> 13); d3 &= 0x1fff;\n d3 += h5 * (5 * r8);\n d3 += h6 * (5 * r7);\n d3 += h7 * (5 * r6);\n d3 += h8 * (5 * r5);\n d3 += h9 * (5 * r4);\n c += (d3 >>> 13); d3 &= 0x1fff;\n\n d4 = c;\n d4 += h0 * r4;\n d4 += h1 * r3;\n d4 += h2 * r2;\n d4 += h3 * r1;\n d4 += h4 * r0;\n c = (d4 >>> 13); d4 &= 0x1fff;\n d4 += h5 * (5 * r9);\n d4 += h6 * (5 * r8);\n d4 += h7 * (5 * r7);\n d4 += h8 * (5 * r6);\n d4 += h9 * (5 * r5);\n c += (d4 >>> 13); d4 &= 0x1fff;\n\n d5 = c;\n d5 += h0 * r5;\n d5 += h1 * r4;\n d5 += h2 * r3;\n d5 += h3 * r2;\n d5 += h4 * r1;\n c = (d5 >>> 13); d5 &= 0x1fff;\n d5 += h5 * r0;\n d5 += h6 * (5 * r9);\n d5 += h7 * (5 * r8);\n d5 += h8 * (5 * r7);\n d5 += h9 * (5 * r6);\n c += (d5 >>> 13); d5 &= 0x1fff;\n\n d6 = c;\n d6 += h0 * r6;\n d6 += h1 * r5;\n d6 += h2 * r4;\n d6 += h3 * r3;\n d6 += h4 * r2;\n c = (d6 >>> 13); d6 &= 0x1fff;\n d6 += h5 * r1;\n d6 += h6 * r0;\n d6 += h7 * (5 * r9);\n d6 += h8 * (5 * r8);\n d6 += h9 * (5 * r7);\n c += (d6 >>> 13); d6 &= 0x1fff;\n\n d7 = c;\n d7 += h0 * r7;\n d7 += h1 * r6;\n d7 += h2 * r5;\n d7 += h3 * r4;\n d7 += h4 * r3;\n c = (d7 >>> 13); d7 &= 0x1fff;\n d7 += h5 * r2;\n d7 += h6 * r1;\n d7 += h7 * r0;\n d7 += h8 * (5 * r9);\n d7 += h9 * (5 * r8);\n c += (d7 >>> 13); d7 &= 0x1fff;\n\n d8 = c;\n d8 += h0 * r8;\n d8 += h1 * r7;\n d8 += h2 * r6;\n d8 += h3 * r5;\n d8 += h4 * r4;\n c = (d8 >>> 13); d8 &= 0x1fff;\n d8 += h5 * r3;\n d8 += h6 * r2;\n d8 += h7 * r1;\n d8 += h8 * r0;\n d8 += h9 * (5 * r9);\n c += (d8 >>> 13); d8 &= 0x1fff;\n\n d9 = c;\n d9 += h0 * r9;\n d9 += h1 * r8;\n d9 += h2 * r7;\n d9 += h3 * r6;\n d9 += h4 * r5;\n c = (d9 >>> 13); d9 &= 0x1fff;\n d9 += h5 * r4;\n d9 += h6 * r3;\n d9 += h7 * r2;\n d9 += h8 * r1;\n d9 += h9 * r0;\n c += (d9 >>> 13); d9 &= 0x1fff;\n\n c = (((c << 2) + c)) | 0;\n c = (c + d0) | 0;\n d0 = c & 0x1fff;\n c = (c >>> 13);\n d1 += c;\n\n h0 = d0;\n h1 = d1;\n h2 = d2;\n h3 = d3;\n h4 = d4;\n h5 = d5;\n h6 = d6;\n h7 = d7;\n h8 = d8;\n h9 = d9;\n\n mpos += 16;\n bytes -= 16;\n }\n this.h[0] = h0;\n this.h[1] = h1;\n this.h[2] = h2;\n this.h[3] = h3;\n this.h[4] = h4;\n this.h[5] = h5;\n this.h[6] = h6;\n this.h[7] = h7;\n this.h[8] = h8;\n this.h[9] = h9;\n};\n\npoly1305.prototype.finish = function(mac, macpos) {\n var g = new Uint16Array(10);\n var c, mask, f, i;\n\n if (this.leftover) {\n i = this.leftover;\n this.buffer[i++] = 1;\n for (; i < 16; i++) this.buffer[i] = 0;\n this.fin = 1;\n this.blocks(this.buffer, 0, 16);\n }\n\n c = this.h[1] >>> 13;\n this.h[1] &= 0x1fff;\n for (i = 2; i < 10; i++) {\n this.h[i] += c;\n c = this.h[i] >>> 13;\n this.h[i] &= 0x1fff;\n }\n this.h[0] += (c * 5);\n c = this.h[0] >>> 13;\n this.h[0] &= 0x1fff;\n this.h[1] += c;\n c = this.h[1] >>> 13;\n this.h[1] &= 0x1fff;\n this.h[2] += c;\n\n g[0] = this.h[0] + 5;\n c = g[0] >>> 13;\n g[0] &= 0x1fff;\n for (i = 1; i < 10; i++) {\n g[i] = this.h[i] + c;\n c = g[i] >>> 13;\n g[i] &= 0x1fff;\n }\n g[9] -= (1 << 13);\n\n mask = (c ^ 1) - 1;\n for (i = 0; i < 10; i++) g[i] &= mask;\n mask = ~mask;\n for (i = 0; i < 10; i++) this.h[i] = (this.h[i] & mask) | g[i];\n\n this.h[0] = ((this.h[0] ) | (this.h[1] << 13) ) & 0xffff;\n this.h[1] = ((this.h[1] >>> 3) | (this.h[2] << 10) ) & 0xffff;\n this.h[2] = ((this.h[2] >>> 6) | (this.h[3] << 7) ) & 0xffff;\n this.h[3] = ((this.h[3] >>> 9) | (this.h[4] << 4) ) & 0xffff;\n this.h[4] = ((this.h[4] >>> 12) | (this.h[5] << 1) | (this.h[6] << 14)) & 0xffff;\n this.h[5] = ((this.h[6] >>> 2) | (this.h[7] << 11) ) & 0xffff;\n this.h[6] = ((this.h[7] >>> 5) | (this.h[8] << 8) ) & 0xffff;\n this.h[7] = ((this.h[8] >>> 8) | (this.h[9] << 5) ) & 0xffff;\n\n f = this.h[0] + this.pad[0];\n this.h[0] = f & 0xffff;\n for (i = 1; i < 8; i++) {\n f = (((this.h[i] + this.pad[i]) | 0) + (f >>> 16)) | 0;\n this.h[i] = f & 0xffff;\n }\n\n mac[macpos+ 0] = (this.h[0] >>> 0) & 0xff;\n mac[macpos+ 1] = (this.h[0] >>> 8) & 0xff;\n mac[macpos+ 2] = (this.h[1] >>> 0) & 0xff;\n mac[macpos+ 3] = (this.h[1] >>> 8) & 0xff;\n mac[macpos+ 4] = (this.h[2] >>> 0) & 0xff;\n mac[macpos+ 5] = (this.h[2] >>> 8) & 0xff;\n mac[macpos+ 6] = (this.h[3] >>> 0) & 0xff;\n mac[macpos+ 7] = (this.h[3] >>> 8) & 0xff;\n mac[macpos+ 8] = (this.h[4] >>> 0) & 0xff;\n mac[macpos+ 9] = (this.h[4] >>> 8) & 0xff;\n mac[macpos+10] = (this.h[5] >>> 0) & 0xff;\n mac[macpos+11] = (this.h[5] >>> 8) & 0xff;\n mac[macpos+12] = (this.h[6] >>> 0) & 0xff;\n mac[macpos+13] = (this.h[6] >>> 8) & 0xff;\n mac[macpos+14] = (this.h[7] >>> 0) & 0xff;\n mac[macpos+15] = (this.h[7] >>> 8) & 0xff;\n};\n\npoly1305.prototype.update = function(m, mpos, bytes) {\n var i, want;\n\n if (this.leftover) {\n want = (16 - this.leftover);\n if (want > bytes)\n want = bytes;\n for (i = 0; i < want; i++)\n this.buffer[this.leftover + i] = m[mpos+i];\n bytes -= want;\n mpos += want;\n this.leftover += want;\n if (this.leftover < 16)\n return;\n this.blocks(this.buffer, 0, 16);\n this.leftover = 0;\n }\n\n if (bytes >= 16) {\n want = bytes - (bytes % 16);\n this.blocks(m, mpos, want);\n mpos += want;\n bytes -= want;\n }\n\n if (bytes) {\n for (i = 0; i < bytes; i++)\n this.buffer[this.leftover + i] = m[mpos+i];\n this.leftover += bytes;\n }\n};\n\nfunction crypto_onetimeauth(out, outpos, m, mpos, n, k) {\n var s = new poly1305(k);\n s.update(m, mpos, n);\n s.finish(out, outpos);\n return 0;\n}\n\nfunction crypto_onetimeauth_verify(h, hpos, m, mpos, n, k) {\n var x = new Uint8Array(16);\n crypto_onetimeauth(x,0,m,mpos,n,k);\n return crypto_verify_16(h,hpos,x,0);\n}\n\nfunction crypto_secretbox(c,m,d,n,k) {\n var i;\n if (d < 32) return -1;\n crypto_stream_xor(c,0,m,0,d,n,k);\n crypto_onetimeauth(c, 16, c, 32, d - 32, c);\n for (i = 0; i < 16; i++) c[i] = 0;\n return 0;\n}\n\nfunction crypto_secretbox_open(m,c,d,n,k) {\n var i;\n var x = new Uint8Array(32);\n if (d < 32) return -1;\n crypto_stream(x,0,32,n,k);\n if (crypto_onetimeauth_verify(c, 16,c, 32,d - 32,x) !== 0) return -1;\n crypto_stream_xor(m,0,c,0,d,n,k);\n for (i = 0; i < 32; i++) m[i] = 0;\n return 0;\n}\n\nfunction set25519(r, a) {\n var i;\n for (i = 0; i < 16; i++) r[i] = a[i]|0;\n}\n\nfunction car25519(o) {\n var i, v, c = 1;\n for (i = 0; i < 16; i++) {\n v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c-1 + 37 * (c-1);\n}\n\nfunction sel25519(p, q, b) {\n var t, c = ~(b-1);\n for (var i = 0; i < 16; i++) {\n t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction pack25519(o, n) {\n var i, j, b;\n var m = gf(), t = gf();\n for (i = 0; i < 16; i++) t[i] = n[i];\n car25519(t);\n car25519(t);\n car25519(t);\n for (j = 0; j < 2; j++) {\n m[0] = t[0] - 0xffed;\n for (i = 1; i < 15; i++) {\n m[i] = t[i] - 0xffff - ((m[i-1]>>16) & 1);\n m[i-1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14]>>16) & 1);\n b = (m[15]>>16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1-b);\n }\n for (i = 0; i < 16; i++) {\n o[2*i] = t[i] & 0xff;\n o[2*i+1] = t[i]>>8;\n }\n}\n\nfunction neq25519(a, b) {\n var c = new Uint8Array(32), d = new Uint8Array(32);\n pack25519(c, a);\n pack25519(d, b);\n return crypto_verify_32(c, 0, d, 0);\n}\n\nfunction par25519(a) {\n var d = new Uint8Array(32);\n pack25519(d, a);\n return d[0] & 1;\n}\n\nfunction unpack25519(o, n) {\n var i;\n for (i = 0; i < 16; i++) o[i] = n[2*i] + (n[2*i+1] << 8);\n o[15] &= 0x7fff;\n}\n\nfunction A(o, a, b) {\n for (var i = 0; i < 16; i++) o[i] = a[i] + b[i];\n}\n\nfunction Z(o, a, b) {\n for (var i = 0; i < 16; i++) o[i] = a[i] - b[i];\n}\n\nfunction M(o, a, b) {\n var v, c,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n o[ 0] = t0;\n o[ 1] = t1;\n o[ 2] = t2;\n o[ 3] = t3;\n o[ 4] = t4;\n o[ 5] = t5;\n o[ 6] = t6;\n o[ 7] = t7;\n o[ 8] = t8;\n o[ 9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n\nfunction S(o, a) {\n M(o, a, a);\n}\n\nfunction inv25519(o, i) {\n var c = gf();\n var a;\n for (a = 0; a < 16; a++) c[a] = i[a];\n for (a = 253; a >= 0; a--) {\n S(c, c);\n if(a !== 2 && a !== 4) M(c, c, i);\n }\n for (a = 0; a < 16; a++) o[a] = c[a];\n}\n\nfunction pow2523(o, i) {\n var c = gf();\n var a;\n for (a = 0; a < 16; a++) c[a] = i[a];\n for (a = 250; a >= 0; a--) {\n S(c, c);\n if(a !== 1) M(c, c, i);\n }\n for (a = 0; a < 16; a++) o[a] = c[a];\n}\n\nfunction crypto_scalarmult(q, n, p) {\n var z = new Uint8Array(32);\n var x = new Float64Array(80), r, i;\n var a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf();\n for (i = 0; i < 31; i++) z[i] = n[i];\n z[31]=(n[31]&127)|64;\n z[0]&=248;\n unpack25519(x,p);\n for (i = 0; i < 16; i++) {\n b[i]=x[i];\n d[i]=a[i]=c[i]=0;\n }\n a[0]=d[0]=1;\n for (i=254; i>=0; --i) {\n r=(z[i>>>3]>>>(i&7))&1;\n sel25519(a,b,r);\n sel25519(c,d,r);\n A(e,a,c);\n Z(a,a,c);\n A(c,b,d);\n Z(b,b,d);\n S(d,e);\n S(f,a);\n M(a,c,a);\n M(c,b,e);\n A(e,a,c);\n Z(a,a,c);\n S(b,a);\n Z(c,d,f);\n M(a,c,_121665);\n A(a,a,d);\n M(c,c,a);\n M(a,d,f);\n M(d,b,x);\n S(b,e);\n sel25519(a,b,r);\n sel25519(c,d,r);\n }\n for (i = 0; i < 16; i++) {\n x[i+16]=a[i];\n x[i+32]=c[i];\n x[i+48]=b[i];\n x[i+64]=d[i];\n }\n var x32 = x.subarray(32);\n var x16 = x.subarray(16);\n inv25519(x32,x32);\n M(x16,x16,x32);\n pack25519(q,x16);\n return 0;\n}\n\nfunction crypto_scalarmult_base(q, n) {\n return crypto_scalarmult(q, n, _9);\n}\n\nfunction crypto_box_keypair(y, x) {\n randombytes(x, 32);\n return crypto_scalarmult_base(y, x);\n}\n\nfunction crypto_box_beforenm(k, y, x) {\n var s = new Uint8Array(32);\n crypto_scalarmult(s, x, y);\n return crypto_core_hsalsa20(k, _0, s, sigma);\n}\n\nvar crypto_box_afternm = crypto_secretbox;\nvar crypto_box_open_afternm = crypto_secretbox_open;\n\nfunction crypto_box(c, m, d, n, y, x) {\n var k = new Uint8Array(32);\n crypto_box_beforenm(k, y, x);\n return crypto_box_afternm(c, m, d, n, k);\n}\n\nfunction crypto_box_open(m, c, d, n, y, x) {\n var k = new Uint8Array(32);\n crypto_box_beforenm(k, y, x);\n return crypto_box_open_afternm(m, c, d, n, k);\n}\n\nvar K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction crypto_hashblocks_hl(hh, hl, m, n) {\n var wh = new Int32Array(16), wl = new Int32Array(16),\n bh0, bh1, bh2, bh3, bh4, bh5, bh6, bh7,\n bl0, bl1, bl2, bl3, bl4, bl5, bl6, bl7,\n th, tl, i, j, h, l, a, b, c, d;\n\n var ah0 = hh[0],\n ah1 = hh[1],\n ah2 = hh[2],\n ah3 = hh[3],\n ah4 = hh[4],\n ah5 = hh[5],\n ah6 = hh[6],\n ah7 = hh[7],\n\n al0 = hl[0],\n al1 = hl[1],\n al2 = hl[2],\n al3 = hl[3],\n al4 = hl[4],\n al5 = hl[5],\n al6 = hl[6],\n al7 = hl[7];\n\n var pos = 0;\n while (n >= 128) {\n for (i = 0; i < 16; i++) {\n j = 8 * i + pos;\n wh[i] = (m[j+0] << 24) | (m[j+1] << 16) | (m[j+2] << 8) | m[j+3];\n wl[i] = (m[j+4] << 24) | (m[j+5] << 16) | (m[j+6] << 8) | m[j+7];\n }\n for (i = 0; i < 80; i++) {\n bh0 = ah0;\n bh1 = ah1;\n bh2 = ah2;\n bh3 = ah3;\n bh4 = ah4;\n bh5 = ah5;\n bh6 = ah6;\n bh7 = ah7;\n\n bl0 = al0;\n bl1 = al1;\n bl2 = al2;\n bl3 = al3;\n bl4 = al4;\n bl5 = al5;\n bl6 = al6;\n bl7 = al7;\n\n // add\n h = ah7;\n l = al7;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n // Sigma1\n h = ((ah4 >>> 14) | (al4 << (32-14))) ^ ((ah4 >>> 18) | (al4 << (32-18))) ^ ((al4 >>> (41-32)) | (ah4 << (32-(41-32))));\n l = ((al4 >>> 14) | (ah4 << (32-14))) ^ ((al4 >>> 18) | (ah4 << (32-18))) ^ ((ah4 >>> (41-32)) | (al4 << (32-(41-32))));\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // Ch\n h = (ah4 & ah5) ^ (~ah4 & ah6);\n l = (al4 & al5) ^ (~al4 & al6);\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // K\n h = K[i*2];\n l = K[i*2+1];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // w\n h = wh[i%16];\n l = wl[i%16];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n th = c & 0xffff | d << 16;\n tl = a & 0xffff | b << 16;\n\n // add\n h = th;\n l = tl;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n // Sigma0\n h = ((ah0 >>> 28) | (al0 << (32-28))) ^ ((al0 >>> (34-32)) | (ah0 << (32-(34-32)))) ^ ((al0 >>> (39-32)) | (ah0 << (32-(39-32))));\n l = ((al0 >>> 28) | (ah0 << (32-28))) ^ ((ah0 >>> (34-32)) | (al0 << (32-(34-32)))) ^ ((ah0 >>> (39-32)) | (al0 << (32-(39-32))));\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // Maj\n h = (ah0 & ah1) ^ (ah0 & ah2) ^ (ah1 & ah2);\n l = (al0 & al1) ^ (al0 & al2) ^ (al1 & al2);\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n bh7 = (c & 0xffff) | (d << 16);\n bl7 = (a & 0xffff) | (b << 16);\n\n // add\n h = bh3;\n l = bl3;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = th;\n l = tl;\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n bh3 = (c & 0xffff) | (d << 16);\n bl3 = (a & 0xffff) | (b << 16);\n\n ah1 = bh0;\n ah2 = bh1;\n ah3 = bh2;\n ah4 = bh3;\n ah5 = bh4;\n ah6 = bh5;\n ah7 = bh6;\n ah0 = bh7;\n\n al1 = bl0;\n al2 = bl1;\n al3 = bl2;\n al4 = bl3;\n al5 = bl4;\n al6 = bl5;\n al7 = bl6;\n al0 = bl7;\n\n if (i%16 === 15) {\n for (j = 0; j < 16; j++) {\n // add\n h = wh[j];\n l = wl[j];\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = wh[(j+9)%16];\n l = wl[(j+9)%16];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // sigma0\n th = wh[(j+1)%16];\n tl = wl[(j+1)%16];\n h = ((th >>> 1) | (tl << (32-1))) ^ ((th >>> 8) | (tl << (32-8))) ^ (th >>> 7);\n l = ((tl >>> 1) | (th << (32-1))) ^ ((tl >>> 8) | (th << (32-8))) ^ ((tl >>> 7) | (th << (32-7)));\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n // sigma1\n th = wh[(j+14)%16];\n tl = wl[(j+14)%16];\n h = ((th >>> 19) | (tl << (32-19))) ^ ((tl >>> (61-32)) | (th << (32-(61-32)))) ^ (th >>> 6);\n l = ((tl >>> 19) | (th << (32-19))) ^ ((th >>> (61-32)) | (tl << (32-(61-32)))) ^ ((tl >>> 6) | (th << (32-6)));\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n wh[j] = (c & 0xffff) | (d << 16);\n wl[j] = (a & 0xffff) | (b << 16);\n }\n }\n }\n\n // add\n h = ah0;\n l = al0;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[0];\n l = hl[0];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[0] = ah0 = (c & 0xffff) | (d << 16);\n hl[0] = al0 = (a & 0xffff) | (b << 16);\n\n h = ah1;\n l = al1;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[1];\n l = hl[1];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[1] = ah1 = (c & 0xffff) | (d << 16);\n hl[1] = al1 = (a & 0xffff) | (b << 16);\n\n h = ah2;\n l = al2;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[2];\n l = hl[2];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[2] = ah2 = (c & 0xffff) | (d << 16);\n hl[2] = al2 = (a & 0xffff) | (b << 16);\n\n h = ah3;\n l = al3;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[3];\n l = hl[3];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[3] = ah3 = (c & 0xffff) | (d << 16);\n hl[3] = al3 = (a & 0xffff) | (b << 16);\n\n h = ah4;\n l = al4;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[4];\n l = hl[4];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[4] = ah4 = (c & 0xffff) | (d << 16);\n hl[4] = al4 = (a & 0xffff) | (b << 16);\n\n h = ah5;\n l = al5;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[5];\n l = hl[5];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[5] = ah5 = (c & 0xffff) | (d << 16);\n hl[5] = al5 = (a & 0xffff) | (b << 16);\n\n h = ah6;\n l = al6;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[6];\n l = hl[6];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[6] = ah6 = (c & 0xffff) | (d << 16);\n hl[6] = al6 = (a & 0xffff) | (b << 16);\n\n h = ah7;\n l = al7;\n\n a = l & 0xffff; b = l >>> 16;\n c = h & 0xffff; d = h >>> 16;\n\n h = hh[7];\n l = hl[7];\n\n a += l & 0xffff; b += l >>> 16;\n c += h & 0xffff; d += h >>> 16;\n\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n\n hh[7] = ah7 = (c & 0xffff) | (d << 16);\n hl[7] = al7 = (a & 0xffff) | (b << 16);\n\n pos += 128;\n n -= 128;\n }\n\n return n;\n}\n\nfunction crypto_hash(out, m, n) {\n var hh = new Int32Array(8),\n hl = new Int32Array(8),\n x = new Uint8Array(256),\n i, b = n;\n\n hh[0] = 0x6a09e667;\n hh[1] = 0xbb67ae85;\n hh[2] = 0x3c6ef372;\n hh[3] = 0xa54ff53a;\n hh[4] = 0x510e527f;\n hh[5] = 0x9b05688c;\n hh[6] = 0x1f83d9ab;\n hh[7] = 0x5be0cd19;\n\n hl[0] = 0xf3bcc908;\n hl[1] = 0x84caa73b;\n hl[2] = 0xfe94f82b;\n hl[3] = 0x5f1d36f1;\n hl[4] = 0xade682d1;\n hl[5] = 0x2b3e6c1f;\n hl[6] = 0xfb41bd6b;\n hl[7] = 0x137e2179;\n\n crypto_hashblocks_hl(hh, hl, m, n);\n n %= 128;\n\n for (i = 0; i < n; i++) x[i] = m[b-n+i];\n x[n] = 128;\n\n n = 256-128*(n<112?1:0);\n x[n-9] = 0;\n ts64(x, n-8, (b / 0x20000000) | 0, b << 3);\n crypto_hashblocks_hl(hh, hl, x, n);\n\n for (i = 0; i < 8; i++) ts64(out, 8*i, hh[i], hl[i]);\n\n return 0;\n}\n\nfunction add(p, q) {\n var a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf(),\n g = gf(), h = gf(), t = gf();\n\n Z(a, p[1], p[0]);\n Z(t, q[1], q[0]);\n M(a, a, t);\n A(b, p[0], p[1]);\n A(t, q[0], q[1]);\n M(b, b, t);\n M(c, p[3], q[3]);\n M(c, c, D2);\n M(d, p[2], q[2]);\n A(d, d, d);\n Z(e, b, a);\n Z(f, d, c);\n A(g, d, c);\n A(h, b, a);\n\n M(p[0], e, f);\n M(p[1], h, g);\n M(p[2], g, f);\n M(p[3], e, h);\n}\n\nfunction cswap(p, q, b) {\n var i;\n for (i = 0; i < 4; i++) {\n sel25519(p[i], q[i], b);\n }\n}\n\nfunction pack(r, p) {\n var tx = gf(), ty = gf(), zi = gf();\n inv25519(zi, p[2]);\n M(tx, p[0], zi);\n M(ty, p[1], zi);\n pack25519(r, ty);\n r[31] ^= par25519(tx) << 7;\n}\n\nfunction scalarmult(p, q, s) {\n var b, i;\n set25519(p[0], gf0);\n set25519(p[1], gf1);\n set25519(p[2], gf1);\n set25519(p[3], gf0);\n for (i = 255; i >= 0; --i) {\n b = (s[(i/8)|0] >> (i&7)) & 1;\n cswap(p, q, b);\n add(q, p);\n add(p, p);\n cswap(p, q, b);\n }\n}\n\nfunction scalarbase(p, s) {\n var q = [gf(), gf(), gf(), gf()];\n set25519(q[0], X);\n set25519(q[1], Y);\n set25519(q[2], gf1);\n M(q[3], X, Y);\n scalarmult(p, q, s);\n}\n\nfunction crypto_sign_keypair(pk, sk, seeded) {\n var d = new Uint8Array(64);\n var p = [gf(), gf(), gf(), gf()];\n var i;\n\n if (!seeded) randombytes(sk, 32);\n crypto_hash(d, sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n scalarbase(p, d);\n pack(pk, p);\n\n for (i = 0; i < 32; i++) sk[i+32] = pk[i];\n return 0;\n}\n\nvar L = new Float64Array([0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58, 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\n\nfunction modL(r, x) {\n var carry, i, j, k;\n for (i = 63; i >= 32; --i) {\n carry = 0;\n for (j = i - 32, k = i - 12; j < k; ++j) {\n x[j] += carry - 16 * x[i] * L[j - (i - 32)];\n carry = Math.floor((x[j] + 128) / 256);\n x[j] -= carry * 256;\n }\n x[j] += carry;\n x[i] = 0;\n }\n carry = 0;\n for (j = 0; j < 32; j++) {\n x[j] += carry - (x[31] >> 4) * L[j];\n carry = x[j] >> 8;\n x[j] &= 255;\n }\n for (j = 0; j < 32; j++) x[j] -= carry * L[j];\n for (i = 0; i < 32; i++) {\n x[i+1] += x[i] >> 8;\n r[i] = x[i] & 255;\n }\n}\n\nfunction reduce(r) {\n var x = new Float64Array(64), i;\n for (i = 0; i < 64; i++) x[i] = r[i];\n for (i = 0; i < 64; i++) r[i] = 0;\n modL(r, x);\n}\n\n// Note: difference from C - smlen returned, not passed as argument.\nfunction crypto_sign(sm, m, n, sk) {\n var d = new Uint8Array(64), h = new Uint8Array(64), r = new Uint8Array(64);\n var i, j, x = new Float64Array(64);\n var p = [gf(), gf(), gf(), gf()];\n\n crypto_hash(d, sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n var smlen = n + 64;\n for (i = 0; i < n; i++) sm[64 + i] = m[i];\n for (i = 0; i < 32; i++) sm[32 + i] = d[32 + i];\n\n crypto_hash(r, sm.subarray(32), n+32);\n reduce(r);\n scalarbase(p, r);\n pack(sm, p);\n\n for (i = 32; i < 64; i++) sm[i] = sk[i];\n crypto_hash(h, sm, n + 64);\n reduce(h);\n\n for (i = 0; i < 64; i++) x[i] = 0;\n for (i = 0; i < 32; i++) x[i] = r[i];\n for (i = 0; i < 32; i++) {\n for (j = 0; j < 32; j++) {\n x[i+j] += h[i] * d[j];\n }\n }\n\n modL(sm.subarray(32), x);\n return smlen;\n}\n\nfunction unpackneg(r, p) {\n var t = gf(), chk = gf(), num = gf(),\n den = gf(), den2 = gf(), den4 = gf(),\n den6 = gf();\n\n set25519(r[2], gf1);\n unpack25519(r[1], p);\n S(num, r[1]);\n M(den, num, D);\n Z(num, num, r[2]);\n A(den, r[2], den);\n\n S(den2, den);\n S(den4, den2);\n M(den6, den4, den2);\n M(t, den6, num);\n M(t, t, den);\n\n pow2523(t, t);\n M(t, t, num);\n M(t, t, den);\n M(t, t, den);\n M(r[0], t, den);\n\n S(chk, r[0]);\n M(chk, chk, den);\n if (neq25519(chk, num)) M(r[0], r[0], I);\n\n S(chk, r[0]);\n M(chk, chk, den);\n if (neq25519(chk, num)) return -1;\n\n if (par25519(r[0]) === (p[31]>>7)) Z(r[0], gf0, r[0]);\n\n M(r[3], r[0], r[1]);\n return 0;\n}\n\nfunction crypto_sign_open(m, sm, n, pk) {\n var i;\n var t = new Uint8Array(32), h = new Uint8Array(64);\n var p = [gf(), gf(), gf(), gf()],\n q = [gf(), gf(), gf(), gf()];\n\n if (n < 64) return -1;\n\n if (unpackneg(q, pk)) return -1;\n\n for (i = 0; i < n; i++) m[i] = sm[i];\n for (i = 0; i < 32; i++) m[i+32] = pk[i];\n crypto_hash(h, m, n);\n reduce(h);\n scalarmult(p, q, h);\n\n scalarbase(q, sm.subarray(32));\n add(p, q);\n pack(t, p);\n\n n -= 64;\n if (crypto_verify_32(sm, 0, t, 0)) {\n for (i = 0; i < n; i++) m[i] = 0;\n return -1;\n }\n\n for (i = 0; i < n; i++) m[i] = sm[i + 64];\n return n;\n}\n\nvar crypto_secretbox_KEYBYTES = 32,\n crypto_secretbox_NONCEBYTES = 24,\n crypto_secretbox_ZEROBYTES = 32,\n crypto_secretbox_BOXZEROBYTES = 16,\n crypto_scalarmult_BYTES = 32,\n crypto_scalarmult_SCALARBYTES = 32,\n crypto_box_PUBLICKEYBYTES = 32,\n crypto_box_SECRETKEYBYTES = 32,\n crypto_box_BEFORENMBYTES = 32,\n crypto_box_NONCEBYTES = crypto_secretbox_NONCEBYTES,\n crypto_box_ZEROBYTES = crypto_secretbox_ZEROBYTES,\n crypto_box_BOXZEROBYTES = crypto_secretbox_BOXZEROBYTES,\n crypto_sign_BYTES = 64,\n crypto_sign_PUBLICKEYBYTES = 32,\n crypto_sign_SECRETKEYBYTES = 64,\n crypto_sign_SEEDBYTES = 32,\n crypto_hash_BYTES = 64;\n\nnacl.lowlevel = {\n crypto_core_hsalsa20: crypto_core_hsalsa20,\n crypto_stream_xor: crypto_stream_xor,\n crypto_stream: crypto_stream,\n crypto_stream_salsa20_xor: crypto_stream_salsa20_xor,\n crypto_stream_salsa20: crypto_stream_salsa20,\n crypto_onetimeauth: crypto_onetimeauth,\n crypto_onetimeauth_verify: crypto_onetimeauth_verify,\n crypto_verify_16: crypto_verify_16,\n crypto_verify_32: crypto_verify_32,\n crypto_secretbox: crypto_secretbox,\n crypto_secretbox_open: crypto_secretbox_open,\n crypto_scalarmult: crypto_scalarmult,\n crypto_scalarmult_base: crypto_scalarmult_base,\n crypto_box_beforenm: crypto_box_beforenm,\n crypto_box_afternm: crypto_box_afternm,\n crypto_box: crypto_box,\n crypto_box_open: crypto_box_open,\n crypto_box_keypair: crypto_box_keypair,\n crypto_hash: crypto_hash,\n crypto_sign: crypto_sign,\n crypto_sign_keypair: crypto_sign_keypair,\n crypto_sign_open: crypto_sign_open,\n\n crypto_secretbox_KEYBYTES: crypto_secretbox_KEYBYTES,\n crypto_secretbox_NONCEBYTES: crypto_secretbox_NONCEBYTES,\n crypto_secretbox_ZEROBYTES: crypto_secretbox_ZEROBYTES,\n crypto_secretbox_BOXZEROBYTES: crypto_secretbox_BOXZEROBYTES,\n crypto_scalarmult_BYTES: crypto_scalarmult_BYTES,\n crypto_scalarmult_SCALARBYTES: crypto_scalarmult_SCALARBYTES,\n crypto_box_PUBLICKEYBYTES: crypto_box_PUBLICKEYBYTES,\n crypto_box_SECRETKEYBYTES: crypto_box_SECRETKEYBYTES,\n crypto_box_BEFORENMBYTES: crypto_box_BEFORENMBYTES,\n crypto_box_NONCEBYTES: crypto_box_NONCEBYTES,\n crypto_box_ZEROBYTES: crypto_box_ZEROBYTES,\n crypto_box_BOXZEROBYTES: crypto_box_BOXZEROBYTES,\n crypto_sign_BYTES: crypto_sign_BYTES,\n crypto_sign_PUBLICKEYBYTES: crypto_sign_PUBLICKEYBYTES,\n crypto_sign_SECRETKEYBYTES: crypto_sign_SECRETKEYBYTES,\n crypto_sign_SEEDBYTES: crypto_sign_SEEDBYTES,\n crypto_hash_BYTES: crypto_hash_BYTES,\n\n gf: gf,\n D: D,\n L: L,\n pack25519: pack25519,\n unpack25519: unpack25519,\n M: M,\n A: A,\n S: S,\n Z: Z,\n pow2523: pow2523,\n add: add,\n set25519: set25519,\n modL: modL,\n scalarmult: scalarmult,\n scalarbase: scalarbase,\n};\n\n/* High-level API */\n\nfunction checkLengths(k, n) {\n if (k.length !== crypto_secretbox_KEYBYTES) throw new Error('bad key size');\n if (n.length !== crypto_secretbox_NONCEBYTES) throw new Error('bad nonce size');\n}\n\nfunction checkBoxLengths(pk, sk) {\n if (pk.length !== crypto_box_PUBLICKEYBYTES) throw new Error('bad public key size');\n if (sk.length !== crypto_box_SECRETKEYBYTES) throw new Error('bad secret key size');\n}\n\nfunction checkArrayTypes() {\n for (var i = 0; i < arguments.length; i++) {\n if (!(arguments[i] instanceof Uint8Array))\n throw new TypeError('unexpected type, use Uint8Array');\n }\n}\n\nfunction cleanup(arr) {\n for (var i = 0; i < arr.length; i++) arr[i] = 0;\n}\n\nnacl.randomBytes = function(n) {\n var b = new Uint8Array(n);\n randombytes(b, n);\n return b;\n};\n\nnacl.secretbox = function(msg, nonce, key) {\n checkArrayTypes(msg, nonce, key);\n checkLengths(key, nonce);\n var m = new Uint8Array(crypto_secretbox_ZEROBYTES + msg.length);\n var c = new Uint8Array(m.length);\n for (var i = 0; i < msg.length; i++) m[i+crypto_secretbox_ZEROBYTES] = msg[i];\n crypto_secretbox(c, m, m.length, nonce, key);\n return c.subarray(crypto_secretbox_BOXZEROBYTES);\n};\n\nnacl.secretbox.open = function(box, nonce, key) {\n checkArrayTypes(box, nonce, key);\n checkLengths(key, nonce);\n var c = new Uint8Array(crypto_secretbox_BOXZEROBYTES + box.length);\n var m = new Uint8Array(c.length);\n for (var i = 0; i < box.length; i++) c[i+crypto_secretbox_BOXZEROBYTES] = box[i];\n if (c.length < 32) return null;\n if (crypto_secretbox_open(m, c, c.length, nonce, key) !== 0) return null;\n return m.subarray(crypto_secretbox_ZEROBYTES);\n};\n\nnacl.secretbox.keyLength = crypto_secretbox_KEYBYTES;\nnacl.secretbox.nonceLength = crypto_secretbox_NONCEBYTES;\nnacl.secretbox.overheadLength = crypto_secretbox_BOXZEROBYTES;\n\nnacl.scalarMult = function(n, p) {\n checkArrayTypes(n, p);\n if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size');\n if (p.length !== crypto_scalarmult_BYTES) throw new Error('bad p size');\n var q = new Uint8Array(crypto_scalarmult_BYTES);\n crypto_scalarmult(q, n, p);\n return q;\n};\n\nnacl.scalarMult.base = function(n) {\n checkArrayTypes(n);\n if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size');\n var q = new Uint8Array(crypto_scalarmult_BYTES);\n crypto_scalarmult_base(q, n);\n return q;\n};\n\nnacl.scalarMult.scalarLength = crypto_scalarmult_SCALARBYTES;\nnacl.scalarMult.groupElementLength = crypto_scalarmult_BYTES;\n\nnacl.box = function(msg, nonce, publicKey, secretKey) {\n var k = nacl.box.before(publicKey, secretKey);\n return nacl.secretbox(msg, nonce, k);\n};\n\nnacl.box.before = function(publicKey, secretKey) {\n checkArrayTypes(publicKey, secretKey);\n checkBoxLengths(publicKey, secretKey);\n var k = new Uint8Array(crypto_box_BEFORENMBYTES);\n crypto_box_beforenm(k, publicKey, secretKey);\n return k;\n};\n\nnacl.box.after = nacl.secretbox;\n\nnacl.box.open = function(msg, nonce, publicKey, secretKey) {\n var k = nacl.box.before(publicKey, secretKey);\n return nacl.secretbox.open(msg, nonce, k);\n};\n\nnacl.box.open.after = nacl.secretbox.open;\n\nnacl.box.keyPair = function() {\n var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_box_SECRETKEYBYTES);\n crypto_box_keypair(pk, sk);\n return {publicKey: pk, secretKey: sk};\n};\n\nnacl.box.keyPair.fromSecretKey = function(secretKey) {\n checkArrayTypes(secretKey);\n if (secretKey.length !== crypto_box_SECRETKEYBYTES)\n throw new Error('bad secret key size');\n var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES);\n crypto_scalarmult_base(pk, secretKey);\n return {publicKey: pk, secretKey: new Uint8Array(secretKey)};\n};\n\nnacl.box.publicKeyLength = crypto_box_PUBLICKEYBYTES;\nnacl.box.secretKeyLength = crypto_box_SECRETKEYBYTES;\nnacl.box.sharedKeyLength = crypto_box_BEFORENMBYTES;\nnacl.box.nonceLength = crypto_box_NONCEBYTES;\nnacl.box.overheadLength = nacl.secretbox.overheadLength;\n\nnacl.sign = function(msg, secretKey) {\n checkArrayTypes(msg, secretKey);\n if (secretKey.length !== crypto_sign_SECRETKEYBYTES)\n throw new Error('bad secret key size');\n var signedMsg = new Uint8Array(crypto_sign_BYTES+msg.length);\n crypto_sign(signedMsg, msg, msg.length, secretKey);\n return signedMsg;\n};\n\nnacl.sign.open = function(signedMsg, publicKey) {\n checkArrayTypes(signedMsg, publicKey);\n if (publicKey.length !== crypto_sign_PUBLICKEYBYTES)\n throw new Error('bad public key size');\n var tmp = new Uint8Array(signedMsg.length);\n var mlen = crypto_sign_open(tmp, signedMsg, signedMsg.length, publicKey);\n if (mlen < 0) return null;\n var m = new Uint8Array(mlen);\n for (var i = 0; i < m.length; i++) m[i] = tmp[i];\n return m;\n};\n\nnacl.sign.detached = function(msg, secretKey) {\n var signedMsg = nacl.sign(msg, secretKey);\n var sig = new Uint8Array(crypto_sign_BYTES);\n for (var i = 0; i < sig.length; i++) sig[i] = signedMsg[i];\n return sig;\n};\n\nnacl.sign.detached.verify = function(msg, sig, publicKey) {\n checkArrayTypes(msg, sig, publicKey);\n if (sig.length !== crypto_sign_BYTES)\n throw new Error('bad signature size');\n if (publicKey.length !== crypto_sign_PUBLICKEYBYTES)\n throw new Error('bad public key size');\n var sm = new Uint8Array(crypto_sign_BYTES + msg.length);\n var m = new Uint8Array(crypto_sign_BYTES + msg.length);\n var i;\n for (i = 0; i < crypto_sign_BYTES; i++) sm[i] = sig[i];\n for (i = 0; i < msg.length; i++) sm[i+crypto_sign_BYTES] = msg[i];\n return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0);\n};\n\nnacl.sign.keyPair = function() {\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES);\n crypto_sign_keypair(pk, sk);\n return {publicKey: pk, secretKey: sk};\n};\n\nnacl.sign.keyPair.fromSecretKey = function(secretKey) {\n checkArrayTypes(secretKey);\n if (secretKey.length !== crypto_sign_SECRETKEYBYTES)\n throw new Error('bad secret key size');\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n for (var i = 0; i < pk.length; i++) pk[i] = secretKey[32+i];\n return {publicKey: pk, secretKey: new Uint8Array(secretKey)};\n};\n\nnacl.sign.keyPair.fromSeed = function(seed) {\n checkArrayTypes(seed);\n if (seed.length !== crypto_sign_SEEDBYTES)\n throw new Error('bad seed size');\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES);\n for (var i = 0; i < 32; i++) sk[i] = seed[i];\n crypto_sign_keypair(pk, sk, true);\n return {publicKey: pk, secretKey: sk};\n};\n\nnacl.sign.publicKeyLength = crypto_sign_PUBLICKEYBYTES;\nnacl.sign.secretKeyLength = crypto_sign_SECRETKEYBYTES;\nnacl.sign.seedLength = crypto_sign_SEEDBYTES;\nnacl.sign.signatureLength = crypto_sign_BYTES;\n\nnacl.hash = function(msg) {\n checkArrayTypes(msg);\n var h = new Uint8Array(crypto_hash_BYTES);\n crypto_hash(h, msg, msg.length);\n return h;\n};\n\nnacl.hash.hashLength = crypto_hash_BYTES;\n\nnacl.verify = function(x, y) {\n checkArrayTypes(x, y);\n // Zero length arguments are considered not equal.\n if (x.length === 0 || y.length === 0) return false;\n if (x.length !== y.length) return false;\n return (vn(x, 0, y, 0, x.length) === 0) ? true : false;\n};\n\nnacl.setPRNG = function(fn) {\n randombytes = fn;\n};\n\n(function() {\n // Initialize PRNG if environment provides CSPRNG.\n // If not, methods calling randombytes will throw.\n var crypto = typeof self !== 'undefined' ? (self.crypto || self.msCrypto) : null;\n if (crypto && crypto.getRandomValues) {\n // Browsers.\n var QUOTA = 65536;\n nacl.setPRNG(function(x, n) {\n var i, v = new Uint8Array(n);\n for (i = 0; i < n; i += QUOTA) {\n crypto.getRandomValues(v.subarray(i, i + Math.min(n - i, QUOTA)));\n }\n for (i = 0; i < n; i++) x[i] = v[i];\n cleanup(v);\n });\n } else if (typeof require !== 'undefined') {\n // Node.js.\n crypto = require('crypto');\n if (crypto && crypto.randomBytes) {\n nacl.setPRNG(function(x, n) {\n var i, v = crypto.randomBytes(n);\n for (i = 0; i < n; i++) x[i] = v[i];\n cleanup(v);\n });\n }\n }\n})();\n\n})(typeof module !== 'undefined' && module.exports ? module.exports : (self.nacl = self.nacl || {}));\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n naf.fill(0);\n\n var ws = 1 << (w + 1);\n var k = num.clone();\n\n for (var i = 0; i < naf.length; i++) {\n var z;\n var mod = k.andln(ws - 1);\n if (k.isOdd()) {\n if (mod > (ws >> 1) - 1)\n z = (ws >> 1) - mod;\n else\n z = mod;\n k.isubn(z);\n } else {\n z = 0;\n }\n\n naf[i] = z;\n k.iushrn(1);\n }\n\n return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n var jsf = [\n [],\n [],\n ];\n\n k1 = k1.clone();\n k2 = k2.clone();\n var d1 = 0;\n var d2 = 0;\n var m8;\n while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n // First phase\n var m14 = (k1.andln(3) + d1) & 3;\n var m24 = (k2.andln(3) + d2) & 3;\n if (m14 === 3)\n m14 = -1;\n if (m24 === 3)\n m24 = -1;\n var u1;\n if ((m14 & 1) === 0) {\n u1 = 0;\n } else {\n m8 = (k1.andln(7) + d1) & 7;\n if ((m8 === 3 || m8 === 5) && m24 === 2)\n u1 = -m14;\n else\n u1 = m14;\n }\n jsf[0].push(u1);\n\n var u2;\n if ((m24 & 1) === 0) {\n u2 = 0;\n } else {\n m8 = (k2.andln(7) + d2) & 7;\n if ((m8 === 3 || m8 === 5) && m14 === 2)\n u2 = -m24;\n else\n u2 = m24;\n }\n jsf[1].push(u2);\n\n // Second phase\n if (2 * d1 === u1 + 1)\n d1 = 1 - d1;\n if (2 * d2 === u2 + 1)\n d2 = 1 - d2;\n k1.iushrn(1);\n k2.iushrn(1);\n }\n\n return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n var key = '_' + name;\n obj.prototype[name] = function cachedProperty() {\n return this[key] !== undefined ? this[key] :\n this[key] = computer.call(this);\n };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n return false;\n }\n if (i < 0 || i + 1 >= msg.length) {\n return false;\n }\n return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg === 'string') {\n if (!enc) {\n // Inspired by stringToUtf8ByteArray() in closure-library by Google\n // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n // Apache License 2.0\n // https://github.com/google/closure-library/blob/master/LICENSE\n var p = 0;\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n if (c < 128) {\n res[p++] = c;\n } else if (c < 2048) {\n res[p++] = (c >> 6) | 192;\n res[p++] = (c & 63) | 128;\n } else if (isSurrogatePair(msg, i)) {\n c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n res[p++] = (c >> 18) | 240;\n res[p++] = ((c >> 12) & 63) | 128;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n } else {\n res[p++] = (c >> 12) | 224;\n res[p++] = ((c >> 6) & 63) | 128;\n res[p++] = (c & 63) | 128;\n }\n }\n } else if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n }\n } else {\n for (i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n }\n return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n var res = (w >>> 24) |\n ((w >>> 8) & 0xff00) |\n ((w << 8) & 0xff0000) |\n ((w & 0xff) << 24);\n return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n var res = '';\n for (var i = 0; i < msg.length; i++) {\n var w = msg[i];\n if (endian === 'little')\n w = htonl(w);\n res += zero8(w.toString(16));\n }\n return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n if (word.length === 7)\n return '0' + word;\n else if (word.length === 6)\n return '00' + word;\n else if (word.length === 5)\n return '000' + word;\n else if (word.length === 4)\n return '0000' + word;\n else if (word.length === 3)\n return '00000' + word;\n else if (word.length === 2)\n return '000000' + word;\n else if (word.length === 1)\n return '0000000' + word;\n else\n return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n var len = end - start;\n assert(len % 4 === 0);\n var res = new Array(len / 4);\n for (var i = 0, k = start; i < res.length; i++, k += 4) {\n var w;\n if (endian === 'big')\n w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n else\n w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n res[i] = w >>> 0;\n }\n return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n var res = new Array(msg.length * 4);\n for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n var m = msg[i];\n if (endian === 'big') {\n res[k] = m >>> 24;\n res[k + 1] = (m >>> 16) & 0xff;\n res[k + 2] = (m >>> 8) & 0xff;\n res[k + 3] = m & 0xff;\n } else {\n res[k + 3] = m >>> 24;\n res[k + 2] = (m >>> 16) & 0xff;\n res[k + 1] = (m >>> 8) & 0xff;\n res[k] = m & 0xff;\n }\n }\n return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n var bh = buf[pos];\n var bl = buf[pos + 1];\n\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n buf[pos] = hi >>> 0;\n buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n var lo = (al + bl) >>> 0;\n var hi = (lo < al ? 1 : 0) + ah + bh;\n return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n var lo = al + bl;\n return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n\n var hi = ah + bh + ch + dh + carry;\n return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n var lo = al + bl + cl + dl;\n return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var carry = 0;\n var lo = al;\n lo = (lo + bl) >>> 0;\n carry += lo < al ? 1 : 0;\n lo = (lo + cl) >>> 0;\n carry += lo < cl ? 1 : 0;\n lo = (lo + dl) >>> 0;\n carry += lo < dl ? 1 : 0;\n lo = (lo + el) >>> 0;\n carry += lo < el ? 1 : 0;\n\n var hi = ah + bh + ch + dh + eh + carry;\n return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n var lo = al + bl + cl + dl + el;\n\n return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n var r = (al << (32 - num)) | (ah >>> num);\n return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n var r = (ah << (32 - num)) | (al >>> num);\n return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\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 if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\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 this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\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 parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\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 // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 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 b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\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 this._strip();\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 function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\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 // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n 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.modrn(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, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\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 var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\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] >>> wbit) & 0x01;\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 // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(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 var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\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 isNegNum ? this.ineg() : 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.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(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.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\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 isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\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 this._strip();\n return isNegNum ? this.ineg() : this;\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 a BN v4 instance\n r.strip();\n } else {\n // r is a 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\n move(a, a.umod(this.m)._forceRed(this));\n return a;\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","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","\n/*! pako 2.0.4 https://github.com/nodeca/pako @license (MIT AND Zlib) */\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n/* eslint-disable space-unary-ops */\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n//const Z_FILTERED = 1;\n//const Z_HUFFMAN_ONLY = 2;\n//const Z_RLE = 3;\nconst Z_FIXED$1 = 4;\n//const Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\nconst Z_BINARY = 0;\nconst Z_TEXT = 1;\n//const Z_ASCII = 1; // = Z_TEXT\nconst Z_UNKNOWN$1 = 2;\n\n/*============================================================================*/\n\n\nfunction zero$1(buf) { let len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n// From zutil.h\n\nconst STORED_BLOCK = 0;\nconst STATIC_TREES = 1;\nconst DYN_TREES = 2;\n/* The three kinds of block type */\n\nconst MIN_MATCH$1 = 3;\nconst MAX_MATCH$1 = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nconst LENGTH_CODES$1 = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nconst LITERALS$1 = 256;\n/* number of literal bytes 0..255 */\n\nconst L_CODES$1 = LITERALS$1 + 1 + LENGTH_CODES$1;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nconst D_CODES$1 = 30;\n/* number of distance codes */\n\nconst BL_CODES$1 = 19;\n/* number of codes used to transfer the bit lengths */\n\nconst HEAP_SIZE$1 = 2 * L_CODES$1 + 1;\n/* maximum heap size */\n\nconst MAX_BITS$1 = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst Buf_size = 16;\n/* size of bit buffer in bi_buf */\n\n\n/* ===========================================================================\n * Constants\n */\n\nconst MAX_BL_BITS = 7;\n/* Bit length codes must not exceed MAX_BL_BITS bits */\n\nconst END_BLOCK = 256;\n/* end of block literal code */\n\nconst REP_3_6 = 16;\n/* repeat previous bit length 3-6 times (2 bits of repeat count) */\n\nconst REPZ_3_10 = 17;\n/* repeat a zero length 3-10 times (3 bits of repeat count) */\n\nconst REPZ_11_138 = 18;\n/* repeat a zero length 11-138 times (7 bits of repeat count) */\n\n/* eslint-disable comma-spacing,array-bracket-spacing */\nconst extra_lbits = /* extra bits for each length code */\n new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]);\n\nconst extra_dbits = /* extra bits for each distance code */\n new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]);\n\nconst extra_blbits = /* extra bits for each bit length code */\n new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]);\n\nconst bl_order =\n new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);\n/* eslint-enable comma-spacing,array-bracket-spacing */\n\n/* The lengths of the bit length codes are sent in order of decreasing\n * probability, to avoid transmitting the lengths for unused bit length codes.\n */\n\n/* ===========================================================================\n * Local data. These are initialized only once.\n */\n\n// We pre-fill arrays with 0 to avoid uninitialized gaps\n\nconst DIST_CODE_LEN = 512; /* see definition of array dist_code below */\n\n// !!!! Use flat array instead of structure, Freq = i*2, Len = i*2+1\nconst static_ltree = new Array((L_CODES$1 + 2) * 2);\nzero$1(static_ltree);\n/* The static literal tree. Since the bit lengths are imposed, there is no\n * need for the L_CODES extra codes used during heap construction. However\n * The codes 286 and 287 are needed to build a canonical tree (see _tr_init\n * below).\n */\n\nconst static_dtree = new Array(D_CODES$1 * 2);\nzero$1(static_dtree);\n/* The static distance tree. (Actually a trivial tree since all codes use\n * 5 bits.)\n */\n\nconst _dist_code = new Array(DIST_CODE_LEN);\nzero$1(_dist_code);\n/* Distance codes. The first 256 values correspond to the distances\n * 3 .. 258, the last 256 values correspond to the top 8 bits of\n * the 15 bit distances.\n */\n\nconst _length_code = new Array(MAX_MATCH$1 - MIN_MATCH$1 + 1);\nzero$1(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nconst base_length = new Array(LENGTH_CODES$1);\nzero$1(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nconst base_dist = new Array(D_CODES$1);\nzero$1(base_dist);\n/* First normalized distance for each code (0 = distance of 1) */\n\n\nfunction StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {\n\n this.static_tree = static_tree; /* static tree or NULL */\n this.extra_bits = extra_bits; /* extra bits for each code or NULL */\n this.extra_base = extra_base; /* base index for extra_bits */\n this.elems = elems; /* max number of elements in the tree */\n this.max_length = max_length; /* max bit length for the codes */\n\n // show if `static_tree` has data or dummy - needed for monomorphic objects\n this.has_stree = static_tree && static_tree.length;\n}\n\n\nlet static_l_desc;\nlet static_d_desc;\nlet static_bl_desc;\n\n\nfunction TreeDesc(dyn_tree, stat_desc) {\n this.dyn_tree = dyn_tree; /* the dynamic tree */\n this.max_code = 0; /* largest code with non zero frequency */\n this.stat_desc = stat_desc; /* the corresponding static tree */\n}\n\n\n\nconst d_code = (dist) => {\n\n return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];\n};\n\n\n/* ===========================================================================\n * Output a short LSB first on the stream.\n * IN assertion: there is enough room in pendingBuf.\n */\nconst put_short = (s, w) => {\n// put_byte(s, (uch)((w) & 0xff));\n// put_byte(s, (uch)((ush)(w) >> 8));\n s.pending_buf[s.pending++] = (w) & 0xff;\n s.pending_buf[s.pending++] = (w >>> 8) & 0xff;\n};\n\n\n/* ===========================================================================\n * Send a value on a given number of bits.\n * IN assertion: length <= 16 and value fits in length bits.\n */\nconst send_bits = (s, value, length) => {\n\n if (s.bi_valid > (Buf_size - length)) {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n put_short(s, s.bi_buf);\n s.bi_buf = value >> (Buf_size - s.bi_valid);\n s.bi_valid += length - Buf_size;\n } else {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n s.bi_valid += length;\n }\n};\n\n\nconst send_code = (s, c, tree) => {\n\n send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);\n};\n\n\n/* ===========================================================================\n * Reverse the first len bits of a code, using straightforward code (a faster\n * method would use a table)\n * IN assertion: 1 <= len <= 15\n */\nconst bi_reverse = (code, len) => {\n\n let res = 0;\n do {\n res |= code & 1;\n code >>>= 1;\n res <<= 1;\n } while (--len > 0);\n return res >>> 1;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer, keeping at most 7 bits in it.\n */\nconst bi_flush = (s) => {\n\n if (s.bi_valid === 16) {\n put_short(s, s.bi_buf);\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n } else if (s.bi_valid >= 8) {\n s.pending_buf[s.pending++] = s.bi_buf & 0xff;\n s.bi_buf >>= 8;\n s.bi_valid -= 8;\n }\n};\n\n\n/* ===========================================================================\n * Compute the optimal bit lengths for a tree and update the total bit length\n * for the current block.\n * IN assertion: the fields freq and dad are set, heap[heap_max] and\n * above are the tree nodes sorted by increasing frequency.\n * OUT assertions: the field len is set to the optimal bit length, the\n * array bl_count contains the frequencies for each bit length.\n * The length opt_len is updated; static_len is also updated if stree is\n * not null.\n */\nconst gen_bitlen = (s, desc) =>\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n const tree = desc.dyn_tree;\n const max_code = desc.max_code;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const extra = desc.stat_desc.extra_bits;\n const base = desc.stat_desc.extra_base;\n const max_length = desc.stat_desc.max_length;\n let h; /* heap index */\n let n, m; /* iterate over the tree elements */\n let bits; /* bit length */\n let xbits; /* extra bits */\n let f; /* frequency */\n let overflow = 0; /* number of elements with bit length too large */\n\n for (bits = 0; bits <= MAX_BITS$1; bits++) {\n s.bl_count[bits] = 0;\n }\n\n /* In a first pass, compute the optimal bit lengths (which may\n * overflow in the case of the bit length tree).\n */\n tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */\n\n for (h = s.heap_max + 1; h < HEAP_SIZE$1; h++) {\n n = s.heap[h];\n bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;\n if (bits > max_length) {\n bits = max_length;\n overflow++;\n }\n tree[n * 2 + 1]/*.Len*/ = bits;\n /* We overwrite tree[n].Dad which is no longer needed */\n\n if (n > max_code) { continue; } /* not a leaf node */\n\n s.bl_count[bits]++;\n xbits = 0;\n if (n >= base) {\n xbits = extra[n - base];\n }\n f = tree[n * 2]/*.Freq*/;\n s.opt_len += f * (bits + xbits);\n if (has_stree) {\n s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);\n }\n }\n if (overflow === 0) { return; }\n\n // Trace((stderr,\"\\nbit length overflow\\n\"));\n /* This happens for example on obj2 and pic of the Calgary corpus */\n\n /* Find the first bit length which could increase: */\n do {\n bits = max_length - 1;\n while (s.bl_count[bits] === 0) { bits--; }\n s.bl_count[bits]--; /* move one leaf down the tree */\n s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */\n s.bl_count[max_length]--;\n /* The brother of the overflow item also moves one step up,\n * but this does not affect bl_count[max_length]\n */\n overflow -= 2;\n } while (overflow > 0);\n\n /* Now recompute all bit lengths, scanning in increasing frequency.\n * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all\n * lengths instead of fixing only the wrong ones. This idea is taken\n * from 'ar' written by Haruhiko Okumura.)\n */\n for (bits = max_length; bits !== 0; bits--) {\n n = s.bl_count[bits];\n while (n !== 0) {\n m = s.heap[--h];\n if (m > max_code) { continue; }\n if (tree[m * 2 + 1]/*.Len*/ !== bits) {\n // Trace((stderr,\"code %d bits %d->%d\\n\", m, tree[m].Len, bits));\n s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;\n tree[m * 2 + 1]/*.Len*/ = bits;\n }\n n--;\n }\n }\n};\n\n\n/* ===========================================================================\n * Generate the codes for a given tree and bit counts (which need not be\n * optimal).\n * IN assertion: the array bl_count contains the bit length statistics for\n * the given tree and the field len is set for all tree elements.\n * OUT assertion: the field code is set for all tree elements of non\n * zero code length.\n */\nconst gen_codes = (tree, max_code, bl_count) =>\n// ct_data *tree; /* the tree to decorate */\n// int max_code; /* largest code with non zero frequency */\n// ushf *bl_count; /* number of codes at each bit length */\n{\n const next_code = new Array(MAX_BITS$1 + 1); /* next code value for each bit length */\n let code = 0; /* running code value */\n let bits; /* bit index */\n let n; /* code index */\n\n /* The distribution counts are first used to generate the code values\n * without bit reversal.\n */\n for (bits = 1; bits <= MAX_BITS$1; bits++) {\n next_code[bits] = code = (code + bl_count[bits - 1]) << 1;\n }\n /* Check that the bit counts in bl_count are consistent. The last code\n * must be all ones.\n */\n //Assert (code + bl_count[MAX_BITS]-1 == (1< {\n\n let n; /* iterates over tree elements */\n let bits; /* bit counter */\n let length; /* length value */\n let code; /* code value */\n let dist; /* distance index */\n const bl_count = new Array(MAX_BITS$1 + 1);\n /* number of codes at each bit length for an optimal tree */\n\n // do check in _tr_init()\n //if (static_init_done) return;\n\n /* For some embedded targets, global variables are not initialized: */\n/*#ifdef NO_INIT_GLOBAL_POINTERS\n static_l_desc.static_tree = static_ltree;\n static_l_desc.extra_bits = extra_lbits;\n static_d_desc.static_tree = static_dtree;\n static_d_desc.extra_bits = extra_dbits;\n static_bl_desc.extra_bits = extra_blbits;\n#endif*/\n\n /* Initialize the mapping length (0..255) -> length code (0..28) */\n length = 0;\n for (code = 0; code < LENGTH_CODES$1 - 1; code++) {\n base_length[code] = length;\n for (n = 0; n < (1 << extra_lbits[code]); n++) {\n _length_code[length++] = code;\n }\n }\n //Assert (length == 256, \"tr_static_init: length != 256\");\n /* Note that the length 255 (match length 258) can be represented\n * in two different ways: code 284 + 5 bits or code 285, so we\n * overwrite length_code[255] to use the best encoding:\n */\n _length_code[length - 1] = code;\n\n /* Initialize the mapping dist (0..32K) -> dist code (0..29) */\n dist = 0;\n for (code = 0; code < 16; code++) {\n base_dist[code] = dist;\n for (n = 0; n < (1 << extra_dbits[code]); n++) {\n _dist_code[dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: dist != 256\");\n dist >>= 7; /* from now on, all distances are divided by 128 */\n for (; code < D_CODES$1; code++) {\n base_dist[code] = dist << 7;\n for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {\n _dist_code[256 + dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: 256+dist != 512\");\n\n /* Construct the codes of the static literal tree */\n for (bits = 0; bits <= MAX_BITS$1; bits++) {\n bl_count[bits] = 0;\n }\n\n n = 0;\n while (n <= 143) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n while (n <= 255) {\n static_ltree[n * 2 + 1]/*.Len*/ = 9;\n n++;\n bl_count[9]++;\n }\n while (n <= 279) {\n static_ltree[n * 2 + 1]/*.Len*/ = 7;\n n++;\n bl_count[7]++;\n }\n while (n <= 287) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n /* Codes 286 and 287 do not exist, but we must include them in the\n * tree construction to get a canonical Huffman tree (longest code\n * all ones)\n */\n gen_codes(static_ltree, L_CODES$1 + 1, bl_count);\n\n /* The static distance tree is trivial: */\n for (n = 0; n < D_CODES$1; n++) {\n static_dtree[n * 2 + 1]/*.Len*/ = 5;\n static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);\n }\n\n // Now data ready and we can init static trees\n static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS$1 + 1, L_CODES$1, MAX_BITS$1);\n static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES$1, MAX_BITS$1);\n static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES$1, MAX_BL_BITS);\n\n //static_init_done = true;\n};\n\n\n/* ===========================================================================\n * Initialize a new block.\n */\nconst init_block = (s) => {\n\n let n; /* iterates over tree elements */\n\n /* Initialize the trees. */\n for (n = 0; n < L_CODES$1; n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < D_CODES$1; n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < BL_CODES$1; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }\n\n s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;\n s.opt_len = s.static_len = 0;\n s.last_lit = s.matches = 0;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer and align the output on a byte boundary\n */\nconst bi_windup = (s) =>\n{\n if (s.bi_valid > 8) {\n put_short(s, s.bi_buf);\n } else if (s.bi_valid > 0) {\n //put_byte(s, (Byte)s->bi_buf);\n s.pending_buf[s.pending++] = s.bi_buf;\n }\n s.bi_buf = 0;\n s.bi_valid = 0;\n};\n\n/* ===========================================================================\n * Copy a stored block, storing first the length and its\n * one's complement if requested.\n */\nconst copy_block = (s, buf, len, header) =>\n//DeflateState *s;\n//charf *buf; /* the input data */\n//unsigned len; /* its length */\n//int header; /* true if block header must be written */\n{\n bi_windup(s); /* align on byte boundary */\n\n if (header) {\n put_short(s, len);\n put_short(s, ~len);\n }\n// while (len--) {\n// put_byte(s, *buf++);\n// }\n s.pending_buf.set(s.window.subarray(buf, buf + len), s.pending);\n s.pending += len;\n};\n\n/* ===========================================================================\n * Compares to subtrees, using the tree depth as tie breaker when\n * the subtrees have equal frequency. This minimizes the worst case length.\n */\nconst smaller = (tree, n, m, depth) => {\n\n const _n2 = n * 2;\n const _m2 = m * 2;\n return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||\n (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));\n};\n\n/* ===========================================================================\n * Restore the heap property by moving down the tree starting at node k,\n * exchanging a node with the smallest of its two sons if necessary, stopping\n * when the heap property is re-established (each father smaller than its\n * two sons).\n */\nconst pqdownheap = (s, tree, k) =>\n// deflate_state *s;\n// ct_data *tree; /* the tree to restore */\n// int k; /* node to move down */\n{\n const v = s.heap[k];\n let j = k << 1; /* left son of k */\n while (j <= s.heap_len) {\n /* Set j to the smallest of the two sons: */\n if (j < s.heap_len &&\n smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {\n j++;\n }\n /* Exit if v is smaller than both sons */\n if (smaller(tree, v, s.heap[j], s.depth)) { break; }\n\n /* Exchange v with the smallest son */\n s.heap[k] = s.heap[j];\n k = j;\n\n /* And continue down the tree, setting j to the left son of k */\n j <<= 1;\n }\n s.heap[k] = v;\n};\n\n\n// inlined manually\n// const SMALLEST = 1;\n\n/* ===========================================================================\n * Send the block data compressed using the given Huffman trees\n */\nconst compress_block = (s, ltree, dtree) =>\n// deflate_state *s;\n// const ct_data *ltree; /* literal tree */\n// const ct_data *dtree; /* distance tree */\n{\n let dist; /* distance of matched string */\n let lc; /* match length or unmatched char (if dist == 0) */\n let lx = 0; /* running index in l_buf */\n let code; /* the code to send */\n let extra; /* number of extra bits to send */\n\n if (s.last_lit !== 0) {\n do {\n dist = (s.pending_buf[s.d_buf + lx * 2] << 8) | (s.pending_buf[s.d_buf + lx * 2 + 1]);\n lc = s.pending_buf[s.l_buf + lx];\n lx++;\n\n if (dist === 0) {\n send_code(s, lc, ltree); /* send a literal byte */\n //Tracecv(isgraph(lc), (stderr,\" '%c' \", lc));\n } else {\n /* Here, lc is the match length - MIN_MATCH */\n code = _length_code[lc];\n send_code(s, code + LITERALS$1 + 1, ltree); /* send the length code */\n extra = extra_lbits[code];\n if (extra !== 0) {\n lc -= base_length[code];\n send_bits(s, lc, extra); /* send the extra length bits */\n }\n dist--; /* dist is now the match distance - 1 */\n code = d_code(dist);\n //Assert (code < D_CODES, \"bad d_code\");\n\n send_code(s, code, dtree); /* send the distance code */\n extra = extra_dbits[code];\n if (extra !== 0) {\n dist -= base_dist[code];\n send_bits(s, dist, extra); /* send the extra distance bits */\n }\n } /* literal or match pair ? */\n\n /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */\n //Assert((uInt)(s->pending) < s->lit_bufsize + 2*lx,\n // \"pendingBuf overflow\");\n\n } while (lx < s.last_lit);\n }\n\n send_code(s, END_BLOCK, ltree);\n};\n\n\n/* ===========================================================================\n * Construct one Huffman tree and assigns the code bit strings and lengths.\n * Update the total bit length for the current block.\n * IN assertion: the field freq is set for all tree elements.\n * OUT assertions: the fields len and code are set to the optimal bit length\n * and corresponding code. The length opt_len is updated; static_len is\n * also updated if stree is not null. The field max_code is set.\n */\nconst build_tree = (s, desc) =>\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n{\n const tree = desc.dyn_tree;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const elems = desc.stat_desc.elems;\n let n, m; /* iterate over heap elements */\n let max_code = -1; /* largest code with non zero frequency */\n let node; /* new node being created */\n\n /* Construct the initial heap, with least frequent element in\n * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].\n * heap[0] is not used.\n */\n s.heap_len = 0;\n s.heap_max = HEAP_SIZE$1;\n\n for (n = 0; n < elems; n++) {\n if (tree[n * 2]/*.Freq*/ !== 0) {\n s.heap[++s.heap_len] = max_code = n;\n s.depth[n] = 0;\n\n } else {\n tree[n * 2 + 1]/*.Len*/ = 0;\n }\n }\n\n /* The pkzip format requires that at least one distance code exists,\n * and that at least one bit should be sent even if there is only one\n * possible code. So to avoid special checks later on we force at least\n * two codes of non zero frequency.\n */\n while (s.heap_len < 2) {\n node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);\n tree[node * 2]/*.Freq*/ = 1;\n s.depth[node] = 0;\n s.opt_len--;\n\n if (has_stree) {\n s.static_len -= stree[node * 2 + 1]/*.Len*/;\n }\n /* node is 0 or 1 so it does not have extra bits */\n }\n desc.max_code = max_code;\n\n /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,\n * establish sub-heaps of increasing lengths:\n */\n for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }\n\n /* Construct the Huffman tree by repeatedly combining the least two\n * frequent nodes.\n */\n node = elems; /* next internal node of the tree */\n do {\n //pqremove(s, tree, n); /* n = node of least frequency */\n /*** pqremove ***/\n n = s.heap[1/*SMALLEST*/];\n s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];\n pqdownheap(s, tree, 1/*SMALLEST*/);\n /***/\n\n m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */\n\n s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */\n s.heap[--s.heap_max] = m;\n\n /* Create a new node father of n and m */\n tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;\n s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;\n tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;\n\n /* and insert the new node in the heap */\n s.heap[1/*SMALLEST*/] = node++;\n pqdownheap(s, tree, 1/*SMALLEST*/);\n\n } while (s.heap_len >= 2);\n\n s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];\n\n /* At this point, the fields freq and dad are set. We can now\n * generate the bit lengths.\n */\n gen_bitlen(s, desc);\n\n /* The field len is now set, we can generate the bit codes */\n gen_codes(tree, max_code, s.bl_count);\n};\n\n\n/* ===========================================================================\n * Scan a literal or distance tree to determine the frequencies of the codes\n * in the bit length tree.\n */\nconst scan_tree = (s, tree, max_code) =>\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n s.bl_tree[curlen * 2]/*.Freq*/ += count;\n\n } else if (curlen !== 0) {\n\n if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }\n s.bl_tree[REP_3_6 * 2]/*.Freq*/++;\n\n } else if (count <= 10) {\n s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;\n\n } else {\n s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;\n }\n\n count = 0;\n prevlen = curlen;\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Send a literal or distance tree in compressed form, using the codes in\n * bl_tree.\n */\nconst send_tree = (s, tree, max_code) =>\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n{\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n /* tree[max_code+1].Len = -1; */ /* guard already set */\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);\n\n } else if (curlen !== 0) {\n if (curlen !== prevlen) {\n send_code(s, curlen, s.bl_tree);\n count--;\n }\n //Assert(count >= 3 && count <= 6, \" 3_6?\");\n send_code(s, REP_3_6, s.bl_tree);\n send_bits(s, count - 3, 2);\n\n } else if (count <= 10) {\n send_code(s, REPZ_3_10, s.bl_tree);\n send_bits(s, count - 3, 3);\n\n } else {\n send_code(s, REPZ_11_138, s.bl_tree);\n send_bits(s, count - 11, 7);\n }\n\n count = 0;\n prevlen = curlen;\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Construct the Huffman tree for the bit lengths and return the index in\n * bl_order of the last bit length code to send.\n */\nconst build_bl_tree = (s) => {\n\n let max_blindex; /* index of last bit length code of non zero freq */\n\n /* Determine the bit length frequencies for literal and distance trees */\n scan_tree(s, s.dyn_ltree, s.l_desc.max_code);\n scan_tree(s, s.dyn_dtree, s.d_desc.max_code);\n\n /* Build the bit length tree: */\n build_tree(s, s.bl_desc);\n /* opt_len now includes the length of the tree representations, except\n * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.\n */\n\n /* Determine the number of bit length codes to send. The pkzip format\n * requires that at least 4 bit length codes be sent. (appnote.txt says\n * 3 but the actual value used is 4.)\n */\n for (max_blindex = BL_CODES$1 - 1; max_blindex >= 3; max_blindex--) {\n if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {\n break;\n }\n }\n /* Update opt_len to include the bit length tree and counts */\n s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;\n //Tracev((stderr, \"\\ndyn trees: dyn %ld, stat %ld\",\n // s->opt_len, s->static_len));\n\n return max_blindex;\n};\n\n\n/* ===========================================================================\n * Send the header for a block using dynamic Huffman trees: the counts, the\n * lengths of the bit length codes, the literal tree and the distance tree.\n * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.\n */\nconst send_all_trees = (s, lcodes, dcodes, blcodes) =>\n// deflate_state *s;\n// int lcodes, dcodes, blcodes; /* number of codes for each tree */\n{\n let rank; /* index in bl_order */\n\n //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, \"not enough codes\");\n //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,\n // \"too many codes\");\n //Tracev((stderr, \"\\nbl counts: \"));\n send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */\n send_bits(s, dcodes - 1, 5);\n send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */\n for (rank = 0; rank < blcodes; rank++) {\n //Tracev((stderr, \"\\nbl code %2d \", bl_order[rank]));\n send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);\n }\n //Tracev((stderr, \"\\nbl tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */\n //Tracev((stderr, \"\\nlit tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */\n //Tracev((stderr, \"\\ndist tree: sent %ld\", s->bits_sent));\n};\n\n\n/* ===========================================================================\n * Check if the data type is TEXT or BINARY, using the following algorithm:\n * - TEXT if the two conditions below are satisfied:\n * a) There are no non-portable control characters belonging to the\n * \"black list\" (0..6, 14..25, 28..31).\n * b) There is at least one printable character belonging to the\n * \"white list\" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).\n * - BINARY otherwise.\n * - The following partially-portable control characters form a\n * \"gray list\" that is ignored in this detection algorithm:\n * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).\n * IN assertion: the fields Freq of dyn_ltree are set.\n */\nconst detect_data_type = (s) => {\n /* black_mask is the bit mask of black-listed bytes\n * set bits 0..6, 14..25, and 28..31\n * 0xf3ffc07f = binary 11110011111111111100000001111111\n */\n let black_mask = 0xf3ffc07f;\n let n;\n\n /* Check for non-textual (\"black-listed\") bytes. */\n for (n = 0; n <= 31; n++, black_mask >>>= 1) {\n if ((black_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {\n return Z_BINARY;\n }\n }\n\n /* Check for textual (\"white-listed\") bytes. */\n if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||\n s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n for (n = 32; n < LITERALS$1; n++) {\n if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n }\n\n /* There are no \"black-listed\" or \"white-listed\" bytes:\n * this stream either is empty or has tolerated (\"gray-listed\") bytes only.\n */\n return Z_BINARY;\n};\n\n\nlet static_init_done = false;\n\n/* ===========================================================================\n * Initialize the tree data structures for a new zlib stream.\n */\nconst _tr_init$1 = (s) =>\n{\n\n if (!static_init_done) {\n tr_static_init();\n static_init_done = true;\n }\n\n s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);\n s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);\n s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);\n\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n /* Initialize the first block of the first file: */\n init_block(s);\n};\n\n\n/* ===========================================================================\n * Send a stored block\n */\nconst _tr_stored_block$1 = (s, buf, stored_len, last) =>\n//DeflateState *s;\n//charf *buf; /* input block */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3); /* send block type */\n copy_block(s, buf, stored_len, true); /* with header */\n};\n\n\n/* ===========================================================================\n * Send one empty static block to give enough lookahead for inflate.\n * This takes 10 bits, of which 7 may remain in the bit buffer.\n */\nconst _tr_align$1 = (s) => {\n send_bits(s, STATIC_TREES << 1, 3);\n send_code(s, END_BLOCK, static_ltree);\n bi_flush(s);\n};\n\n\n/* ===========================================================================\n * Determine the best encoding for the current block: dynamic trees, static\n * trees or store, and output the encoded block to the zip file.\n */\nconst _tr_flush_block$1 = (s, buf, stored_len, last) =>\n//DeflateState *s;\n//charf *buf; /* input block, or NULL if too old */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n{\n let opt_lenb, static_lenb; /* opt_len and static_len in bytes */\n let max_blindex = 0; /* index of last bit length code of non zero freq */\n\n /* Build the Huffman trees unless a stored block is forced */\n if (s.level > 0) {\n\n /* Check if the file is binary or text */\n if (s.strm.data_type === Z_UNKNOWN$1) {\n s.strm.data_type = detect_data_type(s);\n }\n\n /* Construct the literal and distance trees */\n build_tree(s, s.l_desc);\n // Tracev((stderr, \"\\nlit data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n\n build_tree(s, s.d_desc);\n // Tracev((stderr, \"\\ndist data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n /* At this point, opt_len and static_len are the total bit lengths of\n * the compressed block data, excluding the tree representations.\n */\n\n /* Build the bit length tree for the above two trees, and get the index\n * in bl_order of the last bit length code to send.\n */\n max_blindex = build_bl_tree(s);\n\n /* Determine the best encoding. Compute the block lengths in bytes. */\n opt_lenb = (s.opt_len + 3 + 7) >>> 3;\n static_lenb = (s.static_len + 3 + 7) >>> 3;\n\n // Tracev((stderr, \"\\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u \",\n // opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,\n // s->last_lit));\n\n if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }\n\n } else {\n // Assert(buf != (char*)0, \"lost buf\");\n opt_lenb = static_lenb = stored_len + 5; /* force a stored block */\n }\n\n if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {\n /* 4: two words for the lengths */\n\n /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.\n * Otherwise we can't have processed more than WSIZE input bytes since\n * the last block flush, because compression would have been\n * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to\n * transform a block into a stored block.\n */\n _tr_stored_block$1(s, buf, stored_len, last);\n\n } else if (s.strategy === Z_FIXED$1 || static_lenb === opt_lenb) {\n\n send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);\n compress_block(s, static_ltree, static_dtree);\n\n } else {\n send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);\n send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);\n compress_block(s, s.dyn_ltree, s.dyn_dtree);\n }\n // Assert (s->compressed_len == s->bits_sent, \"bad compressed size\");\n /* The above check is made mod 2^32, for files larger than 512 MB\n * and uLong implemented on 32 bits.\n */\n init_block(s);\n\n if (last) {\n bi_windup(s);\n }\n // Tracev((stderr,\"\\ncomprlen %lu(%lu) \", s->compressed_len>>3,\n // s->compressed_len-7*last));\n};\n\n/* ===========================================================================\n * Save the match info and tally the frequency counts. Return true if\n * the current block must be flushed.\n */\nconst _tr_tally$1 = (s, dist, lc) =>\n// deflate_state *s;\n// unsigned dist; /* distance of matched string */\n// unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */\n{\n //let out_length, in_length, dcode;\n\n s.pending_buf[s.d_buf + s.last_lit * 2] = (dist >>> 8) & 0xff;\n s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 0xff;\n\n s.pending_buf[s.l_buf + s.last_lit] = lc & 0xff;\n s.last_lit++;\n\n if (dist === 0) {\n /* lc is the unmatched char */\n s.dyn_ltree[lc * 2]/*.Freq*/++;\n } else {\n s.matches++;\n /* Here, lc is the match length - MIN_MATCH */\n dist--; /* dist = match distance - 1 */\n //Assert((ush)dist < (ush)MAX_DIST(s) &&\n // (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&\n // (ush)d_code(dist) < (ush)D_CODES, \"_tr_tally: bad match\");\n\n s.dyn_ltree[(_length_code[lc] + LITERALS$1 + 1) * 2]/*.Freq*/++;\n s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n\n//#ifdef TRUNCATE_BLOCK\n// /* Try to guess if it is profitable to stop the current block here */\n// if ((s.last_lit & 0x1fff) === 0 && s.level > 2) {\n// /* Compute an upper bound for the compressed length */\n// out_length = s.last_lit*8;\n// in_length = s.strstart - s.block_start;\n//\n// for (dcode = 0; dcode < D_CODES; dcode++) {\n// out_length += s.dyn_dtree[dcode*2]/*.Freq*/ * (5 + extra_dbits[dcode]);\n// }\n// out_length >>>= 3;\n// //Tracev((stderr,\"\\nlast_lit %u, in %ld, out ~%ld(%ld%%) \",\n// // s->last_lit, in_length, out_length,\n// // 100L - out_length*100L/in_length));\n// if (s.matches < (s.last_lit>>1)/*int /2*/ && out_length < (in_length>>1)/*int /2*/) {\n// return true;\n// }\n// }\n//#endif\n\n return (s.last_lit === s.lit_bufsize - 1);\n /* We avoid equality with lit_bufsize because of wraparound at 64K\n * on 16 bit machines and because stored blocks are restricted to\n * 64K-1 bytes.\n */\n};\n\nvar _tr_init_1 = _tr_init$1;\nvar _tr_stored_block_1 = _tr_stored_block$1;\nvar _tr_flush_block_1 = _tr_flush_block$1;\nvar _tr_tally_1 = _tr_tally$1;\nvar _tr_align_1 = _tr_align$1;\n\nvar trees = {\n\t_tr_init: _tr_init_1,\n\t_tr_stored_block: _tr_stored_block_1,\n\t_tr_flush_block: _tr_flush_block_1,\n\t_tr_tally: _tr_tally_1,\n\t_tr_align: _tr_align_1\n};\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst adler32 = (adler, buf, len, pos) => {\n let s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n};\n\n\nvar adler32_1 = adler32;\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nconst makeTable = () => {\n let c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n};\n\n// Create table on load. Just 255 signed longs. Not a problem.\nconst crcTable = new Uint32Array(makeTable());\n\n\nconst crc32 = (crc, buf, len, pos) => {\n const t = crcTable;\n const end = pos + len;\n\n crc ^= -1;\n\n for (let i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n};\n\n\nvar crc32_1 = crc32;\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar messages = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar constants$2 = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst { _tr_init, _tr_stored_block, _tr_flush_block, _tr_tally, _tr_align } = trees;\n\n\n\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH: Z_NO_FLUSH$2, Z_PARTIAL_FLUSH, Z_FULL_FLUSH: Z_FULL_FLUSH$1, Z_FINISH: Z_FINISH$3, Z_BLOCK: Z_BLOCK$1,\n Z_OK: Z_OK$3, Z_STREAM_END: Z_STREAM_END$3, Z_STREAM_ERROR: Z_STREAM_ERROR$2, Z_DATA_ERROR: Z_DATA_ERROR$2, Z_BUF_ERROR: Z_BUF_ERROR$1,\n Z_DEFAULT_COMPRESSION: Z_DEFAULT_COMPRESSION$1,\n Z_FILTERED, Z_HUFFMAN_ONLY, Z_RLE, Z_FIXED, Z_DEFAULT_STRATEGY: Z_DEFAULT_STRATEGY$1,\n Z_UNKNOWN,\n Z_DEFLATED: Z_DEFLATED$2\n} = constants$2;\n\n/*============================================================================*/\n\n\nconst MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nconst MAX_WBITS$1 = 15;\n/* 32K LZ77 window */\nconst DEF_MEM_LEVEL = 8;\n\n\nconst LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\nconst LITERALS = 256;\n/* number of literal bytes 0..255 */\nconst L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\nconst D_CODES = 30;\n/* number of distance codes */\nconst BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\nconst HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\nconst MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst MIN_MATCH = 3;\nconst MAX_MATCH = 258;\nconst MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);\n\nconst PRESET_DICT = 0x20;\n\nconst INIT_STATE = 42;\nconst EXTRA_STATE = 69;\nconst NAME_STATE = 73;\nconst COMMENT_STATE = 91;\nconst HCRC_STATE = 103;\nconst BUSY_STATE = 113;\nconst FINISH_STATE = 666;\n\nconst BS_NEED_MORE = 1; /* block not completed, need more input or more output */\nconst BS_BLOCK_DONE = 2; /* block flush performed */\nconst BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */\nconst BS_FINISH_DONE = 4; /* finish done, accept no more input or output */\n\nconst OS_CODE = 0x03; // Unix :) . Don't detect, use this default.\n\nconst err = (strm, errorCode) => {\n strm.msg = messages[errorCode];\n return errorCode;\n};\n\nconst rank = (f) => {\n return ((f) << 1) - ((f) > 4 ? 9 : 0);\n};\n\nconst zero = (buf) => {\n let len = buf.length; while (--len >= 0) { buf[len] = 0; }\n};\n\n\n/* eslint-disable new-cap */\nlet HASH_ZLIB = (s, prev, data) => ((prev << s.hash_shift) ^ data) & s.hash_mask;\n// This hash causes less collisions, https://github.com/nodeca/pako/issues/135\n// But breaks binary compatibility\n//let HASH_FAST = (s, prev, data) => ((prev << 8) + (prev >> 8) + (data << 4)) & s.hash_mask;\nlet HASH = HASH_ZLIB;\n\n/* =========================================================================\n * Flush as much pending output as possible. All deflate() output goes\n * through this function so some applications may wish to modify it\n * to avoid allocating a large strm->output buffer and copying into it.\n * (See also read_buf()).\n */\nconst flush_pending = (strm) => {\n const s = strm.state;\n\n //_tr_flush_bits(s);\n let len = s.pending;\n if (len > strm.avail_out) {\n len = strm.avail_out;\n }\n if (len === 0) { return; }\n\n strm.output.set(s.pending_buf.subarray(s.pending_out, s.pending_out + len), strm.next_out);\n strm.next_out += len;\n s.pending_out += len;\n strm.total_out += len;\n strm.avail_out -= len;\n s.pending -= len;\n if (s.pending === 0) {\n s.pending_out = 0;\n }\n};\n\n\nconst flush_block_only = (s, last) => {\n _tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);\n s.block_start = s.strstart;\n flush_pending(s.strm);\n};\n\n\nconst put_byte = (s, b) => {\n s.pending_buf[s.pending++] = b;\n};\n\n\n/* =========================================================================\n * Put a short in the pending buffer. The 16-bit value is put in MSB order.\n * IN assertion: the stream state is correct and there is enough room in\n * pending_buf.\n */\nconst putShortMSB = (s, b) => {\n\n // put_byte(s, (Byte)(b >> 8));\n// put_byte(s, (Byte)(b & 0xff));\n s.pending_buf[s.pending++] = (b >>> 8) & 0xff;\n s.pending_buf[s.pending++] = b & 0xff;\n};\n\n\n/* ===========================================================================\n * Read a new buffer from the current input stream, update the adler32\n * and total number of bytes read. All deflate() input goes through\n * this function so some applications may wish to modify it to avoid\n * allocating a large strm->input buffer and copying from it.\n * (See also flush_pending()).\n */\nconst read_buf = (strm, buf, start, size) => {\n\n let len = strm.avail_in;\n\n if (len > size) { len = size; }\n if (len === 0) { return 0; }\n\n strm.avail_in -= len;\n\n // zmemcpy(buf, strm->next_in, len);\n buf.set(strm.input.subarray(strm.next_in, strm.next_in + len), start);\n if (strm.state.wrap === 1) {\n strm.adler = adler32_1(strm.adler, buf, len, start);\n }\n\n else if (strm.state.wrap === 2) {\n strm.adler = crc32_1(strm.adler, buf, len, start);\n }\n\n strm.next_in += len;\n strm.total_in += len;\n\n return len;\n};\n\n\n/* ===========================================================================\n * Set match_start to the longest match starting at the given string and\n * return its length. Matches shorter or equal to prev_length are discarded,\n * in which case the result is equal to prev_length and match_start is\n * garbage.\n * IN assertions: cur_match is the head of the hash chain for the current\n * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1\n * OUT assertion: the match length is not greater than s->lookahead.\n */\nconst longest_match = (s, cur_match) => {\n\n let chain_length = s.max_chain_length; /* max hash chain length */\n let scan = s.strstart; /* current string */\n let match; /* matched string */\n let len; /* length of current match */\n let best_len = s.prev_length; /* best match length so far */\n let nice_match = s.nice_match; /* stop if match long enough */\n const limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?\n s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;\n\n const _win = s.window; // shortcut\n\n const wmask = s.w_mask;\n const prev = s.prev;\n\n /* Stop when cur_match becomes <= limit. To simplify the code,\n * we prevent matches with the string of window index 0.\n */\n\n const strend = s.strstart + MAX_MATCH;\n let scan_end1 = _win[scan + best_len - 1];\n let scan_end = _win[scan + best_len];\n\n /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.\n * It is easy to get rid of this optimization if necessary.\n */\n // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, \"Code too clever\");\n\n /* Do not waste too much time if we already have a good match: */\n if (s.prev_length >= s.good_match) {\n chain_length >>= 2;\n }\n /* Do not look for matches beyond the end of the input. This is necessary\n * to make deflate deterministic.\n */\n if (nice_match > s.lookahead) { nice_match = s.lookahead; }\n\n // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, \"need lookahead\");\n\n do {\n // Assert(cur_match < s->strstart, \"no future\");\n match = cur_match;\n\n /* Skip to next match if the match length cannot increase\n * or if the match length is less than 2. Note that the checks below\n * for insufficient lookahead only occur occasionally for performance\n * reasons. Therefore uninitialized memory will be accessed, and\n * conditional jumps will be made that depend on those values.\n * However the length of the match is limited to the lookahead, so\n * the output of deflate is not affected by the uninitialized values.\n */\n\n if (_win[match + best_len] !== scan_end ||\n _win[match + best_len - 1] !== scan_end1 ||\n _win[match] !== _win[scan] ||\n _win[++match] !== _win[scan + 1]) {\n continue;\n }\n\n /* The check at best_len-1 can be removed because it will be made\n * again later. (This heuristic is not always a win.)\n * It is not necessary to compare scan[2] and match[2] since they\n * are always equal when the other bytes match, given that\n * the hash keys are equal and that HASH_BITS >= 8.\n */\n scan += 2;\n match++;\n // Assert(*scan == *match, \"match[2]?\");\n\n /* We check for insufficient lookahead only every 8th comparison;\n * the 256th check will be made at strstart+258.\n */\n do {\n /*jshint noempty:false*/\n } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n scan < strend);\n\n // Assert(scan <= s->window+(unsigned)(s->window_size-1), \"wild scan\");\n\n len = MAX_MATCH - (strend - scan);\n scan = strend - MAX_MATCH;\n\n if (len > best_len) {\n s.match_start = cur_match;\n best_len = len;\n if (len >= nice_match) {\n break;\n }\n scan_end1 = _win[scan + best_len - 1];\n scan_end = _win[scan + best_len];\n }\n } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);\n\n if (best_len <= s.lookahead) {\n return best_len;\n }\n return s.lookahead;\n};\n\n\n/* ===========================================================================\n * Fill the window when the lookahead becomes insufficient.\n * Updates strstart and lookahead.\n *\n * IN assertion: lookahead < MIN_LOOKAHEAD\n * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD\n * At least one byte has been read, or avail_in == 0; reads are\n * performed for at least two bytes (required for the zip translate_eol\n * option -- not supported here).\n */\nconst fill_window = (s) => {\n\n const _w_size = s.w_size;\n let p, n, m, more, str;\n\n //Assert(s->lookahead < MIN_LOOKAHEAD, \"already enough lookahead\");\n\n do {\n more = s.window_size - s.lookahead - s.strstart;\n\n // JS ints have 32 bit, block below not needed\n /* Deal with !@#$% 64K limit: */\n //if (sizeof(int) <= 2) {\n // if (more == 0 && s->strstart == 0 && s->lookahead == 0) {\n // more = wsize;\n //\n // } else if (more == (unsigned)(-1)) {\n // /* Very unlikely, but possible on 16 bit machine if\n // * strstart == 0 && lookahead == 1 (input done a byte at time)\n // */\n // more--;\n // }\n //}\n\n\n /* If the window is almost full and there is insufficient lookahead,\n * move the upper half to the lower one to make room in the upper half.\n */\n if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {\n\n s.window.set(s.window.subarray(_w_size, _w_size + _w_size), 0);\n s.match_start -= _w_size;\n s.strstart -= _w_size;\n /* we now have strstart >= MAX_DIST */\n s.block_start -= _w_size;\n\n /* Slide the hash table (could be avoided with 32 bit values\n at the expense of memory usage). We slide even when level == 0\n to keep the hash table consistent if we switch back to level > 0\n later. (Using level 0 permanently is not an optimal usage of\n zlib, so we don't care about this pathological case.)\n */\n\n n = s.hash_size;\n p = n;\n\n do {\n m = s.head[--p];\n s.head[p] = (m >= _w_size ? m - _w_size : 0);\n } while (--n);\n\n n = _w_size;\n p = n;\n\n do {\n m = s.prev[--p];\n s.prev[p] = (m >= _w_size ? m - _w_size : 0);\n /* If n is not on any hash chain, prev[n] is garbage but\n * its value will never be used.\n */\n } while (--n);\n\n more += _w_size;\n }\n if (s.strm.avail_in === 0) {\n break;\n }\n\n /* If there was no sliding:\n * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&\n * more == window_size - lookahead - strstart\n * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)\n * => more >= window_size - 2*WSIZE + 2\n * In the BIG_MEM or MMAP case (not yet supported),\n * window_size == input_size + MIN_LOOKAHEAD &&\n * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.\n * Otherwise, window_size == 2*WSIZE so more >= 2.\n * If there was sliding, more >= WSIZE. So in all cases, more >= 2.\n */\n //Assert(more >= 2, \"more < 2\");\n n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);\n s.lookahead += n;\n\n /* Initialize the hash value now that we have some input: */\n if (s.lookahead + s.insert >= MIN_MATCH) {\n str = s.strstart - s.insert;\n s.ins_h = s.window[str];\n\n /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + 1]);\n//#if MIN_MATCH != 3\n// Call update_hash() MIN_MATCH-3 more times\n//#endif\n while (s.insert) {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = str;\n str++;\n s.insert--;\n if (s.lookahead + s.insert < MIN_MATCH) {\n break;\n }\n }\n }\n /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,\n * but this is not important since only literal bytes will be emitted.\n */\n\n } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);\n\n /* If the WIN_INIT bytes after the end of the current data have never been\n * written, then zero those bytes in order to avoid memory check reports of\n * the use of uninitialized (or uninitialised as Julian writes) bytes by\n * the longest match routines. Update the high water mark for the next\n * time through here. WIN_INIT is set to MAX_MATCH since the longest match\n * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.\n */\n// if (s.high_water < s.window_size) {\n// const curr = s.strstart + s.lookahead;\n// let init = 0;\n//\n// if (s.high_water < curr) {\n// /* Previous high water mark below current data -- zero WIN_INIT\n// * bytes or up to end of window, whichever is less.\n// */\n// init = s.window_size - curr;\n// if (init > WIN_INIT)\n// init = WIN_INIT;\n// zmemzero(s->window + curr, (unsigned)init);\n// s->high_water = curr + init;\n// }\n// else if (s->high_water < (ulg)curr + WIN_INIT) {\n// /* High water mark at or above current data, but below current data\n// * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up\n// * to end of window, whichever is less.\n// */\n// init = (ulg)curr + WIN_INIT - s->high_water;\n// if (init > s->window_size - s->high_water)\n// init = s->window_size - s->high_water;\n// zmemzero(s->window + s->high_water, (unsigned)init);\n// s->high_water += init;\n// }\n// }\n//\n// Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,\n// \"not enough room for search\");\n};\n\n/* ===========================================================================\n * Copy without compression as much as possible from the input stream, return\n * the current block state.\n * This function does not insert new strings in the dictionary since\n * uncompressible data is probably not useful. This function is used\n * only for the level=0 compression option.\n * NOTE: this function should be optimized to avoid extra copying from\n * window to pending_buf.\n */\nconst deflate_stored = (s, flush) => {\n\n /* Stored blocks are limited to 0xffff bytes, pending_buf is limited\n * to pending_buf_size, and each stored block has a 5 byte header:\n */\n let max_block_size = 0xffff;\n\n if (max_block_size > s.pending_buf_size - 5) {\n max_block_size = s.pending_buf_size - 5;\n }\n\n /* Copy as much as possible from input to output: */\n for (;;) {\n /* Fill the window as much as possible: */\n if (s.lookahead <= 1) {\n\n //Assert(s->strstart < s->w_size+MAX_DIST(s) ||\n // s->block_start >= (long)s->w_size, \"slide too late\");\n// if (!(s.strstart < s.w_size + (s.w_size - MIN_LOOKAHEAD) ||\n// s.block_start >= s.w_size)) {\n// throw new Error(\"slide too late\");\n// }\n\n fill_window(s);\n if (s.lookahead === 0 && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n\n if (s.lookahead === 0) {\n break;\n }\n /* flush the current block */\n }\n //Assert(s->block_start >= 0L, \"block gone\");\n// if (s.block_start < 0) throw new Error(\"block gone\");\n\n s.strstart += s.lookahead;\n s.lookahead = 0;\n\n /* Emit a stored block if pending_buf will be full: */\n const max_start = s.block_start + max_block_size;\n\n if (s.strstart === 0 || s.strstart >= max_start) {\n /* strstart == 0 is possible when wraparound on 16-bit machine */\n s.lookahead = s.strstart - max_start;\n s.strstart = max_start;\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n\n\n }\n /* Flush if we may have to slide, otherwise block_start may become\n * negative and the data will be gone:\n */\n if (s.strstart - s.block_start >= (s.w_size - MIN_LOOKAHEAD)) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n\n s.insert = 0;\n\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n\n if (s.strstart > s.block_start) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_NEED_MORE;\n};\n\n/* ===========================================================================\n * Compress as much as possible from the input stream, return the current\n * block state.\n * This function does not perform lazy evaluation of matches and inserts\n * new strings in the dictionary only for unmatched strings or for short\n * matches. It is used only for the fast compression options.\n */\nconst deflate_fast = (s, flush) => {\n\n let hash_head; /* head of the hash chain */\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) {\n break; /* flush the current block */\n }\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n * At this point we have always match_length < MIN_MATCH\n */\n if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n }\n if (s.match_length >= MIN_MATCH) {\n // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only\n\n /*** _tr_tally_dist(s, s.strstart - s.match_start,\n s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n\n /* Insert new strings in the hash table only if the match length\n * is not too large. This saves time but degrades compression.\n */\n if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {\n s.match_length--; /* string at strstart already in table */\n do {\n s.strstart++;\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n /* strstart never exceeds WSIZE-MAX_MATCH, so there are\n * always MIN_MATCH bytes ahead.\n */\n } while (--s.match_length !== 0);\n s.strstart++;\n } else\n {\n s.strstart += s.match_length;\n s.match_length = 0;\n s.ins_h = s.window[s.strstart];\n /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + 1]);\n\n//#if MIN_MATCH != 3\n// Call UPDATE_HASH() MIN_MATCH-3 more times\n//#endif\n /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not\n * matter since it will be recomputed at next deflate call.\n */\n }\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s.window[s.strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * Same as above, but achieves better compression. We use a lazy\n * evaluation for matches: a match is finally adopted only if there is\n * no better match at the next window position.\n */\nconst deflate_slow = (s, flush) => {\n\n let hash_head; /* head of hash chain */\n let bflush; /* set if current block must be flushed */\n\n let max_insert;\n\n /* Process the input block. */\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n */\n s.prev_length = s.match_length;\n s.prev_match = s.match_start;\n s.match_length = MIN_MATCH - 1;\n\n if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&\n s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n\n if (s.match_length <= 5 &&\n (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {\n\n /* If prev_match is also MIN_MATCH, match_start is garbage\n * but we will ignore the current match anyway.\n */\n s.match_length = MIN_MATCH - 1;\n }\n }\n /* If there was a match at the previous step and the current\n * match is not better, output the previous match:\n */\n if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {\n max_insert = s.strstart + s.lookahead - MIN_MATCH;\n /* Do not insert strings in hash table beyond this. */\n\n //check_match(s, s.strstart-1, s.prev_match, s.prev_length);\n\n /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,\n s.prev_length - MIN_MATCH, bflush);***/\n bflush = _tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);\n /* Insert in hash table all strings up to the end of the match.\n * strstart-1 and strstart are already inserted. If there is not\n * enough lookahead, the last two strings are not inserted in\n * the hash table.\n */\n s.lookahead -= s.prev_length - 1;\n s.prev_length -= 2;\n do {\n if (++s.strstart <= max_insert) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n } while (--s.prev_length !== 0);\n s.match_available = 0;\n s.match_length = MIN_MATCH - 1;\n s.strstart++;\n\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n } else if (s.match_available) {\n /* If there was no match at the previous position, output a\n * single literal. If there was a match but the current match\n * is longer, truncate the previous match to a single literal.\n */\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n if (bflush) {\n /*** FLUSH_BLOCK_ONLY(s, 0) ***/\n flush_block_only(s, false);\n /***/\n }\n s.strstart++;\n s.lookahead--;\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n } else {\n /* There is no previous match to compare with, wait for\n * the next step to decide.\n */\n s.match_available = 1;\n s.strstart++;\n s.lookahead--;\n }\n }\n //Assert (flush != Z_NO_FLUSH, \"no flush?\");\n if (s.match_available) {\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n s.match_available = 0;\n }\n s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_BLOCK_DONE;\n};\n\n\n/* ===========================================================================\n * For Z_RLE, simply look for runs of bytes, generate matches only of distance\n * one. Do not maintain a hash table. (It will be regenerated if this run of\n * deflate switches away from Z_RLE.)\n */\nconst deflate_rle = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n let prev; /* byte at distance one to match */\n let scan, strend; /* scan goes up to strend for length of run */\n\n const _win = s.window;\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the longest run, plus one for the unrolled loop.\n */\n if (s.lookahead <= MAX_MATCH) {\n fill_window(s);\n if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* See how many times the previous byte repeats */\n s.match_length = 0;\n if (s.lookahead >= MIN_MATCH && s.strstart > 0) {\n scan = s.strstart - 1;\n prev = _win[scan];\n if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {\n strend = s.strstart + MAX_MATCH;\n do {\n /*jshint noempty:false*/\n } while (prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n scan < strend);\n s.match_length = MAX_MATCH - (strend - scan);\n if (s.match_length > s.lookahead) {\n s.match_length = s.lookahead;\n }\n }\n //Assert(scan <= s->window+(uInt)(s->window_size-1), \"wild scan\");\n }\n\n /* Emit match if have run of MIN_MATCH or longer, else emit literal */\n if (s.match_length >= MIN_MATCH) {\n //check_match(s, s.strstart, s.strstart - 1, s.match_length);\n\n /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, 1, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n s.strstart += s.match_length;\n s.match_length = 0;\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table.\n * (It will be regenerated if this run of deflate switches away from Huffman.)\n */\nconst deflate_huff = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we have a literal to write. */\n if (s.lookahead === 0) {\n fill_window(s);\n if (s.lookahead === 0) {\n if (flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n break; /* flush the current block */\n }\n }\n\n /* Output a literal byte */\n s.match_length = 0;\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n s.lookahead--;\n s.strstart++;\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.last_lit) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* Values for max_lazy_match, good_match and max_chain_length, depending on\n * the desired pack level (0..9). The values given below have been tuned to\n * exclude worst case performance for pathological files. Better values may be\n * found for specific files.\n */\nfunction Config(good_length, max_lazy, nice_length, max_chain, func) {\n\n this.good_length = good_length;\n this.max_lazy = max_lazy;\n this.nice_length = nice_length;\n this.max_chain = max_chain;\n this.func = func;\n}\n\nconst configuration_table = [\n /* good lazy nice chain */\n new Config(0, 0, 0, 0, deflate_stored), /* 0 store only */\n new Config(4, 4, 8, 4, deflate_fast), /* 1 max speed, no lazy matches */\n new Config(4, 5, 16, 8, deflate_fast), /* 2 */\n new Config(4, 6, 32, 32, deflate_fast), /* 3 */\n\n new Config(4, 4, 16, 16, deflate_slow), /* 4 lazy matches */\n new Config(8, 16, 32, 32, deflate_slow), /* 5 */\n new Config(8, 16, 128, 128, deflate_slow), /* 6 */\n new Config(8, 32, 128, 256, deflate_slow), /* 7 */\n new Config(32, 128, 258, 1024, deflate_slow), /* 8 */\n new Config(32, 258, 258, 4096, deflate_slow) /* 9 max compression */\n];\n\n\n/* ===========================================================================\n * Initialize the \"longest match\" routines for a new zlib stream\n */\nconst lm_init = (s) => {\n\n s.window_size = 2 * s.w_size;\n\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n\n /* Set the default configuration parameters:\n */\n s.max_lazy_match = configuration_table[s.level].max_lazy;\n s.good_match = configuration_table[s.level].good_length;\n s.nice_match = configuration_table[s.level].nice_length;\n s.max_chain_length = configuration_table[s.level].max_chain;\n\n s.strstart = 0;\n s.block_start = 0;\n s.lookahead = 0;\n s.insert = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n s.ins_h = 0;\n};\n\n\nfunction DeflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.status = 0; /* as the name implies */\n this.pending_buf = null; /* output still pending */\n this.pending_buf_size = 0; /* size of pending_buf */\n this.pending_out = 0; /* next pending byte to output to the stream */\n this.pending = 0; /* nb of bytes in the pending buffer */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.gzhead = null; /* gzip header information to write */\n this.gzindex = 0; /* where in extra, name, or comment */\n this.method = Z_DEFLATED$2; /* can only be DEFLATED */\n this.last_flush = -1; /* value of flush param for previous deflate call */\n\n this.w_size = 0; /* LZ77 window size (32K by default) */\n this.w_bits = 0; /* log2(w_size) (8..16) */\n this.w_mask = 0; /* w_size - 1 */\n\n this.window = null;\n /* Sliding window. Input bytes are read into the second half of the window,\n * and move to the first half later to keep a dictionary of at least wSize\n * bytes. With this organization, matches are limited to a distance of\n * wSize-MAX_MATCH bytes, but this ensures that IO is always\n * performed with a length multiple of the block size.\n */\n\n this.window_size = 0;\n /* Actual size of window: 2*wSize, except when the user input buffer\n * is directly used as sliding window.\n */\n\n this.prev = null;\n /* Link to older string with same hash index. To limit the size of this\n * array to 64K, this link is maintained only for the last 32K strings.\n * An index in this array is thus a window index modulo 32K.\n */\n\n this.head = null; /* Heads of the hash chains or NIL. */\n\n this.ins_h = 0; /* hash index of string to be inserted */\n this.hash_size = 0; /* number of elements in hash table */\n this.hash_bits = 0; /* log2(hash_size) */\n this.hash_mask = 0; /* hash_size-1 */\n\n this.hash_shift = 0;\n /* Number of bits by which ins_h must be shifted at each input\n * step. It must be such that after MIN_MATCH steps, the oldest\n * byte no longer takes part in the hash key, that is:\n * hash_shift * MIN_MATCH >= hash_bits\n */\n\n this.block_start = 0;\n /* Window position at the beginning of the current output block. Gets\n * negative when the window is moved backwards.\n */\n\n this.match_length = 0; /* length of best match */\n this.prev_match = 0; /* previous match */\n this.match_available = 0; /* set if previous match exists */\n this.strstart = 0; /* start of string to insert */\n this.match_start = 0; /* start of matching string */\n this.lookahead = 0; /* number of valid bytes ahead in window */\n\n this.prev_length = 0;\n /* Length of the best match at previous step. Matches not greater than this\n * are discarded. This is used in the lazy match evaluation.\n */\n\n this.max_chain_length = 0;\n /* To speed up deflation, hash chains are never searched beyond this\n * length. A higher limit improves compression ratio but degrades the\n * speed.\n */\n\n this.max_lazy_match = 0;\n /* Attempt to find a better match only when the current match is strictly\n * smaller than this value. This mechanism is used only for compression\n * levels >= 4.\n */\n // That's alias to max_lazy_match, don't use directly\n //this.max_insert_length = 0;\n /* Insert new strings in the hash table only if the match length is not\n * greater than this length. This saves time but degrades compression.\n * max_insert_length is used only for compression levels <= 3.\n */\n\n this.level = 0; /* compression level (1..9) */\n this.strategy = 0; /* favor or force Huffman coding*/\n\n this.good_match = 0;\n /* Use a faster search when the previous match is longer than this */\n\n this.nice_match = 0; /* Stop searching when current match exceeds this */\n\n /* used by trees.c: */\n\n /* Didn't use ct_data typedef below to suppress compiler warning */\n\n // struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */\n // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */\n // struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */\n\n // Use flat array of DOUBLE size, with interleaved fata,\n // because JS does not support effective\n this.dyn_ltree = new Uint16Array(HEAP_SIZE * 2);\n this.dyn_dtree = new Uint16Array((2 * D_CODES + 1) * 2);\n this.bl_tree = new Uint16Array((2 * BL_CODES + 1) * 2);\n zero(this.dyn_ltree);\n zero(this.dyn_dtree);\n zero(this.bl_tree);\n\n this.l_desc = null; /* desc. for literal tree */\n this.d_desc = null; /* desc. for distance tree */\n this.bl_desc = null; /* desc. for bit length tree */\n\n //ush bl_count[MAX_BITS+1];\n this.bl_count = new Uint16Array(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n //int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */\n this.heap = new Uint16Array(2 * L_CODES + 1); /* heap used to build the Huffman trees */\n zero(this.heap);\n\n this.heap_len = 0; /* number of elements in the heap */\n this.heap_max = 0; /* element of largest frequency */\n /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.\n * The same heap array is used to build all trees.\n */\n\n this.depth = new Uint16Array(2 * L_CODES + 1); //uch depth[2*L_CODES+1];\n zero(this.depth);\n /* Depth of each subtree used as tie breaker for trees of equal frequency\n */\n\n this.l_buf = 0; /* buffer index for literals or lengths */\n\n this.lit_bufsize = 0;\n /* Size of match buffer for literals/lengths. There are 4 reasons for\n * limiting lit_bufsize to 64K:\n * - frequencies can be kept in 16 bit counters\n * - if compression is not successful for the first block, all input\n * data is still in the window so we can still emit a stored block even\n * when input comes from standard input. (This can also be done for\n * all blocks if lit_bufsize is not greater than 32K.)\n * - if compression is not successful for a file smaller than 64K, we can\n * even emit a stored file instead of a stored block (saving 5 bytes).\n * This is applicable only for zip (not gzip or zlib).\n * - creating new Huffman trees less frequently may not provide fast\n * adaptation to changes in the input data statistics. (Take for\n * example a binary file with poorly compressible code followed by\n * a highly compressible string table.) Smaller buffer sizes give\n * fast adaptation but have of course the overhead of transmitting\n * trees more frequently.\n * - I can't count above 4\n */\n\n this.last_lit = 0; /* running index in l_buf */\n\n this.d_buf = 0;\n /* Buffer index for distances. To simplify the code, d_buf and l_buf have\n * the same number of elements. To use different lengths, an extra flag\n * array would be necessary.\n */\n\n this.opt_len = 0; /* bit length of current block with optimal trees */\n this.static_len = 0; /* bit length of current block with static trees */\n this.matches = 0; /* number of string matches in current block */\n this.insert = 0; /* bytes at end of window left to insert */\n\n\n this.bi_buf = 0;\n /* Output buffer. bits are inserted starting at the bottom (least\n * significant bits).\n */\n this.bi_valid = 0;\n /* Number of valid bits in bi_buf. All bits above the last valid bit\n * are always zero.\n */\n\n // Used for window memory init. We safely ignore it for JS. That makes\n // sense only for pointers and memory check tools.\n //this.high_water = 0;\n /* High water mark offset in window for initialized bytes -- bytes above\n * this are set to zero in order to avoid memory check warnings when\n * longest match routines access bytes past the input. This is then\n * updated to the new high water mark.\n */\n}\n\n\nconst deflateResetKeep = (strm) => {\n\n if (!strm || !strm.state) {\n return err(strm, Z_STREAM_ERROR$2);\n }\n\n strm.total_in = strm.total_out = 0;\n strm.data_type = Z_UNKNOWN;\n\n const s = strm.state;\n s.pending = 0;\n s.pending_out = 0;\n\n if (s.wrap < 0) {\n s.wrap = -s.wrap;\n /* was made negative by deflate(..., Z_FINISH); */\n }\n s.status = (s.wrap ? INIT_STATE : BUSY_STATE);\n strm.adler = (s.wrap === 2) ?\n 0 // crc32(0, Z_NULL, 0)\n :\n 1; // adler32(0, Z_NULL, 0)\n s.last_flush = Z_NO_FLUSH$2;\n _tr_init(s);\n return Z_OK$3;\n};\n\n\nconst deflateReset = (strm) => {\n\n const ret = deflateResetKeep(strm);\n if (ret === Z_OK$3) {\n lm_init(strm.state);\n }\n return ret;\n};\n\n\nconst deflateSetHeader = (strm, head) => {\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR$2; }\n if (strm.state.wrap !== 2) { return Z_STREAM_ERROR$2; }\n strm.state.gzhead = head;\n return Z_OK$3;\n};\n\n\nconst deflateInit2 = (strm, level, method, windowBits, memLevel, strategy) => {\n\n if (!strm) { // === Z_NULL\n return Z_STREAM_ERROR$2;\n }\n let wrap = 1;\n\n if (level === Z_DEFAULT_COMPRESSION$1) {\n level = 6;\n }\n\n if (windowBits < 0) { /* suppress zlib wrapper */\n wrap = 0;\n windowBits = -windowBits;\n }\n\n else if (windowBits > 15) {\n wrap = 2; /* write gzip wrapper instead */\n windowBits -= 16;\n }\n\n\n if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED$2 ||\n windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||\n strategy < 0 || strategy > Z_FIXED) {\n return err(strm, Z_STREAM_ERROR$2);\n }\n\n\n if (windowBits === 8) {\n windowBits = 9;\n }\n /* until 256-byte window bug fixed */\n\n const s = new DeflateState();\n\n strm.state = s;\n s.strm = strm;\n\n s.wrap = wrap;\n s.gzhead = null;\n s.w_bits = windowBits;\n s.w_size = 1 << s.w_bits;\n s.w_mask = s.w_size - 1;\n\n s.hash_bits = memLevel + 7;\n s.hash_size = 1 << s.hash_bits;\n s.hash_mask = s.hash_size - 1;\n s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);\n\n s.window = new Uint8Array(s.w_size * 2);\n s.head = new Uint16Array(s.hash_size);\n s.prev = new Uint16Array(s.w_size);\n\n // Don't need mem init magic for JS.\n //s.high_water = 0; /* nothing written to s->window yet */\n\n s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */\n\n s.pending_buf_size = s.lit_bufsize * 4;\n\n //overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2);\n //s->pending_buf = (uchf *) overlay;\n s.pending_buf = new Uint8Array(s.pending_buf_size);\n\n // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)\n //s->d_buf = overlay + s->lit_bufsize/sizeof(ush);\n s.d_buf = 1 * s.lit_bufsize;\n\n //s->l_buf = s->pending_buf + (1+sizeof(ush))*s->lit_bufsize;\n s.l_buf = (1 + 2) * s.lit_bufsize;\n\n s.level = level;\n s.strategy = strategy;\n s.method = method;\n\n return deflateReset(strm);\n};\n\nconst deflateInit = (strm, level) => {\n\n return deflateInit2(strm, level, Z_DEFLATED$2, MAX_WBITS$1, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY$1);\n};\n\n\nconst deflate$2 = (strm, flush) => {\n\n let beg, val; // for gzip header write only\n\n if (!strm || !strm.state ||\n flush > Z_BLOCK$1 || flush < 0) {\n return strm ? err(strm, Z_STREAM_ERROR$2) : Z_STREAM_ERROR$2;\n }\n\n const s = strm.state;\n\n if (!strm.output ||\n (!strm.input && strm.avail_in !== 0) ||\n (s.status === FINISH_STATE && flush !== Z_FINISH$3)) {\n return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR$1 : Z_STREAM_ERROR$2);\n }\n\n s.strm = strm; /* just in case */\n const old_flush = s.last_flush;\n s.last_flush = flush;\n\n /* Write the header */\n if (s.status === INIT_STATE) {\n\n if (s.wrap === 2) { // GZIP header\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n put_byte(s, 31);\n put_byte(s, 139);\n put_byte(s, 8);\n if (!s.gzhead) { // s->gzhead == Z_NULL\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, OS_CODE);\n s.status = BUSY_STATE;\n }\n else {\n put_byte(s, (s.gzhead.text ? 1 : 0) +\n (s.gzhead.hcrc ? 2 : 0) +\n (!s.gzhead.extra ? 0 : 4) +\n (!s.gzhead.name ? 0 : 8) +\n (!s.gzhead.comment ? 0 : 16)\n );\n put_byte(s, s.gzhead.time & 0xff);\n put_byte(s, (s.gzhead.time >> 8) & 0xff);\n put_byte(s, (s.gzhead.time >> 16) & 0xff);\n put_byte(s, (s.gzhead.time >> 24) & 0xff);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, s.gzhead.os & 0xff);\n if (s.gzhead.extra && s.gzhead.extra.length) {\n put_byte(s, s.gzhead.extra.length & 0xff);\n put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);\n }\n if (s.gzhead.hcrc) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending, 0);\n }\n s.gzindex = 0;\n s.status = EXTRA_STATE;\n }\n }\n else // DEFLATE header\n {\n let header = (Z_DEFLATED$2 + ((s.w_bits - 8) << 4)) << 8;\n let level_flags = -1;\n\n if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {\n level_flags = 0;\n } else if (s.level < 6) {\n level_flags = 1;\n } else if (s.level === 6) {\n level_flags = 2;\n } else {\n level_flags = 3;\n }\n header |= (level_flags << 6);\n if (s.strstart !== 0) { header |= PRESET_DICT; }\n header += 31 - (header % 31);\n\n s.status = BUSY_STATE;\n putShortMSB(s, header);\n\n /* Save the adler32 of the preset dictionary: */\n if (s.strstart !== 0) {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n strm.adler = 1; // adler32(0L, Z_NULL, 0);\n }\n }\n\n//#ifdef GZIP\n if (s.status === EXTRA_STATE) {\n if (s.gzhead.extra/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n\n while (s.gzindex < (s.gzhead.extra.length & 0xffff)) {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n break;\n }\n }\n put_byte(s, s.gzhead.extra[s.gzindex] & 0xff);\n s.gzindex++;\n }\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (s.gzindex === s.gzhead.extra.length) {\n s.gzindex = 0;\n s.status = NAME_STATE;\n }\n }\n else {\n s.status = NAME_STATE;\n }\n }\n if (s.status === NAME_STATE) {\n if (s.gzhead.name/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.name.length) {\n val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.gzindex = 0;\n s.status = COMMENT_STATE;\n }\n }\n else {\n s.status = COMMENT_STATE;\n }\n }\n if (s.status === COMMENT_STATE) {\n if (s.gzhead.comment/* != Z_NULL*/) {\n beg = s.pending; /* start of bytes to update crc */\n //int val;\n\n do {\n if (s.pending === s.pending_buf_size) {\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n flush_pending(strm);\n beg = s.pending;\n if (s.pending === s.pending_buf_size) {\n val = 1;\n break;\n }\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.comment.length) {\n val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n if (val === 0) {\n s.status = HCRC_STATE;\n }\n }\n else {\n s.status = HCRC_STATE;\n }\n }\n if (s.status === HCRC_STATE) {\n if (s.gzhead.hcrc) {\n if (s.pending + 2 > s.pending_buf_size) {\n flush_pending(strm);\n }\n if (s.pending + 2 <= s.pending_buf_size) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n s.status = BUSY_STATE;\n }\n }\n else {\n s.status = BUSY_STATE;\n }\n }\n//#endif\n\n /* Flush as much pending output as possible */\n if (s.pending !== 0) {\n flush_pending(strm);\n if (strm.avail_out === 0) {\n /* Since avail_out is 0, deflate will be called again with\n * more output space, but possibly with both pending and\n * avail_in equal to zero. There won't be anything to do,\n * but this is not an error situation so make sure we\n * return OK instead of BUF_ERROR at next call of deflate:\n */\n s.last_flush = -1;\n return Z_OK$3;\n }\n\n /* Make sure there is something to do and avoid duplicate consecutive\n * flushes. For repeated and useless calls with Z_FINISH, we keep\n * returning Z_STREAM_END instead of Z_BUF_ERROR.\n */\n } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&\n flush !== Z_FINISH$3) {\n return err(strm, Z_BUF_ERROR$1);\n }\n\n /* User must not provide more input after the first FINISH: */\n if (s.status === FINISH_STATE && strm.avail_in !== 0) {\n return err(strm, Z_BUF_ERROR$1);\n }\n\n /* Start a new block or continue the current one.\n */\n if (strm.avail_in !== 0 || s.lookahead !== 0 ||\n (flush !== Z_NO_FLUSH$2 && s.status !== FINISH_STATE)) {\n let bstate = (s.strategy === Z_HUFFMAN_ONLY) ? deflate_huff(s, flush) :\n (s.strategy === Z_RLE ? deflate_rle(s, flush) :\n configuration_table[s.level].func(s, flush));\n\n if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {\n s.status = FINISH_STATE;\n }\n if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {\n if (strm.avail_out === 0) {\n s.last_flush = -1;\n /* avoid BUF_ERROR next call, see above */\n }\n return Z_OK$3;\n /* If flush != Z_NO_FLUSH && avail_out == 0, the next call\n * of deflate should use the same flush parameter to make sure\n * that the flush is complete. So we don't have to output an\n * empty block here, this will be done at next call. This also\n * ensures that for a very small output buffer, we emit at most\n * one empty block.\n */\n }\n if (bstate === BS_BLOCK_DONE) {\n if (flush === Z_PARTIAL_FLUSH) {\n _tr_align(s);\n }\n else if (flush !== Z_BLOCK$1) { /* FULL_FLUSH or SYNC_FLUSH */\n\n _tr_stored_block(s, 0, 0, false);\n /* For a full flush, this empty block will be recognized\n * as a special marker by inflate_sync().\n */\n if (flush === Z_FULL_FLUSH$1) {\n /*** CLEAR_HASH(s); ***/ /* forget history */\n zero(s.head); // Fill with NIL (= 0);\n\n if (s.lookahead === 0) {\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n }\n }\n flush_pending(strm);\n if (strm.avail_out === 0) {\n s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */\n return Z_OK$3;\n }\n }\n }\n //Assert(strm->avail_out > 0, \"bug2\");\n //if (strm.avail_out <= 0) { throw new Error(\"bug2\");}\n\n if (flush !== Z_FINISH$3) { return Z_OK$3; }\n if (s.wrap <= 0) { return Z_STREAM_END$3; }\n\n /* Write the trailer */\n if (s.wrap === 2) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n put_byte(s, (strm.adler >> 16) & 0xff);\n put_byte(s, (strm.adler >> 24) & 0xff);\n put_byte(s, strm.total_in & 0xff);\n put_byte(s, (strm.total_in >> 8) & 0xff);\n put_byte(s, (strm.total_in >> 16) & 0xff);\n put_byte(s, (strm.total_in >> 24) & 0xff);\n }\n else\n {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n\n flush_pending(strm);\n /* If avail_out is zero, the application will call deflate again\n * to flush the rest.\n */\n if (s.wrap > 0) { s.wrap = -s.wrap; }\n /* write the trailer only once! */\n return s.pending !== 0 ? Z_OK$3 : Z_STREAM_END$3;\n};\n\n\nconst deflateEnd = (strm) => {\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR$2;\n }\n\n const status = strm.state.status;\n if (status !== INIT_STATE &&\n status !== EXTRA_STATE &&\n status !== NAME_STATE &&\n status !== COMMENT_STATE &&\n status !== HCRC_STATE &&\n status !== BUSY_STATE &&\n status !== FINISH_STATE\n ) {\n return err(strm, Z_STREAM_ERROR$2);\n }\n\n strm.state = null;\n\n return status === BUSY_STATE ? err(strm, Z_DATA_ERROR$2) : Z_OK$3;\n};\n\n\n/* =========================================================================\n * Initializes the compression dictionary from the given byte\n * sequence without producing any compressed output.\n */\nconst deflateSetDictionary = (strm, dictionary) => {\n\n let dictLength = dictionary.length;\n\n if (!strm/*== Z_NULL*/ || !strm.state/*== Z_NULL*/) {\n return Z_STREAM_ERROR$2;\n }\n\n const s = strm.state;\n const wrap = s.wrap;\n\n if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {\n return Z_STREAM_ERROR$2;\n }\n\n /* when using zlib wrappers, compute Adler-32 for provided dictionary */\n if (wrap === 1) {\n /* adler32(strm->adler, dictionary, dictLength); */\n strm.adler = adler32_1(strm.adler, dictionary, dictLength, 0);\n }\n\n s.wrap = 0; /* avoid computing Adler-32 in read_buf */\n\n /* if dictionary would fill window, just replace the history */\n if (dictLength >= s.w_size) {\n if (wrap === 0) { /* already empty otherwise */\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n /* use the tail */\n // dictionary = dictionary.slice(dictLength - s.w_size);\n let tmpDict = new Uint8Array(s.w_size);\n tmpDict.set(dictionary.subarray(dictLength - s.w_size, dictLength), 0);\n dictionary = tmpDict;\n dictLength = s.w_size;\n }\n /* insert dictionary into window and hash */\n const avail = strm.avail_in;\n const next = strm.next_in;\n const input = strm.input;\n strm.avail_in = dictLength;\n strm.next_in = 0;\n strm.input = dictionary;\n fill_window(s);\n while (s.lookahead >= MIN_MATCH) {\n let str = s.strstart;\n let n = s.lookahead - (MIN_MATCH - 1);\n do {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n\n s.head[s.ins_h] = str;\n str++;\n } while (--n);\n s.strstart = str;\n s.lookahead = MIN_MATCH - 1;\n fill_window(s);\n }\n s.strstart += s.lookahead;\n s.block_start = s.strstart;\n s.insert = s.lookahead;\n s.lookahead = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n strm.next_in = next;\n strm.input = input;\n strm.avail_in = avail;\n s.wrap = wrap;\n return Z_OK$3;\n};\n\n\nvar deflateInit_1 = deflateInit;\nvar deflateInit2_1 = deflateInit2;\nvar deflateReset_1 = deflateReset;\nvar deflateResetKeep_1 = deflateResetKeep;\nvar deflateSetHeader_1 = deflateSetHeader;\nvar deflate_2$1 = deflate$2;\nvar deflateEnd_1 = deflateEnd;\nvar deflateSetDictionary_1 = deflateSetDictionary;\nvar deflateInfo = 'pako deflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.deflateBound = deflateBound;\nmodule.exports.deflateCopy = deflateCopy;\nmodule.exports.deflateParams = deflateParams;\nmodule.exports.deflatePending = deflatePending;\nmodule.exports.deflatePrime = deflatePrime;\nmodule.exports.deflateTune = deflateTune;\n*/\n\nvar deflate_1$2 = {\n\tdeflateInit: deflateInit_1,\n\tdeflateInit2: deflateInit2_1,\n\tdeflateReset: deflateReset_1,\n\tdeflateResetKeep: deflateResetKeep_1,\n\tdeflateSetHeader: deflateSetHeader_1,\n\tdeflate: deflate_2$1,\n\tdeflateEnd: deflateEnd_1,\n\tdeflateSetDictionary: deflateSetDictionary_1,\n\tdeflateInfo: deflateInfo\n};\n\nconst _has = (obj, key) => {\n return Object.prototype.hasOwnProperty.call(obj, key);\n};\n\nvar assign = function (obj /*from1, from2, from3, ...*/) {\n const sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n const source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (const p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// Join array of chunks to single array.\nvar flattenChunks = (chunks) => {\n // calculate data length\n let len = 0;\n\n for (let i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n const result = new Uint8Array(len);\n\n for (let i = 0, pos = 0, l = chunks.length; i < l; i++) {\n let chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n};\n\nvar common = {\n\tassign: assign,\n\tflattenChunks: flattenChunks\n};\n\n// String encode/decode helpers\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nlet STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nconst _utf8len = new Uint8Array(256);\nfor (let q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nvar string2buf = (str) => {\n if (typeof TextEncoder === 'function' && TextEncoder.prototype.encode) {\n return new TextEncoder().encode(str);\n }\n\n let buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new Uint8Array(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper\nconst buf2binstring = (buf, len) => {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if (buf.subarray && STR_APPLY_UIA_OK) {\n return String.fromCharCode.apply(null, buf.length === len ? buf : buf.subarray(0, len));\n }\n }\n\n let result = '';\n for (let i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n};\n\n\n// convert array to string\nvar buf2string = (buf, max) => {\n const len = max || buf.length;\n\n if (typeof TextDecoder === 'function' && TextDecoder.prototype.decode) {\n return new TextDecoder().decode(buf.subarray(0, max));\n }\n\n let i, out;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n const utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n let c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n let c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nvar utf8border = (buf, max) => {\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n let pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n\nvar strings = {\n\tstring2buf: string2buf,\n\tbuf2string: buf2string,\n\tutf8border: utf8border\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nvar zstream = ZStream;\n\nconst toString$1 = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH: Z_NO_FLUSH$1, Z_SYNC_FLUSH, Z_FULL_FLUSH, Z_FINISH: Z_FINISH$2,\n Z_OK: Z_OK$2, Z_STREAM_END: Z_STREAM_END$2,\n Z_DEFAULT_COMPRESSION,\n Z_DEFAULT_STRATEGY,\n Z_DEFLATED: Z_DEFLATED$1\n} = constants$2;\n\n/* ===========================================================================*/\n\n\n/**\n * class Deflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[deflate]],\n * [[deflateRaw]] and [[gzip]].\n **/\n\n/* internal\n * Deflate.chunks -> Array\n *\n * Chunks of output data, if [[Deflate#onData]] not overridden.\n **/\n\n/**\n * Deflate.result -> Uint8Array\n *\n * Compressed result, generated by default [[Deflate#onData]]\n * and [[Deflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Deflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Deflate.err -> Number\n *\n * Error code after deflate finished. 0 (Z_OK) on success.\n * You will not need it in real life, because deflate errors\n * are possible only on wrong options or bad `onData` / `onEnd`\n * custom handlers.\n **/\n\n/**\n * Deflate.msg -> String\n *\n * Error message, if [[Deflate.err]] != 0\n **/\n\n\n/**\n * new Deflate(options)\n * - options (Object): zlib deflate options.\n *\n * Creates new deflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `level`\n * - `windowBits`\n * - `memLevel`\n * - `strategy`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw deflate\n * - `gzip` (Boolean) - create gzip wrapper\n * - `header` (Object) - custom header for gzip\n * - `text` (Boolean) - true if compressed data believed to be text\n * - `time` (Number) - modification time, unix timestamp\n * - `os` (Number) - operation system code\n * - `extra` (Array) - array of bytes with extra data (max 65536)\n * - `name` (String) - file name (binary string)\n * - `comment` (String) - comment (binary string)\n * - `hcrc` (Boolean) - true if header crc should be added\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * , chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const deflate = new pako.Deflate({ level: 3});\n *\n * deflate.push(chunk1, false);\n * deflate.push(chunk2, true); // true -> last chunk\n *\n * if (deflate.err) { throw new Error(deflate.err); }\n *\n * console.log(deflate.result);\n * ```\n **/\nfunction Deflate$1(options) {\n this.options = common.assign({\n level: Z_DEFAULT_COMPRESSION,\n method: Z_DEFLATED$1,\n chunkSize: 16384,\n windowBits: 15,\n memLevel: 8,\n strategy: Z_DEFAULT_STRATEGY\n }, options || {});\n\n let opt = this.options;\n\n if (opt.raw && (opt.windowBits > 0)) {\n opt.windowBits = -opt.windowBits;\n }\n\n else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {\n opt.windowBits += 16;\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new zstream();\n this.strm.avail_out = 0;\n\n let status = deflate_1$2.deflateInit2(\n this.strm,\n opt.level,\n opt.method,\n opt.windowBits,\n opt.memLevel,\n opt.strategy\n );\n\n if (status !== Z_OK$2) {\n throw new Error(messages[status]);\n }\n\n if (opt.header) {\n deflate_1$2.deflateSetHeader(this.strm, opt.header);\n }\n\n if (opt.dictionary) {\n let dict;\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n // If we need to compress text, change encoding to utf8.\n dict = strings.string2buf(opt.dictionary);\n } else if (toString$1.call(opt.dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(opt.dictionary);\n } else {\n dict = opt.dictionary;\n }\n\n status = deflate_1$2.deflateSetDictionary(this.strm, dict);\n\n if (status !== Z_OK$2) {\n throw new Error(messages[status]);\n }\n\n this._dict_set = true;\n }\n}\n\n/**\n * Deflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer|String): input data. Strings will be\n * converted to utf8 byte sequence.\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with\n * new compressed chunks. Returns `true` on success. The last data block must\n * have `flush_mode` Z_FINISH (or `true`). That will flush internal pending\n * buffers and call [[Deflate#onEnd]].\n *\n * On fail call [[Deflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nDeflate$1.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n let status, _flush_mode;\n\n if (this.ended) { return false; }\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH$2 : Z_NO_FLUSH$1;\n\n // Convert data if needed\n if (typeof data === 'string') {\n // If we need to compress text, change encoding to utf8.\n strm.input = strings.string2buf(data);\n } else if (toString$1.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n // Make sure avail_out > 6 to avoid repeating markers\n if ((_flush_mode === Z_SYNC_FLUSH || _flush_mode === Z_FULL_FLUSH) && strm.avail_out <= 6) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n status = deflate_1$2.deflate(strm, _flush_mode);\n\n // Ended => flush and finish\n if (status === Z_STREAM_END$2) {\n if (strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n }\n status = deflate_1$2.deflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK$2;\n }\n\n // Flush if out buffer full\n if (strm.avail_out === 0) {\n this.onData(strm.output);\n continue;\n }\n\n // Flush if requested and has data\n if (_flush_mode > 0 && strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Deflate#onData(chunk) -> Void\n * - chunk (Uint8Array): output data.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nDeflate$1.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Deflate#onEnd(status) -> Void\n * - status (Number): deflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called once after you tell deflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nDeflate$1.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK$2) {\n this.result = common.flattenChunks(this.chunks);\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * deflate(data[, options]) -> Uint8Array\n * - data (Uint8Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * Compress `data` with deflate algorithm and `options`.\n *\n * Supported options are:\n *\n * - level\n * - windowBits\n * - memLevel\n * - strategy\n * - dictionary\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const data = new Uint8Array([1,2,3,4,5,6,7,8,9]);\n *\n * console.log(pako.deflate(data));\n * ```\n **/\nfunction deflate$1(input, options) {\n const deflator = new Deflate$1(options);\n\n deflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (deflator.err) { throw deflator.msg || messages[deflator.err]; }\n\n return deflator.result;\n}\n\n\n/**\n * deflateRaw(data[, options]) -> Uint8Array\n * - data (Uint8Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction deflateRaw$1(input, options) {\n options = options || {};\n options.raw = true;\n return deflate$1(input, options);\n}\n\n\n/**\n * gzip(data[, options]) -> Uint8Array\n * - data (Uint8Array|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but create gzip wrapper instead of\n * deflate one.\n **/\nfunction gzip$1(input, options) {\n options = options || {};\n options.gzip = true;\n return deflate$1(input, options);\n}\n\n\nvar Deflate_1$1 = Deflate$1;\nvar deflate_2 = deflate$1;\nvar deflateRaw_1$1 = deflateRaw$1;\nvar gzip_1$1 = gzip$1;\nvar constants$1 = constants$2;\n\nvar deflate_1$1 = {\n\tDeflate: Deflate_1$1,\n\tdeflate: deflate_2,\n\tdeflateRaw: deflateRaw_1$1,\n\tgzip: gzip_1$1,\n\tconstants: constants$1\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nconst BAD$1 = 30; /* got a data error -- remain here until reset */\nconst TYPE$1 = 12; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nvar inffast = function inflate_fast(strm, start) {\n let _in; /* local strm.input */\n let last; /* have enough input while in < last */\n let _out; /* local strm.output */\n let beg; /* inflate()'s initial strm.output */\n let end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n let dmax; /* maximum distance from zlib header */\n//#endif\n let wsize; /* window size or zero if not using window */\n let whave; /* valid bytes in the window */\n let wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n let s_window; /* allocated sliding window, if wsize != 0 */\n let hold; /* local strm.hold */\n let bits; /* local strm.bits */\n let lcode; /* local strm.lencode */\n let dcode; /* local strm.distcode */\n let lmask; /* mask for first level of length codes */\n let dmask; /* mask for first level of distance codes */\n let here; /* retrieved table entry */\n let op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n let len; /* match length, unused bytes */\n let dist; /* match distance */\n let from; /* where to copy match from */\n let from_source;\n\n\n let input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n const state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD$1;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD$1;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD$1;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE$1;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD$1;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst MAXBITS = 15;\nconst ENOUGH_LENS$1 = 852;\nconst ENOUGH_DISTS$1 = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst CODES$1 = 0;\nconst LENS$1 = 1;\nconst DISTS$1 = 2;\n\nconst lbase = new Uint16Array([ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n]);\n\nconst lext = new Uint8Array([ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n]);\n\nconst dbase = new Uint16Array([ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n]);\n\nconst dext = new Uint8Array([ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n]);\n\nconst inflate_table = (type, lens, lens_index, codes, table, table_index, work, opts) =>\n{\n const bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n let len = 0; /* a code's length in bits */\n let sym = 0; /* index of code symbols */\n let min = 0, max = 0; /* minimum and maximum code lengths */\n let root = 0; /* number of index bits for root table */\n let curr = 0; /* number of index bits for current table */\n let drop = 0; /* code bits to drop for sub-table */\n let left = 0; /* number of prefix codes available */\n let used = 0; /* code entries in table used */\n let huff = 0; /* Huffman code */\n let incr; /* for incrementing code, index */\n let fill; /* index for replicating entries */\n let low; /* low bits for current root entry */\n let mask; /* mask for low root bits */\n let next; /* next available space in table */\n let base = null; /* base value table to use */\n let base_index = 0;\n// let shoextra; /* extra bits table to use */\n let end; /* use base and extra for symbol > end */\n const count = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n const offs = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n let extra = null;\n let extra_index = 0;\n\n let here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES$1 || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES$1) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n\n } else if (type === LENS$1) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS$1 && used > ENOUGH_LENS$1) ||\n (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS$1 && used > ENOUGH_LENS$1) ||\n (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n\n\nvar inftrees = inflate_table;\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n\n\n\n\n\nconst CODES = 0;\nconst LENS = 1;\nconst DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_FINISH: Z_FINISH$1, Z_BLOCK, Z_TREES,\n Z_OK: Z_OK$1, Z_STREAM_END: Z_STREAM_END$1, Z_NEED_DICT: Z_NEED_DICT$1, Z_STREAM_ERROR: Z_STREAM_ERROR$1, Z_DATA_ERROR: Z_DATA_ERROR$1, Z_MEM_ERROR: Z_MEM_ERROR$1, Z_BUF_ERROR,\n Z_DEFLATED\n} = constants$2;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nconst HEAD = 1; /* i: waiting for magic header */\nconst FLAGS = 2; /* i: waiting for method and flags (gzip) */\nconst TIME = 3; /* i: waiting for modification time (gzip) */\nconst OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nconst EXLEN = 5; /* i: waiting for extra length (gzip) */\nconst EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nconst NAME = 7; /* i: waiting for end of file name (gzip) */\nconst COMMENT = 8; /* i: waiting for end of comment (gzip) */\nconst HCRC = 9; /* i: waiting for header crc (gzip) */\nconst DICTID = 10; /* i: waiting for dictionary check value */\nconst DICT = 11; /* waiting for inflateSetDictionary() call */\nconst TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nconst TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nconst STORED = 14; /* i: waiting for stored size (length and complement) */\nconst COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nconst COPY = 16; /* i/o: waiting for input or output to copy stored block */\nconst TABLE = 17; /* i: waiting for dynamic block table lengths */\nconst LENLENS = 18; /* i: waiting for code length code lengths */\nconst CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nconst LEN_ = 20; /* i: same as LEN below, but only first time in */\nconst LEN = 21; /* i: waiting for length/lit/eob code */\nconst LENEXT = 22; /* i: waiting for length extra bits */\nconst DIST = 23; /* i: waiting for distance code */\nconst DISTEXT = 24; /* i: waiting for distance extra bits */\nconst MATCH = 25; /* o: waiting for output space to copy string */\nconst LIT = 26; /* o: waiting for output space to write literal */\nconst CHECK = 27; /* i: waiting for 32-bit check value */\nconst LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nconst DONE = 29; /* finished check, done -- remain here until reset */\nconst BAD = 30; /* got a data error -- remain here until reset */\nconst MEM = 31; /* got an inflate() memory error -- remain here until reset */\nconst SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nconst ENOUGH_LENS = 852;\nconst ENOUGH_DISTS = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst MAX_WBITS = 15;\n/* 32K LZ77 window */\nconst DEF_WBITS = MAX_WBITS;\n\n\nconst zswap32 = (q) => {\n\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n};\n\n\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new Uint16Array(320); /* temporary storage for code lengths */\n this.work = new Uint16Array(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new Int32Array(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\n\nconst inflateResetKeep = (strm) => {\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new Int32Array(ENOUGH_LENS);\n state.distcode = state.distdyn = new Int32Array(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK$1;\n};\n\n\nconst inflateReset = (strm) => {\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n};\n\n\nconst inflateReset2 = (strm, windowBits) => {\n let wrap;\n\n /* get the state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR$1;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n};\n\n\nconst inflateInit2 = (strm, windowBits) => {\n\n if (!strm) { return Z_STREAM_ERROR$1; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n const state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null/*Z_NULL*/;\n const ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK$1) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n};\n\n\nconst inflateInit = (strm) => {\n\n return inflateInit2(strm, DEF_WBITS);\n};\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nlet virgin = true;\n\nlet lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\n\nconst fixedtables = (state) => {\n\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n lenfix = new Int32Array(512);\n distfix = new Int32Array(32);\n\n /* literal/length table */\n let sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inftrees(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inftrees(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n};\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nconst updatewindow = (strm, src, end, copy) => {\n\n let dist;\n const state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new Uint8Array(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n state.window.set(src.subarray(end - state.wsize, end), 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n state.window.set(src.subarray(end - copy, end - copy + dist), state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n state.window.set(src.subarray(end - copy, end), 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n};\n\n\nconst inflate$2 = (strm, flush) => {\n\n let state;\n let input, output; // input/output buffers\n let next; /* next input INDEX */\n let put; /* next output INDEX */\n let have, left; /* available input and output */\n let hold; /* bit buffer */\n let bits; /* bits in bit buffer */\n let _in, _out; /* save starting available input and output */\n let copy; /* number of stored or match bytes to copy */\n let from; /* where to copy match bytes from */\n let from_source;\n let here = 0; /* current decoding table entry */\n let here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //let last; /* parent table entry */\n let last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n let len; /* length to copy for repeats, bits to drop */\n let ret; /* return code */\n const hbuf = new Uint8Array(4); /* buffer for gzip header crc calculation */\n let opts;\n\n let n; // temporary variable for NEED_BITS\n\n const order = /* permutation of code lengths */\n new Uint8Array([ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ]);\n\n\n if (!strm || !strm.state || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR$1;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK$1;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n\n // !!! pako patch. Force use `options.windowBits` if passed.\n // Required to always use max window size by default.\n state.dmax = 1 << state.wbits;\n //state.dmax = 1 << len;\n\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32_1(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Uint8Array(state.head.extra_len);\n }\n state.head.extra.set(\n input.subarray(\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n next + copy\n ),\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if (state.flags & 0x0200) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT$1;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n output.set(input.subarray(next, next + copy), put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inftrees(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inftrees(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inftrees(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inffast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n (state.flags ? crc32_1(state.check, output, _out, put - _out) : adler32_1(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END$1;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR$1;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR$1;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR$1;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH$1))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) ;\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32_1(state.check, output, _out, strm.next_out - _out) : adler32_1(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH$1) && ret === Z_OK$1) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n};\n\n\nconst inflateEnd = (strm) => {\n\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR$1;\n }\n\n let state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK$1;\n};\n\n\nconst inflateGetHeader = (strm, head) => {\n\n /* check state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR$1; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK$1;\n};\n\n\nconst inflateSetDictionary = (strm, dictionary) => {\n const dictLength = dictionary.length;\n\n let state;\n let dictid;\n let ret;\n\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR$1; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR$1;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32_1(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR$1;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR$1;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK$1;\n};\n\n\nvar inflateReset_1 = inflateReset;\nvar inflateReset2_1 = inflateReset2;\nvar inflateResetKeep_1 = inflateResetKeep;\nvar inflateInit_1 = inflateInit;\nvar inflateInit2_1 = inflateInit2;\nvar inflate_2$1 = inflate$2;\nvar inflateEnd_1 = inflateEnd;\nvar inflateGetHeader_1 = inflateGetHeader;\nvar inflateSetDictionary_1 = inflateSetDictionary;\nvar inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.inflateCopy = inflateCopy;\nmodule.exports.inflateGetDictionary = inflateGetDictionary;\nmodule.exports.inflateMark = inflateMark;\nmodule.exports.inflatePrime = inflatePrime;\nmodule.exports.inflateSync = inflateSync;\nmodule.exports.inflateSyncPoint = inflateSyncPoint;\nmodule.exports.inflateUndermine = inflateUndermine;\n*/\n\nvar inflate_1$2 = {\n\tinflateReset: inflateReset_1,\n\tinflateReset2: inflateReset2_1,\n\tinflateResetKeep: inflateResetKeep_1,\n\tinflateInit: inflateInit_1,\n\tinflateInit2: inflateInit2_1,\n\tinflate: inflate_2$1,\n\tinflateEnd: inflateEnd_1,\n\tinflateGetHeader: inflateGetHeader_1,\n\tinflateSetDictionary: inflateSetDictionary_1,\n\tinflateInfo: inflateInfo\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nvar gzheader = GZheader;\n\nconst toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH, Z_FINISH,\n Z_OK, Z_STREAM_END, Z_NEED_DICT, Z_STREAM_ERROR, Z_DATA_ERROR, Z_MEM_ERROR\n} = constants$2;\n\n/* ===========================================================================*/\n\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * const chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate$1(options) {\n this.options = common.assign({\n chunkSize: 1024 * 64,\n windowBits: 15,\n to: ''\n }, options || {});\n\n const opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new zstream();\n this.strm.avail_out = 0;\n\n let status = inflate_1$2.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== Z_OK) {\n throw new Error(messages[status]);\n }\n\n this.header = new gzheader();\n\n inflate_1$2.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = inflate_1$2.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== Z_OK) {\n throw new Error(messages[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer): input data\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE\n * flush modes. See constants. Skipped or `false` means Z_NO_FLUSH,\n * `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. If end of stream detected,\n * [[Inflate#onEnd]] will be called.\n *\n * `flush_mode` is not needed for normal operation, because end of stream\n * detected automatically. You may try to use it for advanced things, but\n * this functionality was not tested.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate$1.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n const dictionary = this.options.dictionary;\n let status, _flush_mode, last_avail_out;\n\n if (this.ended) return false;\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH : Z_NO_FLUSH;\n\n // Convert data if needed\n if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = inflate_1$2.inflate(strm, _flush_mode);\n\n if (status === Z_NEED_DICT && dictionary) {\n status = inflate_1$2.inflateSetDictionary(strm, dictionary);\n\n if (status === Z_OK) {\n status = inflate_1$2.inflate(strm, _flush_mode);\n } else if (status === Z_DATA_ERROR) {\n // Replace code with more verbose\n status = Z_NEED_DICT;\n }\n }\n\n // Skip snyc markers if more data follows and not raw mode\n while (strm.avail_in > 0 &&\n status === Z_STREAM_END &&\n strm.state.wrap > 0 &&\n data[strm.next_in] !== 0)\n {\n inflate_1$2.inflateReset(strm);\n status = inflate_1$2.inflate(strm, _flush_mode);\n }\n\n switch (status) {\n case Z_STREAM_ERROR:\n case Z_DATA_ERROR:\n case Z_NEED_DICT:\n case Z_MEM_ERROR:\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n // Remember real `avail_out` value, because we may patch out buffer content\n // to align utf8 strings boundaries.\n last_avail_out = strm.avail_out;\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === Z_STREAM_END) {\n\n if (this.options.to === 'string') {\n\n let next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n let tail = strm.next_out - next_out_utf8;\n let utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail & realign counters\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) strm.output.set(strm.output.subarray(next_out_utf8, next_out_utf8 + tail), 0);\n\n this.onData(utf8str);\n\n } else {\n this.onData(strm.output.length === strm.next_out ? strm.output : strm.output.subarray(0, strm.next_out));\n }\n }\n }\n\n // Must repeat iteration if out buffer is full\n if (status === Z_OK && last_avail_out === 0) continue;\n\n // Finalize if end of stream reached.\n if (status === Z_STREAM_END) {\n status = inflate_1$2.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return true;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|String): output data. When string output requested,\n * each chunk will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate$1.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate$1.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n this.result = this.chunks.join('');\n } else {\n this.result = common.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|String\n * - data (Uint8Array): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako');\n * const input = pako.deflate(new Uint8Array([1,2,3,4,5,6,7,8,9]));\n * let output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err) {\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate$1(input, options) {\n const inflator = new Inflate$1(options);\n\n inflator.push(input);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) throw inflator.msg || messages[inflator.err];\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|String\n * - data (Uint8Array): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw$1(input, options) {\n options = options || {};\n options.raw = true;\n return inflate$1(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|String\n * - data (Uint8Array): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nvar Inflate_1$1 = Inflate$1;\nvar inflate_2 = inflate$1;\nvar inflateRaw_1$1 = inflateRaw$1;\nvar ungzip$1 = inflate$1;\nvar constants = constants$2;\n\nvar inflate_1$1 = {\n\tInflate: Inflate_1$1,\n\tinflate: inflate_2,\n\tinflateRaw: inflateRaw_1$1,\n\tungzip: ungzip$1,\n\tconstants: constants\n};\n\nconst { Deflate, deflate, deflateRaw, gzip } = deflate_1$1;\n\nconst { Inflate, inflate, inflateRaw, ungzip } = inflate_1$1;\n\n\n\nvar Deflate_1 = Deflate;\nvar deflate_1 = deflate;\nvar deflateRaw_1 = deflateRaw;\nvar gzip_1 = gzip;\nvar Inflate_1 = Inflate;\nvar inflate_1 = inflate;\nvar inflateRaw_1 = inflateRaw;\nvar ungzip_1 = ungzip;\nvar constants_1 = constants$2;\n\nvar pako = {\n\tDeflate: Deflate_1,\n\tdeflate: deflate_1,\n\tdeflateRaw: deflateRaw_1,\n\tgzip: gzip_1,\n\tInflate: Inflate_1,\n\tinflate: inflate_1,\n\tinflateRaw: inflateRaw_1,\n\tungzip: ungzip_1,\n\tconstants: constants_1\n};\n\nexport { Deflate_1 as Deflate, Inflate_1 as Inflate, constants_1 as constants, pako as default, deflate_1 as deflate, deflateRaw_1 as deflateRaw, gzip_1 as gzip, inflate_1 as inflate, inflateRaw_1 as inflateRaw, ungzip_1 as ungzip };\n","export function splitArgsAndCtx(idlIx, args) {\n var _a, _b;\n let options = {};\n const inputLen = idlIx.args ? idlIx.args.length : 0;\n if (args.length > inputLen) {\n if (args.length !== inputLen + 1) {\n throw new Error(`provided too many arguments ${args} to instruction ${idlIx === null || idlIx === void 0 ? void 0 : idlIx.name} expecting: ${(_b = (_a = idlIx.args) === null || _a === void 0 ? void 0 : _a.map((a) => a.name)) !== null && _b !== void 0 ? _b : []}`);\n }\n options = args.pop();\n }\n return [args, options];\n}\n//# sourceMappingURL=context.js.map","import { TransactionInstruction, } from \"@solana/web3.js\";\nimport { IdlError } from \"../../error\";\nimport { toInstruction, validateAccounts, translateAddress, } from \"../common\";\nimport { splitArgsAndCtx } from \"../context\";\nexport default class InstructionNamespaceFactory {\n static build(idlIx, encodeFn, programId) {\n if (idlIx.name === \"_inner\") {\n throw new IdlError(\"the _inner name is reserved\");\n }\n const ix = (...args) => {\n const [ixArgs, ctx] = splitArgsAndCtx(idlIx, [...args]);\n validateAccounts(idlIx.accounts, ctx.accounts);\n validateInstruction(idlIx, ...args);\n const keys = ix.accounts(ctx.accounts);\n if (ctx.remainingAccounts !== undefined) {\n keys.push(...ctx.remainingAccounts);\n }\n if (ctx.__private && ctx.__private.logAccounts) {\n console.log(\"Outgoing account metas:\", keys);\n }\n return new TransactionInstruction({\n keys,\n programId,\n data: encodeFn(idlIx.name, toInstruction(idlIx, ...ixArgs)),\n });\n };\n // Utility fn for ordering the accounts for this instruction.\n ix[\"accounts\"] = (accs) => {\n return InstructionNamespaceFactory.accountsArray(accs, idlIx.accounts);\n };\n return ix;\n }\n static accountsArray(ctx, accounts) {\n if (!ctx) {\n return [];\n }\n return accounts\n .map((acc) => {\n // Nested accounts.\n const nestedAccounts = \"accounts\" in acc ? acc.accounts : undefined;\n if (nestedAccounts !== undefined) {\n const rpcAccs = ctx[acc.name];\n return InstructionNamespaceFactory.accountsArray(rpcAccs, acc.accounts).flat();\n }\n else {\n const account = acc;\n return {\n pubkey: translateAddress(ctx[acc.name]),\n isWritable: account.isMut,\n isSigner: account.isSigner,\n };\n }\n })\n .flat();\n }\n}\n// Throws error if any argument required for the `ix` is not given.\nfunction validateInstruction(ix, ...args) {\n // todo\n}\n//# sourceMappingURL=instruction.js.map","import { splitArgsAndCtx } from \"../context\";\nimport { ProgramError } from \"../../error\";\nexport default class RpcFactory {\n static build(idlIx, txFn, idlErrors, provider) {\n const rpc = async (...args) => {\n const tx = txFn(...args);\n const [, ctx] = splitArgsAndCtx(idlIx, [...args]);\n try {\n const txSig = await provider.send(tx, ctx.signers, ctx.options);\n return txSig;\n }\n catch (err) {\n console.log(\"Translating error\", err);\n let translatedErr = ProgramError.parse(err, idlErrors);\n if (translatedErr === null) {\n throw err;\n }\n throw translatedErr;\n }\n };\n return rpc;\n }\n}\n//# sourceMappingURL=rpc.js.map","import { Transaction } from \"@solana/web3.js\";\nimport { splitArgsAndCtx } from \"../context\";\nexport default class TransactionFactory {\n static build(idlIx, ixFn) {\n const txFn = (...args) => {\n var _a;\n const [, ctx] = splitArgsAndCtx(idlIx, [...args]);\n const tx = new Transaction();\n (_a = ctx.instructions) === null || _a === void 0 ? void 0 : _a.forEach((ix) => tx.add(ix));\n tx.add(ixFn(...args));\n return tx;\n };\n return txFn;\n }\n}\n//# sourceMappingURL=transaction.js.map","import EventEmitter from \"eventemitter3\";\nimport camelCase from \"camelcase\";\nimport { SystemProgram, } from \"@solana/web3.js\";\nimport Coder, { stateDiscriminator } from \"../../coder\";\nimport { getProvider } from \"../../\";\nimport { validateAccounts, parseIdlErrors } from \"../common\";\nimport { findProgramAddressSync, createWithSeedSync } from \"../../utils/pubkey\";\nimport InstructionNamespaceFactory from \"./instruction\";\nimport RpcNamespaceFactory from \"./rpc\";\nimport TransactionNamespaceFactory from \"./transaction\";\nexport default class StateFactory {\n static build(idl, coder, programId, provider) {\n if (idl.state === undefined) {\n return undefined;\n }\n return new StateClient(idl, programId, provider, coder);\n }\n}\n/**\n * A client for the program state. Similar to the base [[Program]] client,\n * one can use this to send transactions and read accounts for the state\n * abstraction.\n */\nexport class StateClient {\n constructor(idl, programId, \n /**\n * Returns the client's wallet and network provider.\n */\n provider = getProvider(), \n /**\n * Returns the coder.\n */\n coder = new Coder(idl)) {\n this.provider = provider;\n this.coder = coder;\n this._idl = idl;\n this._programId = programId;\n this._address = programStateAddress(programId);\n this._sub = null;\n // Build namespaces.\n const [instruction, transaction, rpc] = (() => {\n var _a;\n let instruction = {};\n let transaction = {};\n let rpc = {};\n (_a = idl.state) === null || _a === void 0 ? void 0 : _a.methods.forEach((m) => {\n // Build instruction method.\n const ixItem = InstructionNamespaceFactory.build(m, (ixName, ix) => coder.instruction.encodeState(ixName, ix), programId);\n ixItem[\"accounts\"] = (accounts) => {\n const keys = stateInstructionKeys(programId, provider, m, accounts);\n return keys.concat(InstructionNamespaceFactory.accountsArray(accounts, m.accounts));\n };\n // Build transaction method.\n const txItem = TransactionNamespaceFactory.build(m, ixItem);\n // Build RPC method.\n const rpcItem = RpcNamespaceFactory.build(m, txItem, parseIdlErrors(idl), provider);\n // Attach them all to their respective namespaces.\n const name = camelCase(m.name);\n instruction[name] = ixItem;\n transaction[name] = txItem;\n rpc[name] = rpcItem;\n });\n return [\n instruction,\n transaction,\n rpc,\n ];\n })();\n this.instruction = instruction;\n this.transaction = transaction;\n this.rpc = rpc;\n }\n /**\n * Returns the program ID owning the state.\n */\n get programId() {\n return this._programId;\n }\n /**\n * Returns the deserialized state account.\n */\n async fetch() {\n const addr = this.address();\n const accountInfo = await this.provider.connection.getAccountInfo(addr);\n if (accountInfo === null) {\n throw new Error(`Account does not exist ${addr.toString()}`);\n }\n // Assert the account discriminator is correct.\n const state = this._idl.state;\n if (!state) {\n throw new Error(\"State is not specified in IDL.\");\n }\n const expectedDiscriminator = await stateDiscriminator(state.struct.name);\n if (expectedDiscriminator.compare(accountInfo.data.slice(0, 8))) {\n throw new Error(\"Invalid account discriminator\");\n }\n return this.coder.state.decode(accountInfo.data);\n }\n /**\n * Returns the state address.\n */\n address() {\n return this._address;\n }\n /**\n * Returns an `EventEmitter` with a `\"change\"` event that's fired whenever\n * the state account cahnges.\n */\n subscribe(commitment) {\n if (this._sub !== null) {\n return this._sub.ee;\n }\n const ee = new EventEmitter();\n const listener = this.provider.connection.onAccountChange(this.address(), (acc) => {\n const account = this.coder.state.decode(acc.data);\n ee.emit(\"change\", account);\n }, commitment);\n this._sub = {\n ee,\n listener,\n };\n return ee;\n }\n /**\n * Unsubscribes to state changes.\n */\n unsubscribe() {\n if (this._sub !== null) {\n this.provider.connection\n .removeAccountChangeListener(this._sub.listener)\n .then(async () => {\n this._sub = null;\n })\n .catch(console.error);\n }\n }\n}\n// Calculates the deterministic address of the program's \"state\" account.\nfunction programStateAddress(programId) {\n let [registrySigner] = findProgramAddressSync([], programId);\n return createWithSeedSync(registrySigner, \"unversioned\", programId);\n}\n// Returns the common keys that are prepended to all instructions targeting\n// the \"state\" of a program.\nfunction stateInstructionKeys(programId, provider, m, accounts) {\n if (m.name === \"new\") {\n // Ctor `new` method.\n const [programSigner] = findProgramAddressSync([], programId);\n return [\n {\n pubkey: provider.wallet.publicKey,\n isWritable: false,\n isSigner: true,\n },\n {\n pubkey: programStateAddress(programId),\n isWritable: true,\n isSigner: false,\n },\n { pubkey: programSigner, isWritable: false, isSigner: false },\n {\n pubkey: SystemProgram.programId,\n isWritable: false,\n isSigner: false,\n },\n { pubkey: programId, isWritable: false, isSigner: false },\n ];\n }\n else {\n validateAccounts(m.accounts, accounts);\n return [\n {\n pubkey: programStateAddress(programId),\n isWritable: true,\n isSigner: false,\n },\n ];\n }\n}\n//# sourceMappingURL=state.js.map","import * as assert from \"assert\";\nconst LOG_START_INDEX = \"Program log: \".length;\nexport class EventManager {\n constructor(programId, provider, coder) {\n this._programId = programId;\n this._provider = provider;\n this._eventParser = new EventParser(programId, coder);\n this._eventCallbacks = new Map();\n this._eventListeners = new Map();\n this._listenerIdCount = 0;\n }\n addEventListener(eventName, callback) {\n var _a;\n let listener = this._listenerIdCount;\n this._listenerIdCount += 1;\n // Store the listener into the event map.\n if (!(eventName in this._eventCallbacks)) {\n this._eventListeners.set(eventName, []);\n }\n this._eventListeners.set(eventName, ((_a = this._eventListeners.get(eventName)) !== null && _a !== void 0 ? _a : []).concat(listener));\n // Store the callback into the listener map.\n this._eventCallbacks.set(listener, [eventName, callback]);\n // Create the subscription singleton, if needed.\n if (this._onLogsSubscriptionId !== undefined) {\n return listener;\n }\n this._onLogsSubscriptionId = this._provider.connection.onLogs(this._programId, (logs, ctx) => {\n if (logs.err) {\n console.error(logs);\n return;\n }\n this._eventParser.parseLogs(logs.logs, (event) => {\n const allListeners = this._eventListeners.get(event.name);\n if (allListeners) {\n allListeners.forEach((listener) => {\n const listenerCb = this._eventCallbacks.get(listener);\n if (listenerCb) {\n const [, callback] = listenerCb;\n callback(event.data, ctx.slot);\n }\n });\n }\n });\n });\n return listener;\n }\n async removeEventListener(listener) {\n // Get the callback.\n const callback = this._eventCallbacks.get(listener);\n if (!callback) {\n throw new Error(`Event listener ${listener} doesn't exist!`);\n }\n const [eventName] = callback;\n // Get the listeners.\n let listeners = this._eventListeners.get(eventName);\n if (!listeners) {\n throw new Error(`Event listeners don't exist for ${eventName}!`);\n }\n // Update both maps.\n this._eventCallbacks.delete(listener);\n listeners = listeners.filter((l) => l !== listener);\n if (listeners.length === 0) {\n this._eventListeners.delete(eventName);\n }\n // Kill the websocket connection if all listeners have been removed.\n if (this._eventCallbacks.size == 0) {\n assert.ok(this._eventListeners.size === 0);\n if (this._onLogsSubscriptionId !== undefined) {\n await this._provider.connection.removeOnLogsListener(this._onLogsSubscriptionId);\n this._onLogsSubscriptionId = undefined;\n }\n }\n }\n}\nexport class EventParser {\n constructor(programId, coder) {\n this.coder = coder;\n this.programId = programId;\n }\n // Each log given, represents an array of messages emitted by\n // a single transaction, which can execute many different programs across\n // CPI boundaries. However, the subscription is only interested in the\n // events emitted by *this* program. In achieving this, we keep track of the\n // program execution context by parsing each log and looking for a CPI\n // `invoke` call. If one exists, we know a new program is executing. So we\n // push the programId onto a stack and switch the program context. This\n // allows us to track, for a given log, which program was executing during\n // its emission, thereby allowing us to know if a given log event was\n // emitted by *this* program. If it was, then we parse the raw string and\n // emit the event if the string matches the event being subscribed to.\n parseLogs(logs, callback) {\n const logScanner = new LogScanner(logs);\n const execution = new ExecutionContext(logScanner.next());\n let log = logScanner.next();\n while (log !== null) {\n let [event, newProgram, didPop] = this.handleLog(execution, log);\n if (event) {\n callback(event);\n }\n if (newProgram) {\n execution.push(newProgram);\n }\n if (didPop) {\n execution.pop();\n }\n log = logScanner.next();\n }\n }\n // Main log handler. Returns a three element array of the event, the\n // next program that was invoked for CPI, and a boolean indicating if\n // a program has completed execution (and thus should be popped off the\n // execution stack).\n handleLog(execution, log) {\n // Executing program is this program.\n if (execution.stack.length > 0 &&\n execution.program() === this.programId.toString()) {\n return this.handleProgramLog(log);\n }\n // Executing program is not this program.\n else {\n return [null, ...this.handleSystemLog(log)];\n }\n }\n // Handles logs from *this* program.\n handleProgramLog(log) {\n // This is a `msg!` log.\n if (log.startsWith(\"Program log:\")) {\n const logStr = log.slice(LOG_START_INDEX);\n const event = this.coder.events.decode(logStr);\n return [event, null, false];\n }\n // System log.\n else {\n return [null, ...this.handleSystemLog(log)];\n }\n }\n // Handles logs when the current program being executing is *not* this.\n handleSystemLog(log) {\n // System component.\n const logStart = log.split(\":\")[0];\n // Did the program finish executing?\n if (logStart.match(/^Program (.*) success/g) !== null) {\n return [null, true];\n // Recursive call.\n }\n else if (logStart.startsWith(`Program ${this.programId.toString()} invoke`)) {\n return [this.programId.toString(), false];\n }\n // CPI call.\n else if (logStart.includes(\"invoke\")) {\n return [\"cpi\", false]; // Any string will do.\n }\n else {\n return [null, false];\n }\n }\n}\n// Stack frame execution context, allowing one to track what program is\n// executing for a given log.\nclass ExecutionContext {\n constructor(log) {\n var _a;\n // Assumes the first log in every transaction is an `invoke` log from the\n // runtime.\n const program = (_a = /^Program (.*) invoke.*$/g.exec(log)) === null || _a === void 0 ? void 0 : _a[1];\n if (!program) {\n throw new Error(`Could not find program invocation log line`);\n }\n this.stack = [program];\n }\n program() {\n assert.ok(this.stack.length > 0);\n return this.stack[this.stack.length - 1];\n }\n push(newProgram) {\n this.stack.push(newProgram);\n }\n pop() {\n assert.ok(this.stack.length > 0);\n this.stack.pop();\n }\n}\nclass LogScanner {\n constructor(logs) {\n this.logs = logs;\n }\n next() {\n if (this.logs.length === 0) {\n return null;\n }\n let l = this.logs[0];\n this.logs = this.logs.slice(1);\n return l;\n }\n}\n//# sourceMappingURL=event.js.map","import { splitArgsAndCtx } from \"../context\";\nimport { EventParser } from \"../event\";\nimport { ProgramError } from \"../../error\";\nexport default class SimulateFactory {\n static build(idlIx, txFn, idlErrors, provider, coder, programId, idl) {\n const simulate = async (...args) => {\n const tx = txFn(...args);\n const [, ctx] = splitArgsAndCtx(idlIx, [...args]);\n let resp = undefined;\n try {\n resp = await provider.simulate(tx, ctx.signers, ctx.options);\n }\n catch (err) {\n console.log(\"Translating error\", err);\n let translatedErr = ProgramError.parse(err, idlErrors);\n if (translatedErr === null) {\n throw err;\n }\n throw translatedErr;\n }\n if (resp === undefined) {\n throw new Error(\"Unable to simulate transaction\");\n }\n if (resp.value.err) {\n throw new Error(`Simulate error: ${resp.value.err.toString()}`);\n }\n const logs = resp.value.logs;\n if (!logs) {\n throw new Error(\"Simulated logs not found\");\n }\n const events = [];\n if (idl.events) {\n let parser = new EventParser(programId, coder);\n parser.parseLogs(logs, (event) => {\n events.push(event);\n });\n }\n return { events, raw: logs };\n };\n return simulate;\n }\n}\n//# sourceMappingURL=simulate.js.map","import camelCase from \"camelcase\";\nimport StateFactory from \"./state\";\nimport InstructionFactory from \"./instruction\";\nimport TransactionFactory from \"./transaction\";\nimport RpcFactory from \"./rpc\";\nimport AccountFactory from \"./account\";\nimport SimulateFactory from \"./simulate\";\nimport { parseIdlErrors } from \"../common\";\n// Re-exports.\nexport { StateClient } from \"./state\";\nexport { AccountClient } from \"./account\";\nexport default class NamespaceFactory {\n /**\n * Generates all namespaces for a given program.\n */\n static build(idl, coder, programId, provider) {\n const rpc = {};\n const instruction = {};\n const transaction = {};\n const simulate = {};\n const idlErrors = parseIdlErrors(idl);\n const state = StateFactory.build(idl, coder, programId, provider);\n idl.instructions.forEach((idlIx) => {\n const ixItem = InstructionFactory.build(idlIx, (ixName, ix) => coder.instruction.encode(ixName, ix), programId);\n const txItem = TransactionFactory.build(idlIx, ixItem);\n const rpcItem = RpcFactory.build(idlIx, txItem, idlErrors, provider);\n const simulateItem = SimulateFactory.build(idlIx, txItem, idlErrors, provider, coder, programId, idl);\n const name = camelCase(idlIx.name);\n instruction[name] = ixItem;\n transaction[name] = txItem;\n rpc[name] = rpcItem;\n simulate[name] = simulateItem;\n });\n const account = idl.accounts\n ? AccountFactory.build(idl, coder, programId, provider)\n : {};\n return [\n rpc,\n instruction,\n transaction,\n account,\n simulate,\n state,\n ];\n }\n}\n//# sourceMappingURL=index.js.map","export function decode(array) {\n const decoder = typeof TextDecoder === \"undefined\"\n ? new (require(\"util\").TextDecoder)(\"utf-8\") // Node.\n : new TextDecoder(\"utf-8\"); // Browser.\n return decoder.decode(array);\n}\nexport function encode(input) {\n const encoder = typeof TextEncoder === \"undefined\"\n ? new (require(\"util\").TextEncoder)(\"utf-8\") // Node.\n : new TextEncoder(); // Browser.\n return encoder.encode(input);\n}\n//# sourceMappingURL=utf8.js.map","import { inflate } from \"pako\";\nimport { idlAddress, decodeIdlAccount } from \"../idl\";\nimport Coder from \"../coder\";\nimport NamespaceFactory from \"./namespace\";\nimport { getProvider } from \"../\";\nimport { utf8 } from \"../utils/bytes\";\nimport { EventManager } from \"./event\";\nimport { translateAddress } from \"./common\";\nexport * from \"./common\";\nexport * from \"./context\";\nexport * from \"./event\";\nexport * from \"./namespace\";\n/**\n * ## Program\n *\n * Program provides the IDL deserialized client representation of an Anchor\n * program.\n *\n * This API is the one stop shop for all things related to communicating with\n * on-chain programs. Among other things, one can send transactions, fetch\n * deserialized accounts, decode instruction data, subscribe to account\n * changes, and listen to events.\n *\n * In addition to field accessors and methods, the object provides a set of\n * dynamically generated properties, also known as namespaces, that\n * map one-to-one to program methods and accounts. These namespaces generally\n * can be used as follows:\n *\n * ## Usage\n *\n * ```javascript\n * program..\n * ```\n *\n * API specifics are namespace dependent. The examples used in the documentation\n * below will refer to the two counter examples found\n * [here](https://github.com/project-serum/anchor#examples).\n */\nexport class Program {\n /**\n * @param idl The interface definition.\n * @param programId The on-chain address of the program.\n * @param provider The network and wallet context to use. If not provided\n * then uses [[getProvider]].\n */\n constructor(idl, programId, provider) {\n programId = translateAddress(programId);\n if (!provider) {\n provider = getProvider();\n }\n // Fields.\n this._idl = idl;\n this._provider = provider;\n this._programId = programId;\n this._coder = new Coder(idl);\n this._events = new EventManager(this._programId, provider, this._coder);\n // Dynamic namespaces.\n const [rpc, instruction, transaction, account, simulate, state,] = NamespaceFactory.build(idl, this._coder, programId, provider);\n this.rpc = rpc;\n this.instruction = instruction;\n this.transaction = transaction;\n this.account = account;\n this.simulate = simulate;\n this.state = state;\n }\n /**\n * Address of the program.\n */\n get programId() {\n return this._programId;\n }\n /**\n * IDL defining the program's interface.\n */\n get idl() {\n return this._idl;\n }\n /**\n * Coder for serializing requests.\n */\n get coder() {\n return this._coder;\n }\n /**\n * Wallet and network provider.\n */\n get provider() {\n return this._provider;\n }\n /**\n * Generates a Program client by fetching the IDL from the network.\n *\n * In order to use this method, an IDL must have been previously initialized\n * via the anchor CLI's `anchor idl init` command.\n *\n * @param programId The on-chain address of the program.\n * @param provider The network and wallet context.\n */\n static async at(address, provider) {\n const programId = translateAddress(address);\n const idl = await Program.fetchIdl(programId, provider);\n if (!idl) {\n throw new Error(`IDL not found for program: ${address.toString()}`);\n }\n return new Program(idl, programId, provider);\n }\n /**\n * Fetches an idl from the blockchain.\n *\n * In order to use this method, an IDL must have been previously initialized\n * via the anchor CLI's `anchor idl init` command.\n *\n * @param programId The on-chain address of the program.\n * @param provider The network and wallet context.\n */\n static async fetchIdl(address, provider) {\n provider = provider !== null && provider !== void 0 ? provider : getProvider();\n const programId = translateAddress(address);\n const idlAddr = await idlAddress(programId);\n const accountInfo = await provider.connection.getAccountInfo(idlAddr);\n if (!accountInfo) {\n return null;\n }\n // Chop off account discriminator.\n let idlAccount = decodeIdlAccount(accountInfo.data.slice(8));\n const inflatedIdl = inflate(idlAccount.data);\n return JSON.parse(utf8.decode(inflatedIdl));\n }\n /**\n * Invokes the given callback every time the given event is emitted.\n *\n * @param eventName The PascalCase name of the event, provided by the IDL.\n * @param callback The function to invoke whenever the event is emitted from\n * program logs.\n */\n addEventListener(eventName, callback) {\n return this._events.addEventListener(eventName, callback);\n }\n /**\n * Unsubscribes from the given eventName.\n */\n async removeEventListener(listener) {\n return await this._events.removeEventListener(listener);\n }\n}\n//# sourceMappingURL=index.js.map","import camelCase from \"camelcase\";\nimport * as toml from \"toml\";\nimport { PublicKey } from \"@solana/web3.js\";\nimport { Program } from \"./program\";\nimport { isBrowser } from \"./utils/common\";\nlet _populatedWorkspace = false;\n/**\n * The `workspace` namespace provides a convenience API to automatically\n * search for and deserialize [[Program]] objects defined by compiled IDLs\n * in an Anchor workspace.\n *\n * This API is for Node only.\n */\nconst workspace = new Proxy({}, {\n get(workspaceCache, programName) {\n if (isBrowser) {\n console.log(\"Workspaces aren't available in the browser\");\n return undefined;\n }\n const fs = require(\"fs\");\n const process = require(\"process\");\n if (!_populatedWorkspace) {\n const path = require(\"path\");\n let projectRoot = process.cwd();\n while (!fs.existsSync(path.join(projectRoot, \"Anchor.toml\"))) {\n const parentDir = path.dirname(projectRoot);\n if (parentDir === projectRoot) {\n projectRoot = undefined;\n }\n projectRoot = parentDir;\n }\n if (projectRoot === undefined) {\n throw new Error(\"Could not find workspace root.\");\n }\n const idlFolder = `${projectRoot}/target/idl`;\n if (!fs.existsSync(idlFolder)) {\n throw new Error(`${idlFolder} doesn't exist. Did you use \"anchor build\"?`);\n }\n const idlMap = new Map();\n fs.readdirSync(idlFolder).forEach((file) => {\n const filePath = `${idlFolder}/${file}`;\n const idlStr = fs.readFileSync(filePath);\n const idl = JSON.parse(idlStr);\n idlMap.set(idl.name, idl);\n const name = camelCase(idl.name, { pascalCase: true });\n if (idl.metadata && idl.metadata.address) {\n workspaceCache[name] = new Program(idl, new PublicKey(idl.metadata.address));\n }\n });\n // Override the workspace programs if the user put them in the config.\n const anchorToml = toml.parse(fs.readFileSync(path.join(projectRoot, \"Anchor.toml\"), \"utf-8\"));\n const clusterId = anchorToml.provider.cluster;\n if (anchorToml.programs && anchorToml.programs[clusterId]) {\n attachWorkspaceOverride(workspaceCache, anchorToml.programs[clusterId], idlMap);\n }\n _populatedWorkspace = true;\n }\n return workspaceCache[programName];\n },\n});\nfunction attachWorkspaceOverride(workspaceCache, overrideConfig, idlMap) {\n Object.keys(overrideConfig).forEach((programName) => {\n const wsProgramName = camelCase(programName, { pascalCase: true });\n const entry = overrideConfig[programName];\n const overrideAddress = new PublicKey(typeof entry === \"string\" ? entry : entry.address);\n let idl = idlMap.get(programName);\n if (typeof entry !== \"string\" && entry.idl) {\n idl = JSON.parse(require(\"fs\").readFileSync(entry.idl, \"utf-8\"));\n }\n if (!idl) {\n throw new Error(`Error loading workspace IDL for ${programName}`);\n }\n workspaceCache[wsProgramName] = new Program(idl, overrideAddress);\n });\n}\nexport default workspace;\n//# sourceMappingURL=workspace.js.map","import { PublicKey } from \"@solana/web3.js\";\nconst TOKEN_PROGRAM_ID = new PublicKey(\"TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA\");\nconst ASSOCIATED_PROGRAM_ID = new PublicKey(\"ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL\");\nexport async function associatedAddress({ mint, owner, }) {\n return (await PublicKey.findProgramAddress([owner.toBuffer(), TOKEN_PROGRAM_ID.toBuffer(), mint.toBuffer()], ASSOCIATED_PROGRAM_ID))[0];\n}\n//# sourceMappingURL=token.js.map","(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 if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\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 this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\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 parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\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 // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\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 this.strip();\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","import camelCase from \"camelcase\";\nimport * as borsh from \"@project-serum/borsh\";\nimport { IdlError } from \"../error\";\nexport class IdlCoder {\n static fieldLayout(field, types) {\n const fieldName = field.name !== undefined ? camelCase(field.name) : undefined;\n switch (field.type) {\n case \"bool\": {\n return borsh.bool(fieldName);\n }\n case \"u8\": {\n return borsh.u8(fieldName);\n }\n case \"i8\": {\n return borsh.i8(fieldName);\n }\n case \"u16\": {\n return borsh.u16(fieldName);\n }\n case \"i16\": {\n return borsh.i16(fieldName);\n }\n case \"u32\": {\n return borsh.u32(fieldName);\n }\n case \"i32\": {\n return borsh.i32(fieldName);\n }\n case \"u64\": {\n return borsh.u64(fieldName);\n }\n case \"i64\": {\n return borsh.i64(fieldName);\n }\n case \"u128\": {\n return borsh.u128(fieldName);\n }\n case \"i128\": {\n return borsh.i128(fieldName);\n }\n case \"bytes\": {\n return borsh.vecU8(fieldName);\n }\n case \"string\": {\n return borsh.str(fieldName);\n }\n case \"publicKey\": {\n return borsh.publicKey(fieldName);\n }\n default: {\n if (\"vec\" in field.type) {\n return borsh.vec(IdlCoder.fieldLayout({\n name: undefined,\n // @ts-ignore\n type: field.type.vec,\n }, types), fieldName);\n }\n else if (\"option\" in field.type) {\n return borsh.option(IdlCoder.fieldLayout({\n name: undefined,\n type: field.type.option,\n }, types), fieldName);\n }\n else if (\"defined\" in field.type) {\n const defined = field.type.defined;\n // User defined type.\n if (types === undefined) {\n throw new IdlError(\"User defined types not provided\");\n }\n const filtered = types.filter((t) => t.name === defined);\n if (filtered.length !== 1) {\n throw new IdlError(`Type not found: ${JSON.stringify(field)}`);\n }\n return IdlCoder.typeDefLayout(filtered[0], types, fieldName);\n }\n else if (\"array\" in field.type) {\n let arrayTy = field.type.array[0];\n let arrayLen = field.type.array[1];\n let innerLayout = IdlCoder.fieldLayout({\n name: undefined,\n type: arrayTy,\n }, types);\n return borsh.array(innerLayout, arrayLen, fieldName);\n }\n else {\n throw new Error(`Not yet implemented: ${field}`);\n }\n }\n }\n }\n static typeDefLayout(typeDef, types = [], name) {\n if (typeDef.type.kind === \"struct\") {\n const fieldLayouts = typeDef.type.fields.map((field) => {\n const x = IdlCoder.fieldLayout(field, types);\n return x;\n });\n return borsh.struct(fieldLayouts, name);\n }\n else if (typeDef.type.kind === \"enum\") {\n let variants = typeDef.type.variants.map((variant) => {\n const name = camelCase(variant.name);\n if (variant.fields === undefined) {\n return borsh.struct([], name);\n }\n // @ts-ignore\n const fieldLayouts = variant.fields.map((f) => {\n // @ts-ignore\n if (f.name === undefined) {\n throw new Error(\"Tuple enum variants not yet implemented.\");\n }\n // @ts-ignore\n return IdlCoder.fieldLayout(f, types);\n });\n return borsh.struct(fieldLayouts, name);\n });\n if (name !== undefined) {\n // Buffer-layout lib requires the name to be null (on construction)\n // when used as a field.\n return borsh.rustEnum(variants).replicate(name);\n }\n return borsh.rustEnum(variants, name);\n }\n else {\n throw new Error(`Unknown type kint: ${typeDef}`);\n }\n }\n}\n//# sourceMappingURL=idl.js.map","import BN from \"bn.js\";\nimport { sha256 as sha256Sync } from \"js-sha256\";\nimport { PublicKey } from \"@solana/web3.js\";\nimport { translateAddress } from \"../program/common\";\n// Sync version of web3.PublicKey.createWithSeed.\nexport function createWithSeedSync(fromPublicKey, seed, programId) {\n const buffer = Buffer.concat([\n fromPublicKey.toBuffer(),\n Buffer.from(seed),\n programId.toBuffer(),\n ]);\n const hash = sha256Sync.digest(buffer);\n return new PublicKey(Buffer.from(hash));\n}\n// Sync version of web3.PublicKey.createProgramAddress.\nexport function createProgramAddressSync(seeds, programId) {\n const MAX_SEED_LENGTH = 32;\n let buffer = Buffer.alloc(0);\n seeds.forEach(function (seed) {\n if (seed.length > MAX_SEED_LENGTH) {\n throw new TypeError(`Max seed length exceeded`);\n }\n buffer = Buffer.concat([buffer, toBuffer(seed)]);\n });\n buffer = Buffer.concat([\n buffer,\n programId.toBuffer(),\n Buffer.from(\"ProgramDerivedAddress\"),\n ]);\n let hash = sha256Sync(new Uint8Array(buffer));\n let publicKeyBytes = new BN(hash, 16).toArray(undefined, 32);\n if (PublicKey.isOnCurve(new Uint8Array(publicKeyBytes))) {\n throw new Error(`Invalid seeds, address must fall off the curve`);\n }\n return new PublicKey(publicKeyBytes);\n}\n// Sync version of web3.PublicKey.findProgramAddress.\nexport function findProgramAddressSync(seeds, programId) {\n let nonce = 255;\n let address;\n while (nonce != 0) {\n try {\n const seedsWithNonce = seeds.concat(Buffer.from([nonce]));\n address = createProgramAddressSync(seedsWithNonce, programId);\n }\n catch (err) {\n if (err instanceof TypeError) {\n throw err;\n }\n nonce--;\n continue;\n }\n return [address, nonce];\n }\n throw new Error(`Unable to find a viable program address nonce`);\n}\nconst toBuffer = (arr) => {\n if (arr instanceof Buffer) {\n return arr;\n }\n else if (arr instanceof Uint8Array) {\n return Buffer.from(arr.buffer, arr.byteOffset, arr.byteLength);\n }\n else {\n return Buffer.from(arr);\n }\n};\nexport async function associated(programId, ...args) {\n let seeds = [Buffer.from([97, 110, 99, 104, 111, 114])]; // b\"anchor\".\n args.forEach((arg) => {\n seeds.push(\n // @ts-ignore\n arg.buffer !== undefined ? arg : translateAddress(arg).toBuffer());\n });\n const [assoc] = await PublicKey.findProgramAddress(seeds, translateAddress(programId));\n return assoc;\n}\n//# sourceMappingURL=pubkey.js.map","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return possibleConstructorReturn(this, result);\n };\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","import { snakeCase } from \"snake-case\";\nimport { sha256 } from \"js-sha256\";\nimport { IdlError } from \"../error\";\nexport function accountSize(idl, idlAccount) {\n if (idlAccount.type.kind === \"enum\") {\n let variantSizes = idlAccount.type.variants.map((variant) => {\n if (variant.fields === undefined) {\n return 0;\n }\n return variant.fields\n .map((f) => {\n if (!(typeof f === \"object\" && \"name\" in f)) {\n throw new Error(\"Tuple enum variants not yet implemented.\");\n }\n return typeSize(idl, f.type);\n })\n .reduce((a, b) => a + b);\n });\n return Math.max(...variantSizes) + 1;\n }\n if (idlAccount.type.fields === undefined) {\n return 0;\n }\n return idlAccount.type.fields\n .map((f) => typeSize(idl, f.type))\n .reduce((a, b) => a + b, 0);\n}\n// Returns the size of the type in bytes. For variable length types, just return\n// 1. Users should override this value in such cases.\nfunction typeSize(idl, ty) {\n var _a, _b;\n switch (ty) {\n case \"bool\":\n return 1;\n case \"u8\":\n return 1;\n case \"i8\":\n return 1;\n case \"i16\":\n return 2;\n case \"u16\":\n return 2;\n case \"u32\":\n return 4;\n case \"i32\":\n return 4;\n case \"u64\":\n return 8;\n case \"i64\":\n return 8;\n case \"u128\":\n return 16;\n case \"i128\":\n return 16;\n case \"bytes\":\n return 1;\n case \"string\":\n return 1;\n case \"publicKey\":\n return 32;\n default:\n if (\"vec\" in ty) {\n return 1;\n }\n if (\"option\" in ty) {\n return 1 + typeSize(idl, ty.option);\n }\n if (\"defined\" in ty) {\n const filtered = (_b = (_a = idl.types) === null || _a === void 0 ? void 0 : _a.filter((t) => t.name === ty.defined)) !== null && _b !== void 0 ? _b : [];\n if (filtered.length !== 1) {\n throw new IdlError(`Type not found: ${JSON.stringify(ty)}`);\n }\n let typeDef = filtered[0];\n return accountSize(idl, typeDef);\n }\n if (\"array\" in ty) {\n let arrayTy = ty.array[0];\n let arraySize = ty.array[1];\n return typeSize(idl, arrayTy) * arraySize;\n }\n throw new Error(`Invalid type ${JSON.stringify(ty)}`);\n }\n}\n// Not technically sighash, since we don't include the arguments, as Rust\n// doesn't allow function overloading.\nexport function sighash(nameSpace, ixName) {\n let name = snakeCase(ixName);\n let preimage = `${nameSpace}:${name}`;\n return Buffer.from(sha256.digest(preimage)).slice(0, 8);\n}\n//# sourceMappingURL=common.js.map","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","import { Connection, Keypair, sendAndConfirmRawTransaction, } from \"@solana/web3.js\";\nimport { isBrowser } from \"./utils/common\";\n/**\n * The network and wallet context used to send transactions paid for and signed\n * by the provider.\n */\nexport default class Provider {\n /**\n * @param connection The cluster connection where the program is deployed.\n * @param wallet The wallet used to pay for and sign all transactions.\n * @param opts Transaction confirmation options to use by default.\n */\n constructor(connection, wallet, opts) {\n this.connection = connection;\n this.wallet = wallet;\n this.opts = opts;\n }\n static defaultOptions() {\n return {\n preflightCommitment: \"recent\",\n commitment: \"recent\",\n };\n }\n /**\n * Returns a `Provider` with a wallet read from the local filesystem.\n *\n * @param url The network cluster url.\n * @param opts The default transaction confirmation options.\n *\n * (This api is for Node only.)\n */\n static local(url, opts) {\n opts = opts !== null && opts !== void 0 ? opts : Provider.defaultOptions();\n const connection = new Connection(url !== null && url !== void 0 ? url : \"http://localhost:8899\", opts.preflightCommitment);\n const wallet = NodeWallet.local();\n return new Provider(connection, wallet, opts);\n }\n /**\n * Returns a `Provider` read from the `ANCHOR_PROVIDER_URL` environment\n * variable\n *\n * (This api is for Node only.)\n */\n static env() {\n if (isBrowser) {\n throw new Error(`Provider env is not available on browser.`);\n }\n const process = require(\"process\");\n const url = process.env.ANCHOR_PROVIDER_URL;\n if (url === undefined) {\n throw new Error(\"ANCHOR_PROVIDER_URL is not defined\");\n }\n const options = Provider.defaultOptions();\n const connection = new Connection(url, options.commitment);\n const wallet = NodeWallet.local();\n return new Provider(connection, wallet, options);\n }\n /**\n * Sends the given transaction, paid for and signed by the provider's wallet.\n *\n * @param tx The transaction to send.\n * @param signers The set of signers in addition to the provider wallet that\n * will sign the transaction.\n * @param opts Transaction confirmation options.\n */\n async send(tx, signers, opts) {\n if (signers === undefined) {\n signers = [];\n }\n if (opts === undefined) {\n opts = this.opts;\n }\n tx.feePayer = this.wallet.publicKey;\n tx.recentBlockhash = (await this.connection.getRecentBlockhash(opts.preflightCommitment)).blockhash;\n await this.wallet.signTransaction(tx);\n signers\n .filter((s) => s !== undefined)\n .forEach((kp) => {\n tx.partialSign(kp);\n });\n const rawTx = tx.serialize();\n const txId = await sendAndConfirmRawTransaction(this.connection, rawTx, opts);\n return txId;\n }\n /**\n * Similar to `send`, but for an array of transactions and signers.\n */\n async sendAll(reqs, opts) {\n if (opts === undefined) {\n opts = this.opts;\n }\n const blockhash = await this.connection.getRecentBlockhash(opts.preflightCommitment);\n let txs = reqs.map((r) => {\n let tx = r.tx;\n let signers = r.signers;\n if (signers === undefined) {\n signers = [];\n }\n tx.feePayer = this.wallet.publicKey;\n tx.recentBlockhash = blockhash.blockhash;\n signers\n .filter((s) => s !== undefined)\n .forEach((kp) => {\n tx.partialSign(kp);\n });\n return tx;\n });\n const signedTxs = await this.wallet.signAllTransactions(txs);\n const sigs = [];\n for (let k = 0; k < txs.length; k += 1) {\n const tx = signedTxs[k];\n const rawTx = tx.serialize();\n sigs.push(await sendAndConfirmRawTransaction(this.connection, rawTx, opts));\n }\n return sigs;\n }\n /**\n * Simulates the given transaction, returning emitted logs from execution.\n *\n * @param tx The transaction to send.\n * @param signers The set of signers in addition to the provdier wallet that\n * will sign the transaction.\n * @param opts Transaction confirmation options.\n */\n async simulate(tx, signers, opts = this.opts) {\n var _a, _b, _c;\n if (signers === undefined) {\n signers = [];\n }\n tx.feePayer = this.wallet.publicKey;\n tx.recentBlockhash = (await this.connection.getRecentBlockhash((_a = opts.preflightCommitment) !== null && _a !== void 0 ? _a : this.opts.preflightCommitment)).blockhash;\n await this.wallet.signTransaction(tx);\n signers\n .filter((s) => s !== undefined)\n .forEach((kp) => {\n tx.partialSign(kp);\n });\n return await simulateTransaction(this.connection, tx, (_c = (_b = opts.commitment) !== null && _b !== void 0 ? _b : this.opts.commitment) !== null && _c !== void 0 ? _c : \"recent\");\n }\n}\n/**\n * Node only wallet.\n */\nexport class NodeWallet {\n constructor(payer) {\n this.payer = payer;\n }\n static local() {\n const process = require(\"process\");\n const payer = Keypair.fromSecretKey(Buffer.from(JSON.parse(require(\"fs\").readFileSync(process.env.ANCHOR_WALLET, {\n encoding: \"utf-8\",\n }))));\n return new NodeWallet(payer);\n }\n async signTransaction(tx) {\n tx.partialSign(this.payer);\n return tx;\n }\n async signAllTransactions(txs) {\n return txs.map((t) => {\n t.partialSign(this.payer);\n return t;\n });\n }\n get publicKey() {\n return this.payer.publicKey;\n }\n}\n// Copy of Connection.simulateTransaction that takes a commitment parameter.\nasync function simulateTransaction(connection, transaction, commitment) {\n // @ts-ignore\n transaction.recentBlockhash = await connection._recentBlockhash(\n // @ts-ignore\n connection._disableBlockhashCaching);\n const signData = transaction.serializeMessage();\n // @ts-ignore\n const wireTransaction = transaction._serialize(signData);\n const encodedTransaction = wireTransaction.toString(\"base64\");\n const config = { encoding: \"base64\", commitment };\n const args = [encodedTransaction, config];\n // @ts-ignore\n const res = await connection._rpcRequest(\"simulateTransaction\", args);\n if (res.error) {\n throw new Error(\"failed to simulate transaction: \" + res.error.message);\n }\n return res.result;\n}\n/**\n * Sets the default provider on the client.\n */\nexport function setProvider(provider) {\n _provider = provider;\n}\n/**\n * Returns the default provider being used by the client.\n */\nexport function getProvider() {\n if (_provider === null) {\n return Provider.local();\n }\n return _provider;\n}\n// Global provider used as the default when a provider is not given.\nlet _provider = null;\n//# sourceMappingURL=provider.js.map","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct;\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","'use strict';\n\nvar objectAssign = require('object-assign');\n\n// compare and isBuffer taken from https://github.com/feross/buffer/blob/680e9e5e488f22aac27599a57dc844a6315928dd/index.js\n// original notice:\n\n/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\nfunction compare(a, b) {\n if (a === b) {\n return 0;\n }\n\n var x = a.length;\n var y = b.length;\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i];\n y = b[i];\n break;\n }\n }\n\n if (x < y) {\n return -1;\n }\n if (y < x) {\n return 1;\n }\n return 0;\n}\nfunction isBuffer(b) {\n if (global.Buffer && typeof global.Buffer.isBuffer === 'function') {\n return global.Buffer.isBuffer(b);\n }\n return !!(b != null && b._isBuffer);\n}\n\n// based on node assert, original notice:\n// NB: The URL to the CommonJS spec is kept just for tradition.\n// node-assert has evolved a lot since then, both in API and behavior.\n\n// http://wiki.commonjs.org/wiki/Unit_Testing/1.0\n//\n// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!\n//\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar util = require('util/');\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar pSlice = Array.prototype.slice;\nvar functionsHaveNames = (function () {\n return function foo() {}.name === 'foo';\n}());\nfunction pToString (obj) {\n return Object.prototype.toString.call(obj);\n}\nfunction isView(arrbuf) {\n if (isBuffer(arrbuf)) {\n return false;\n }\n if (typeof global.ArrayBuffer !== 'function') {\n return false;\n }\n if (typeof ArrayBuffer.isView === 'function') {\n return ArrayBuffer.isView(arrbuf);\n }\n if (!arrbuf) {\n return false;\n }\n if (arrbuf instanceof DataView) {\n return true;\n }\n if (arrbuf.buffer && arrbuf.buffer instanceof ArrayBuffer) {\n return true;\n }\n return false;\n}\n// 1. The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\n\n// 2. The AssertionError is defined in assert.\n// new assert.AssertionError({ message: message,\n// actual: actual,\n// expected: expected })\n\nvar regex = /\\s*function\\s+([^\\(\\s]*)\\s*/;\n// based on https://github.com/ljharb/function.prototype.name/blob/adeeeec8bfcc6068b187d7d9fb3d5bb1d3a30899/implementation.js\nfunction getName(func) {\n if (!util.isFunction(func)) {\n return;\n }\n if (functionsHaveNames) {\n return func.name;\n }\n var str = func.toString();\n var match = str.match(regex);\n return match && match[1];\n}\nassert.AssertionError = function AssertionError(options) {\n this.name = 'AssertionError';\n this.actual = options.actual;\n this.expected = options.expected;\n this.operator = options.operator;\n if (options.message) {\n this.message = options.message;\n this.generatedMessage = false;\n } else {\n this.message = getMessage(this);\n this.generatedMessage = true;\n }\n var stackStartFunction = options.stackStartFunction || fail;\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, stackStartFunction);\n } else {\n // non v8 browsers so we can have a stacktrace\n var err = new Error();\n if (err.stack) {\n var out = err.stack;\n\n // try to strip useless frames\n var fn_name = getName(stackStartFunction);\n var idx = out.indexOf('\\n' + fn_name);\n if (idx >= 0) {\n // once we have located the function frame\n // we need to strip out everything before it (and its line)\n var next_line = out.indexOf('\\n', idx + 1);\n out = out.substring(next_line + 1);\n }\n\n this.stack = out;\n }\n }\n};\n\n// assert.AssertionError instanceof Error\nutil.inherits(assert.AssertionError, Error);\n\nfunction truncate(s, n) {\n if (typeof s === 'string') {\n return s.length < n ? s : s.slice(0, n);\n } else {\n return s;\n }\n}\nfunction inspect(something) {\n if (functionsHaveNames || !util.isFunction(something)) {\n return util.inspect(something);\n }\n var rawname = getName(something);\n var name = rawname ? ': ' + rawname : '';\n return '[Function' + name + ']';\n}\nfunction getMessage(self) {\n return truncate(inspect(self.actual), 128) + ' ' +\n self.operator + ' ' +\n truncate(inspect(self.expected), 128);\n}\n\n// At present only the three keys mentioned above are used and\n// understood by the spec. Implementations or sub modules can pass\n// other keys to the AssertionError's constructor - they will be\n// ignored.\n\n// 3. All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided. All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction fail(actual, expected, message, operator, stackStartFunction) {\n throw new assert.AssertionError({\n message: message,\n actual: actual,\n expected: expected,\n operator: operator,\n stackStartFunction: stackStartFunction\n });\n}\n\n// EXTENSION! allows for well behaved errors defined elsewhere.\nassert.fail = fail;\n\n// 4. Pure assertion tests whether a value is truthy, as determined\n// by !!guard.\n// assert.ok(guard, message_opt);\n// This statement is equivalent to assert.equal(true, !!guard,\n// message_opt);. To test strictly for the value true, use\n// assert.strictEqual(true, guard, message_opt);.\n\nfunction ok(value, message) {\n if (!value) fail(value, true, message, '==', assert.ok);\n}\nassert.ok = ok;\n\n// 5. The equality assertion tests shallow, coercive equality with\n// ==.\n// assert.equal(actual, expected, message_opt);\n\nassert.equal = function equal(actual, expected, message) {\n if (actual != expected) fail(actual, expected, message, '==', assert.equal);\n};\n\n// 6. The non-equality assertion tests for whether two objects are not equal\n// with != assert.notEqual(actual, expected, message_opt);\n\nassert.notEqual = function notEqual(actual, expected, message) {\n if (actual == expected) {\n fail(actual, expected, message, '!=', assert.notEqual);\n }\n};\n\n// 7. The equivalence assertion tests a deep equality relation.\n// assert.deepEqual(actual, expected, message_opt);\n\nassert.deepEqual = function deepEqual(actual, expected, message) {\n if (!_deepEqual(actual, expected, false)) {\n fail(actual, expected, message, 'deepEqual', assert.deepEqual);\n }\n};\n\nassert.deepStrictEqual = function deepStrictEqual(actual, expected, message) {\n if (!_deepEqual(actual, expected, true)) {\n fail(actual, expected, message, 'deepStrictEqual', assert.deepStrictEqual);\n }\n};\n\nfunction _deepEqual(actual, expected, strict, memos) {\n // 7.1. All identical values are equivalent, as determined by ===.\n if (actual === expected) {\n return true;\n } else if (isBuffer(actual) && isBuffer(expected)) {\n return compare(actual, expected) === 0;\n\n // 7.2. If the expected value is a Date object, the actual value is\n // equivalent if it is also a Date object that refers to the same time.\n } else if (util.isDate(actual) && util.isDate(expected)) {\n return actual.getTime() === expected.getTime();\n\n // 7.3 If the expected value is a RegExp object, the actual value is\n // equivalent if it is also a RegExp object with the same source and\n // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).\n } else if (util.isRegExp(actual) && util.isRegExp(expected)) {\n return actual.source === expected.source &&\n actual.global === expected.global &&\n actual.multiline === expected.multiline &&\n actual.lastIndex === expected.lastIndex &&\n actual.ignoreCase === expected.ignoreCase;\n\n // 7.4. Other pairs that do not both pass typeof value == 'object',\n // equivalence is determined by ==.\n } else if ((actual === null || typeof actual !== 'object') &&\n (expected === null || typeof expected !== 'object')) {\n return strict ? actual === expected : actual == expected;\n\n // If both values are instances of typed arrays, wrap their underlying\n // ArrayBuffers in a Buffer each to increase performance\n // This optimization requires the arrays to have the same type as checked by\n // Object.prototype.toString (aka pToString). Never perform binary\n // comparisons for Float*Arrays, though, since e.g. +0 === -0 but their\n // bit patterns are not identical.\n } else if (isView(actual) && isView(expected) &&\n pToString(actual) === pToString(expected) &&\n !(actual instanceof Float32Array ||\n actual instanceof Float64Array)) {\n return compare(new Uint8Array(actual.buffer),\n new Uint8Array(expected.buffer)) === 0;\n\n // 7.5 For all other Object pairs, including Array objects, equivalence is\n // determined by having the same number of owned properties (as verified\n // with Object.prototype.hasOwnProperty.call), the same set of keys\n // (although not necessarily the same order), equivalent values for every\n // corresponding key, and an identical 'prototype' property. Note: this\n // accounts for both named and indexed properties on Arrays.\n } else if (isBuffer(actual) !== isBuffer(expected)) {\n return false;\n } else {\n memos = memos || {actual: [], expected: []};\n\n var actualIndex = memos.actual.indexOf(actual);\n if (actualIndex !== -1) {\n if (actualIndex === memos.expected.indexOf(expected)) {\n return true;\n }\n }\n\n memos.actual.push(actual);\n memos.expected.push(expected);\n\n return objEquiv(actual, expected, strict, memos);\n }\n}\n\nfunction isArguments(object) {\n return Object.prototype.toString.call(object) == '[object Arguments]';\n}\n\nfunction objEquiv(a, b, strict, actualVisitedObjects) {\n if (a === null || a === undefined || b === null || b === undefined)\n return false;\n // if one is a primitive, the other must be same\n if (util.isPrimitive(a) || util.isPrimitive(b))\n return a === b;\n if (strict && Object.getPrototypeOf(a) !== Object.getPrototypeOf(b))\n return false;\n var aIsArgs = isArguments(a);\n var bIsArgs = isArguments(b);\n if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs))\n return false;\n if (aIsArgs) {\n a = pSlice.call(a);\n b = pSlice.call(b);\n return _deepEqual(a, b, strict);\n }\n var ka = objectKeys(a);\n var kb = objectKeys(b);\n var key, i;\n // having the same number of owned properties (keys incorporates\n // hasOwnProperty)\n if (ka.length !== kb.length)\n return false;\n //the same set of keys (although not necessarily the same order),\n ka.sort();\n kb.sort();\n //~~~cheap key test\n for (i = ka.length - 1; i >= 0; i--) {\n if (ka[i] !== kb[i])\n return false;\n }\n //equivalent values for every corresponding key, and\n //~~~possibly expensive deep test\n for (i = ka.length - 1; i >= 0; i--) {\n key = ka[i];\n if (!_deepEqual(a[key], b[key], strict, actualVisitedObjects))\n return false;\n }\n return true;\n}\n\n// 8. The non-equivalence assertion tests for any deep inequality.\n// assert.notDeepEqual(actual, expected, message_opt);\n\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n if (_deepEqual(actual, expected, false)) {\n fail(actual, expected, message, 'notDeepEqual', assert.notDeepEqual);\n }\n};\n\nassert.notDeepStrictEqual = notDeepStrictEqual;\nfunction notDeepStrictEqual(actual, expected, message) {\n if (_deepEqual(actual, expected, true)) {\n fail(actual, expected, message, 'notDeepStrictEqual', notDeepStrictEqual);\n }\n}\n\n\n// 9. The strict equality assertion tests strict equality, as determined by ===.\n// assert.strictEqual(actual, expected, message_opt);\n\nassert.strictEqual = function strictEqual(actual, expected, message) {\n if (actual !== expected) {\n fail(actual, expected, message, '===', assert.strictEqual);\n }\n};\n\n// 10. The strict non-equality assertion tests for strict inequality, as\n// determined by !==. assert.notStrictEqual(actual, expected, message_opt);\n\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n if (actual === expected) {\n fail(actual, expected, message, '!==', assert.notStrictEqual);\n }\n};\n\nfunction expectedException(actual, expected) {\n if (!actual || !expected) {\n return false;\n }\n\n if (Object.prototype.toString.call(expected) == '[object RegExp]') {\n return expected.test(actual);\n }\n\n try {\n if (actual instanceof expected) {\n return true;\n }\n } catch (e) {\n // Ignore. The instanceof check doesn't work for arrow functions.\n }\n\n if (Error.isPrototypeOf(expected)) {\n return false;\n }\n\n return expected.call({}, actual) === true;\n}\n\nfunction _tryBlock(block) {\n var error;\n try {\n block();\n } catch (e) {\n error = e;\n }\n return error;\n}\n\nfunction _throws(shouldThrow, block, expected, message) {\n var actual;\n\n if (typeof block !== 'function') {\n throw new TypeError('\"block\" argument must be a function');\n }\n\n if (typeof expected === 'string') {\n message = expected;\n expected = null;\n }\n\n actual = _tryBlock(block);\n\n message = (expected && expected.name ? ' (' + expected.name + ').' : '.') +\n (message ? ' ' + message : '.');\n\n if (shouldThrow && !actual) {\n fail(actual, expected, 'Missing expected exception' + message);\n }\n\n var userProvidedMessage = typeof message === 'string';\n var isUnwantedException = !shouldThrow && util.isError(actual);\n var isUnexpectedException = !shouldThrow && actual && !expected;\n\n if ((isUnwantedException &&\n userProvidedMessage &&\n expectedException(actual, expected)) ||\n isUnexpectedException) {\n fail(actual, expected, 'Got unwanted exception' + message);\n }\n\n if ((shouldThrow && actual && expected &&\n !expectedException(actual, expected)) || (!shouldThrow && actual)) {\n throw actual;\n }\n}\n\n// 11. Expected to throw an error:\n// assert.throws(block, Error_opt, message_opt);\n\nassert.throws = function(block, /*optional*/error, /*optional*/message) {\n _throws(true, block, error, message);\n};\n\n// EXTENSION! This is annoying to write outside this module.\nassert.doesNotThrow = function(block, /*optional*/error, /*optional*/message) {\n _throws(false, block, error, message);\n};\n\nassert.ifError = function(err) { if (err) throw err; };\n\n// Expose a strict only variant of assert\nfunction strict(value, message) {\n if (!value) fail(value, true, message, '==', strict);\n}\nassert.strict = objectAssign(strict, assert, {\n equal: assert.strictEqual,\n deepEqual: assert.deepStrictEqual,\n notEqual: assert.notStrictEqual,\n notDeepEqual: assert.notDeepStrictEqual\n});\nassert.strict.strict = assert.strict;\n\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) {\n if (hasOwn.call(obj, key)) keys.push(key);\n }\n return keys;\n};\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}","var _a;\n/**\n * Returns true if being run inside a web browser,\n * false if in a Node process or electron app.\n */\nexport const isBrowser = typeof window !== \"undefined\" && !((_a = window.process) === null || _a === void 0 ? void 0 : _a.hasOwnProperty(\"type\"));\n/**\n * Splits an array into chunks\n *\n * @param array Array of objects to chunk.\n * @param size The max size of a chunk.\n * @returns A two dimensional array where each T[] length is < the provided size.\n */\nexport function chunks(array, size) {\n return Array.apply(0, new Array(Math.ceil(array.length / size))).map((_, index) => array.slice(index * size, (index + 1) * size));\n}\n//# sourceMappingURL=common.js.map","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\n\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n this.pending = null;\n this.pendingTotal = 0;\n this.blockSize = this.constructor.blockSize;\n this.outSize = this.constructor.outSize;\n this.hmacStrength = this.constructor.hmacStrength;\n this.padLength = this.constructor.padLength / 8;\n this.endian = 'big';\n\n this._delta8 = this.blockSize / 8;\n this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n // Convert message to array, pad it, and join into 32bit blocks\n msg = utils.toArray(msg, enc);\n if (!this.pending)\n this.pending = msg;\n else\n this.pending = this.pending.concat(msg);\n this.pendingTotal += msg.length;\n\n // Enough data, try updating\n if (this.pending.length >= this._delta8) {\n msg = this.pending;\n\n // Process pending data in blocks\n var r = msg.length % this._delta8;\n this.pending = msg.slice(msg.length - r, msg.length);\n if (this.pending.length === 0)\n this.pending = null;\n\n msg = utils.join32(msg, 0, msg.length - r, this.endian);\n for (var i = 0; i < msg.length; i += this._delta32)\n this._update(msg, i, i + this._delta32);\n }\n\n return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n this.update(this._pad());\n assert(this.pending === null);\n\n return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n var len = this.pendingTotal;\n var bytes = this._delta8;\n var k = bytes - ((len + this.padLength) % bytes);\n var res = new Array(k + this.padLength);\n res[0] = 0x80;\n for (var i = 1; i < k; i++)\n res[i] = 0;\n\n // Append length\n len <<= 3;\n if (this.endian === 'big') {\n for (var t = 8; t < this.padLength; t++)\n res[i++] = 0;\n\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = len & 0xff;\n } else {\n res[i++] = len & 0xff;\n res[i++] = (len >>> 8) & 0xff;\n res[i++] = (len >>> 16) & 0xff;\n res[i++] = (len >>> 24) & 0xff;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n res[i++] = 0;\n\n for (t = 8; t < this.padLength; t++)\n res[i++] = 0;\n }\n\n return res;\n};\n","import { IdlCoder } from \"./idl\";\nimport { sha256 } from \"js-sha256\";\nimport camelcase from \"camelcase\";\n/**\n * Number of bytes of the account discriminator.\n */\nexport const ACCOUNT_DISCRIMINATOR_SIZE = 8;\n/**\n * Encodes and decodes account objects.\n */\nexport class AccountsCoder {\n constructor(idl) {\n if (idl.accounts === undefined) {\n this.accountLayouts = new Map();\n return;\n }\n const layouts = idl.accounts.map((acc) => {\n return [acc.name, IdlCoder.typeDefLayout(acc, idl.types)];\n });\n this.accountLayouts = new Map(layouts);\n }\n async encode(accountName, account) {\n const buffer = Buffer.alloc(1000); // TODO: use a tighter buffer.\n const layout = this.accountLayouts.get(accountName);\n if (!layout) {\n throw new Error(`Unknown account: ${accountName}`);\n }\n const len = layout.encode(account, buffer);\n let accountData = buffer.slice(0, len);\n let discriminator = AccountsCoder.accountDiscriminator(accountName);\n return Buffer.concat([discriminator, accountData]);\n }\n decode(accountName, ix) {\n // Chop off the discriminator before decoding.\n const data = ix.slice(ACCOUNT_DISCRIMINATOR_SIZE);\n const layout = this.accountLayouts.get(accountName);\n if (!layout) {\n throw new Error(`Unknown account: ${accountName}`);\n }\n return layout.decode(data);\n }\n /**\n * Calculates and returns a unique 8 byte discriminator prepended to all anchor accounts.\n *\n * @param name The name of the account to calculate the discriminator.\n */\n static accountDiscriminator(name) {\n return Buffer.from(sha256.digest(`account:${camelcase(name, { pascalCase: true })}`)).slice(0, ACCOUNT_DISCRIMINATOR_SIZE);\n }\n}\n//# sourceMappingURL=accounts.js.map","import * as base64 from \"base64-js\";\nimport { sha256 } from \"js-sha256\";\nimport { IdlCoder } from \"./idl\";\nexport class EventCoder {\n constructor(idl) {\n if (idl.events === undefined) {\n this.layouts = new Map();\n return;\n }\n const layouts = idl.events.map((event) => {\n let eventTypeDef = {\n name: event.name,\n type: {\n kind: \"struct\",\n fields: event.fields.map((f) => {\n return { name: f.name, type: f.type };\n }),\n },\n };\n return [event.name, IdlCoder.typeDefLayout(eventTypeDef, idl.types)];\n });\n // @ts-ignore\n this.layouts = new Map(layouts);\n this.discriminators = new Map(idl.events === undefined\n ? []\n : idl.events.map((e) => [\n base64.fromByteArray(eventDiscriminator(e.name)),\n e.name,\n ]));\n }\n decode(log) {\n let logArr;\n // This will throw if log length is not a multiple of 4.\n try {\n logArr = Buffer.from(base64.toByteArray(log));\n }\n catch (e) {\n return null;\n }\n const disc = base64.fromByteArray(logArr.slice(0, 8));\n // Only deserialize if the discriminator implies a proper event.\n const eventName = this.discriminators.get(disc);\n if (eventName === undefined) {\n return null;\n }\n const layout = this.layouts.get(eventName);\n if (!layout) {\n throw new Error(`Unknown event: ${eventName}`);\n }\n const data = layout.decode(logArr.slice(8));\n return { data, name: eventName };\n }\n}\nexport function eventDiscriminator(name) {\n return Buffer.from(sha256.digest(`event:${name}`)).slice(0, 8);\n}\n//# sourceMappingURL=event.js.map","import { sha256 } from \"js-sha256\";\nimport { IdlCoder } from \"./idl\";\nimport * as features from \"../utils/features\";\nexport class StateCoder {\n constructor(idl) {\n if (idl.state === undefined) {\n throw new Error(\"Idl state not defined.\");\n }\n this.layout = IdlCoder.typeDefLayout(idl.state.struct, idl.types);\n }\n async encode(name, account) {\n const buffer = Buffer.alloc(1000); // TODO: use a tighter buffer.\n const len = this.layout.encode(account, buffer);\n const disc = await stateDiscriminator(name);\n const accData = buffer.slice(0, len);\n return Buffer.concat([disc, accData]);\n }\n decode(ix) {\n // Chop off discriminator.\n const data = ix.slice(8);\n return this.layout.decode(data);\n }\n}\n// Calculates unique 8 byte discriminator prepended to all anchor state accounts.\nexport async function stateDiscriminator(name) {\n let ns = features.isSet(\"anchor-deprecated-state\") ? \"account\" : \"state\";\n return Buffer.from(sha256.digest(`${ns}:${name}`)).slice(0, 8);\n}\n//# sourceMappingURL=state.js.map","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","var _typeof = require(\"./typeof.js\")[\"default\"];\n\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n this.type = type;\n this.p = new BN(conf.p, 16);\n\n // Use Montgomery, when there is no fast reduction for the prime\n this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n // Useful for many curves\n this.zero = new BN(0).toRed(this.red);\n this.one = new BN(1).toRed(this.red);\n this.two = new BN(2).toRed(this.red);\n\n // Curve configuration, optional\n this.n = conf.n && new BN(conf.n, 16);\n this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n // Temporary arrays\n this._wnafT1 = new Array(4);\n this._wnafT2 = new Array(4);\n this._wnafT3 = new Array(4);\n this._wnafT4 = new Array(4);\n\n this._bitLength = this.n ? this.n.bitLength() : 0;\n\n // Generalized Greg Maxwell's trick\n var adjustCount = this.n && this.p.div(this.n);\n if (!adjustCount || adjustCount.cmpn(100) > 0) {\n this.redN = null;\n } else {\n this._maxwellTrick = true;\n this.redN = this.n.toRed(this.red);\n }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n assert(p.precomputed);\n var doubles = p._getDoubles();\n\n var naf = getNAF(k, 1, this._bitLength);\n var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n I /= 3;\n\n // Translate into more windowed form\n var repr = [];\n var j;\n var nafW;\n for (j = 0; j < naf.length; j += doubles.step) {\n nafW = 0;\n for (var l = j + doubles.step - 1; l >= j; l--)\n nafW = (nafW << 1) + naf[l];\n repr.push(nafW);\n }\n\n var a = this.jpoint(null, null, null);\n var b = this.jpoint(null, null, null);\n for (var i = I; i > 0; i--) {\n for (j = 0; j < repr.length; j++) {\n nafW = repr[j];\n if (nafW === i)\n b = b.mixedAdd(doubles.points[j]);\n else if (nafW === -i)\n b = b.mixedAdd(doubles.points[j].neg());\n }\n a = a.add(b);\n }\n return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n var w = 4;\n\n // Precompute window\n var nafPoints = p._getNAFPoints(w);\n w = nafPoints.wnd;\n var wnd = nafPoints.points;\n\n // Get NAF form\n var naf = getNAF(k, w, this._bitLength);\n\n // Add `this`*(N+1) for every w-NAF index\n var acc = this.jpoint(null, null, null);\n for (var i = naf.length - 1; i >= 0; i--) {\n // Count zeroes\n for (var l = 0; i >= 0 && naf[i] === 0; i--)\n l++;\n if (i >= 0)\n l++;\n acc = acc.dblp(l);\n\n if (i < 0)\n break;\n var z = naf[i];\n assert(z !== 0);\n if (p.type === 'affine') {\n // J +- P\n if (z > 0)\n acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n else\n acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n } else {\n // J +- J\n if (z > 0)\n acc = acc.add(wnd[(z - 1) >> 1]);\n else\n acc = acc.add(wnd[(-z - 1) >> 1].neg());\n }\n }\n return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n points,\n coeffs,\n len,\n jacobianResult) {\n var wndWidth = this._wnafT1;\n var wnd = this._wnafT2;\n var naf = this._wnafT3;\n\n // Fill all arrays\n var max = 0;\n var i;\n var j;\n var p;\n for (i = 0; i < len; i++) {\n p = points[i];\n var nafPoints = p._getNAFPoints(defW);\n wndWidth[i] = nafPoints.wnd;\n wnd[i] = nafPoints.points;\n }\n\n // Comb small window NAFs\n for (i = len - 1; i >= 1; i -= 2) {\n var a = i - 1;\n var b = i;\n if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n max = Math.max(naf[a].length, max);\n max = Math.max(naf[b].length, max);\n continue;\n }\n\n var comb = [\n points[a], /* 1 */\n null, /* 3 */\n null, /* 5 */\n points[b], /* 7 */\n ];\n\n // Try to avoid Projective points, if possible\n if (points[a].y.cmp(points[b].y) === 0) {\n comb[1] = points[a].add(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].add(points[b].neg());\n } else {\n comb[1] = points[a].toJ().mixedAdd(points[b]);\n comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n }\n\n var index = [\n -3, /* -1 -1 */\n -1, /* -1 0 */\n -5, /* -1 1 */\n -7, /* 0 -1 */\n 0, /* 0 0 */\n 7, /* 0 1 */\n 5, /* 1 -1 */\n 1, /* 1 0 */\n 3, /* 1 1 */\n ];\n\n var jsf = getJSF(coeffs[a], coeffs[b]);\n max = Math.max(jsf[0].length, max);\n naf[a] = new Array(max);\n naf[b] = new Array(max);\n for (j = 0; j < max; j++) {\n var ja = jsf[0][j] | 0;\n var jb = jsf[1][j] | 0;\n\n naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n naf[b][j] = 0;\n wnd[a] = comb;\n }\n }\n\n var acc = this.jpoint(null, null, null);\n var tmp = this._wnafT4;\n for (i = max; i >= 0; i--) {\n var k = 0;\n\n while (i >= 0) {\n var zero = true;\n for (j = 0; j < len; j++) {\n tmp[j] = naf[j][i] | 0;\n if (tmp[j] !== 0)\n zero = false;\n }\n if (!zero)\n break;\n k++;\n i--;\n }\n if (i >= 0)\n k++;\n acc = acc.dblp(k);\n if (i < 0)\n break;\n\n for (j = 0; j < len; j++) {\n var z = tmp[j];\n p;\n if (z === 0)\n continue;\n else if (z > 0)\n p = wnd[j][(z - 1) >> 1];\n else if (z < 0)\n p = wnd[j][(-z - 1) >> 1].neg();\n\n if (p.type === 'affine')\n acc = acc.mixedAdd(p);\n else\n acc = acc.add(p);\n }\n }\n // Zeroify references\n for (i = 0; i < len; i++)\n wnd[i] = null;\n\n if (jacobianResult)\n return acc;\n else\n return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n this.curve = curve;\n this.type = type;\n this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n bytes = utils.toArray(bytes, enc);\n\n var len = this.p.byteLength();\n\n // uncompressed, hybrid-odd, hybrid-even\n if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n bytes.length - 1 === 2 * len) {\n if (bytes[0] === 0x06)\n assert(bytes[bytes.length - 1] % 2 === 0);\n else if (bytes[0] === 0x07)\n assert(bytes[bytes.length - 1] % 2 === 1);\n\n var res = this.point(bytes.slice(1, 1 + len),\n bytes.slice(1 + len, 1 + 2 * len));\n\n return res;\n } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n bytes.length - 1 === len) {\n return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n }\n throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n var len = this.curve.p.byteLength();\n var x = this.getX().toArray('be', len);\n\n if (compact)\n return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n if (this.precomputed)\n return this;\n\n var precomputed = {\n doubles: null,\n naf: null,\n beta: null,\n };\n precomputed.naf = this._getNAFPoints(8);\n precomputed.doubles = this._getDoubles(4, power);\n precomputed.beta = this._getBeta();\n this.precomputed = precomputed;\n\n return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n if (!this.precomputed)\n return false;\n\n var doubles = this.precomputed.doubles;\n if (!doubles)\n return false;\n\n return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n if (this.precomputed && this.precomputed.doubles)\n return this.precomputed.doubles;\n\n var doubles = [ this ];\n var acc = this;\n for (var i = 0; i < power; i += step) {\n for (var j = 0; j < step; j++)\n acc = acc.dbl();\n doubles.push(acc);\n }\n return {\n step: step,\n points: doubles,\n };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n if (this.precomputed && this.precomputed.naf)\n return this.precomputed.naf;\n\n var res = [ this ];\n var max = (1 << wnd) - 1;\n var dbl = max === 1 ? null : this.dbl();\n for (var i = 1; i < max; i++)\n res[i] = res[i - 1].add(dbl);\n return {\n wnd: wnd,\n points: res,\n };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n var r = this;\n for (var i = 0; i < k; i++)\n r = r.dbl();\n return r;\n};\n","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (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}\n","import camelCase from \"camelcase\";\nimport * as borsh from \"@project-serum/borsh\";\nimport * as bs58 from \"bs58\";\nimport { IdlCoder } from \"./idl\";\nimport { sighash } from \"./common\";\n/**\n * Namespace for state method function signatures.\n */\nexport const SIGHASH_STATE_NAMESPACE = \"state\";\n/**\n * Namespace for global instruction function signatures (i.e. functions\n * that aren't namespaced by the state or any of its trait implementations).\n */\nexport const SIGHASH_GLOBAL_NAMESPACE = \"global\";\n/**\n * Encodes and decodes program instructions.\n */\nexport class InstructionCoder {\n constructor(idl) {\n this.idl = idl;\n this.ixLayout = InstructionCoder.parseIxLayout(idl);\n const sighashLayouts = new Map();\n idl.instructions.forEach((ix) => {\n const sh = sighash(SIGHASH_GLOBAL_NAMESPACE, ix.name);\n sighashLayouts.set(bs58.encode(sh), {\n layout: this.ixLayout.get(ix.name),\n name: ix.name,\n });\n });\n if (idl.state) {\n idl.state.methods.map((ix) => {\n const sh = sighash(SIGHASH_STATE_NAMESPACE, ix.name);\n sighashLayouts.set(bs58.encode(sh), {\n layout: this.ixLayout.get(ix.name),\n name: ix.name,\n });\n });\n }\n this.sighashLayouts = sighashLayouts;\n }\n /**\n * Encodes a program instruction.\n */\n encode(ixName, ix) {\n return this._encode(SIGHASH_GLOBAL_NAMESPACE, ixName, ix);\n }\n /**\n * Encodes a program state instruction.\n */\n encodeState(ixName, ix) {\n return this._encode(SIGHASH_STATE_NAMESPACE, ixName, ix);\n }\n _encode(nameSpace, ixName, ix) {\n const buffer = Buffer.alloc(1000); // TODO: use a tighter buffer.\n const methodName = camelCase(ixName);\n const layout = this.ixLayout.get(methodName);\n if (!layout) {\n throw new Error(`Unknown method: ${methodName}`);\n }\n const len = layout.encode(ix, buffer);\n const data = buffer.slice(0, len);\n return Buffer.concat([sighash(nameSpace, ixName), data]);\n }\n static parseIxLayout(idl) {\n const stateMethods = idl.state ? idl.state.methods : [];\n const ixLayouts = stateMethods\n .map((m) => {\n let fieldLayouts = m.args.map((arg) => {\n var _a, _b;\n return IdlCoder.fieldLayout(arg, Array.from([...((_a = idl.accounts) !== null && _a !== void 0 ? _a : []), ...((_b = idl.types) !== null && _b !== void 0 ? _b : [])]));\n });\n const name = camelCase(m.name);\n return [name, borsh.struct(fieldLayouts, name)];\n })\n .concat(idl.instructions.map((ix) => {\n let fieldLayouts = ix.args.map((arg) => {\n var _a, _b;\n return IdlCoder.fieldLayout(arg, Array.from([...((_a = idl.accounts) !== null && _a !== void 0 ? _a : []), ...((_b = idl.types) !== null && _b !== void 0 ? _b : [])]));\n });\n const name = camelCase(ix.name);\n return [name, borsh.struct(fieldLayouts, name)];\n }));\n // @ts-ignore\n return new Map(ixLayouts);\n }\n /**\n * Dewcodes a program instruction.\n */\n decode(ix, encoding = \"hex\") {\n if (typeof ix === \"string\") {\n ix = encoding === \"hex\" ? Buffer.from(ix, \"hex\") : bs58.decode(ix);\n }\n let sighash = bs58.encode(ix.slice(0, 8));\n let data = ix.slice(8);\n const decoder = this.sighashLayouts.get(sighash);\n if (!decoder) {\n return null;\n }\n return {\n data: decoder.layout.decode(data),\n name: decoder.name,\n };\n }\n /**\n * Returns a formatted table of all the fields in the given instruction data.\n */\n format(ix, accountMetas) {\n return InstructionFormatter.format(ix, accountMetas, this.idl);\n }\n}\nclass InstructionFormatter {\n static format(ix, accountMetas, idl) {\n const idlIx = idl.instructions.filter((i) => ix.name === i.name)[0];\n if (idlIx === undefined) {\n console.error(\"Invalid instruction given\");\n return null;\n }\n const args = idlIx.args.map((idlField) => {\n return {\n name: idlField.name,\n type: InstructionFormatter.formatIdlType(idlField.type),\n data: InstructionFormatter.formatIdlData(idlField, ix.data[idlField.name], idl.types),\n };\n });\n const flatIdlAccounts = InstructionFormatter.flattenIdlAccounts(idlIx.accounts);\n const accounts = accountMetas.map((meta, idx) => {\n if (idx < flatIdlAccounts.length) {\n return {\n name: flatIdlAccounts[idx].name,\n ...meta,\n };\n }\n // \"Remaining accounts\" are unnamed in Anchor.\n else {\n return {\n name: undefined,\n ...meta,\n };\n }\n });\n return {\n args,\n accounts,\n };\n }\n static formatIdlType(idlType) {\n if (typeof idlType === \"string\") {\n return idlType;\n }\n if (\"vec\" in idlType) {\n return `Vec<${this.formatIdlType(idlType.vec)}>`;\n }\n if (\"option\" in idlType) {\n return `Option<${this.formatIdlType(idlType.option)}>`;\n }\n if (\"defined\" in idlType) {\n return idlType.defined;\n }\n if (\"array\" in idlType) {\n return `Array<${idlType.array[0]}; ${idlType.array[1]}>`;\n }\n throw new Error(`Unknown IDL type: ${idlType}`);\n }\n static formatIdlData(idlField, data, types) {\n if (typeof idlField.type === \"string\") {\n return data.toString();\n }\n // @ts-ignore\n if (idlField.type.vec) {\n // @ts-ignore\n return (\"[\" +\n data\n // @ts-ignore\n .map((d) => this.formatIdlData(\n // @ts-ignore\n { name: \"\", type: idlField.type.vec }, d))\n .join(\", \") +\n \"]\");\n }\n // @ts-ignore\n if (idlField.type.option) {\n // @ts-ignore\n return data === null\n ? \"null\"\n : this.formatIdlData(\n // @ts-ignore\n { name: \"\", type: idlField.type.option }, data);\n }\n // @ts-ignore\n if (idlField.type.defined) {\n if (types === undefined) {\n throw new Error(\"User defined types not provided\");\n }\n // @ts-ignore\n const filtered = types.filter((t) => t.name === idlField.type.defined);\n if (filtered.length !== 1) {\n // @ts-ignore\n throw new Error(`Type not found: ${idlField.type.defined}`);\n }\n return InstructionFormatter.formatIdlDataDefined(filtered[0], data, types);\n }\n return \"unknown\";\n }\n static formatIdlDataDefined(typeDef, data, types) {\n if (typeDef.type.kind === \"struct\") {\n const struct = typeDef.type;\n const fields = Object.keys(data)\n .map((k) => {\n const f = struct.fields.filter((f) => f.name === k)[0];\n if (f === undefined) {\n throw new Error(\"Unable to find type\");\n }\n return (k + \": \" + InstructionFormatter.formatIdlData(f, data[k], types));\n })\n .join(\", \");\n return \"{ \" + fields + \" }\";\n }\n else {\n if (typeDef.type.variants.length === 0) {\n return \"{}\";\n }\n // Struct enum.\n if (typeDef.type.variants[0].name) {\n const variants = typeDef.type.variants;\n const variant = Object.keys(data)[0];\n const enumType = data[variant];\n const namedFields = Object.keys(enumType)\n .map((f) => {\n var _a;\n const fieldData = enumType[f];\n const idlField = (_a = variants[variant]) === null || _a === void 0 ? void 0 : _a.filter((v) => v.name === f)[0];\n if (idlField === undefined) {\n throw new Error(\"Unable to find variant\");\n }\n return (f +\n \": \" +\n InstructionFormatter.formatIdlData(idlField, fieldData, types));\n })\n .join(\", \");\n const variantName = camelCase(variant, { pascalCase: true });\n if (namedFields.length === 0) {\n return variantName;\n }\n return `${variantName} { ${namedFields} }`;\n }\n // Tuple enum.\n else {\n // TODO.\n return \"Tuple formatting not yet implemented\";\n }\n }\n }\n static flattenIdlAccounts(accounts, prefix) {\n // @ts-ignore\n return accounts\n .map((account) => {\n const accName = sentenceCase(account.name);\n // @ts-ignore\n if (account.accounts) {\n const newPrefix = prefix ? `${prefix} > ${accName}` : accName;\n // @ts-ignore\n return InstructionFormatter.flattenIdlAccounts(\n // @ts-ignore\n account.accounts, newPrefix);\n }\n else {\n return {\n ...account,\n name: prefix ? `${prefix} > ${accName}` : accName,\n };\n }\n })\n .flat();\n }\n}\nfunction sentenceCase(field) {\n const result = field.replace(/([A-Z])/g, \" $1\");\n return result.charAt(0).toUpperCase() + result.slice(1);\n}\n//# sourceMappingURL=instruction.js.map","const _AVAILABLE_FEATURES = new Set([\"anchor-deprecated-state\"]);\nconst _FEATURES = new Map();\nexport function set(key) {\n if (!_AVAILABLE_FEATURES.has(key)) {\n throw new Error(\"Invalid feature\");\n }\n _FEATURES.set(key, true);\n}\nexport function isSet(key) {\n return _FEATURES.get(key) !== undefined;\n}\n//# sourceMappingURL=features.js.map","import camelCase from \"camelcase\";\nimport EventEmitter from \"eventemitter3\";\nimport * as bs58 from \"bs58\";\nimport { SystemProgram, } from \"@solana/web3.js\";\nimport Coder, { ACCOUNT_DISCRIMINATOR_SIZE, accountSize, AccountsCoder, } from \"../../coder\";\nimport { translateAddress } from \"../common\";\nimport { getProvider } from \"../../\";\nimport * as pubkeyUtil from \"../../utils/pubkey\";\nimport * as rpcUtil from \"../../utils/rpc\";\nexport default class AccountFactory {\n static build(idl, coder, programId, provider) {\n var _a;\n const accountFns = {};\n (_a = idl.accounts) === null || _a === void 0 ? void 0 : _a.forEach((idlAccount) => {\n const name = camelCase(idlAccount.name);\n accountFns[name] = new AccountClient(idl, idlAccount, programId, provider, coder);\n });\n return accountFns;\n }\n}\nexport class AccountClient {\n constructor(idl, idlAccount, programId, provider, coder) {\n var _a;\n this._idlAccount = idlAccount;\n this._programId = programId;\n this._provider = provider !== null && provider !== void 0 ? provider : getProvider();\n this._coder = coder !== null && coder !== void 0 ? coder : new Coder(idl);\n this._size =\n ACCOUNT_DISCRIMINATOR_SIZE + ((_a = accountSize(idl, idlAccount)) !== null && _a !== void 0 ? _a : 0);\n }\n /**\n * Returns the number of bytes in this account.\n */\n get size() {\n return this._size;\n }\n /**\n * Returns the program ID owning all accounts.\n */\n get programId() {\n return this._programId;\n }\n /**\n * Returns the client's wallet and network provider.\n */\n get provider() {\n return this._provider;\n }\n /**\n * Returns the coder.\n */\n get coder() {\n return this._coder;\n }\n /**\n * Returns a deserialized account, returning null if it doesn't exist.\n *\n * @param address The address of the account to fetch.\n */\n async fetchNullable(address) {\n const accountInfo = await this._provider.connection.getAccountInfo(translateAddress(address));\n if (accountInfo === null) {\n return null;\n }\n // Assert the account discriminator is correct.\n const discriminator = AccountsCoder.accountDiscriminator(this._idlAccount.name);\n if (discriminator.compare(accountInfo.data.slice(0, 8))) {\n throw new Error(\"Invalid account discriminator\");\n }\n return this._coder.accounts.decode(this._idlAccount.name, accountInfo.data);\n }\n /**\n * Returns a deserialized account.\n *\n * @param address The address of the account to fetch.\n */\n async fetch(address) {\n const data = await this.fetchNullable(address);\n if (data === null) {\n throw new Error(`Account does not exist ${address.toString()}`);\n }\n return data;\n }\n /**\n * Returns multiple deserialized accounts.\n * Accounts not found or with wrong discriminator are returned as null.\n *\n * @param addresses The addresses of the accounts to fetch.\n */\n async fetchMultiple(addresses) {\n const accounts = await rpcUtil.getMultipleAccounts(this._provider.connection, addresses.map((address) => translateAddress(address)));\n const discriminator = AccountsCoder.accountDiscriminator(this._idlAccount.name);\n // Decode accounts where discriminator is correct, null otherwise\n return accounts.map((account) => {\n if (account == null) {\n return null;\n }\n if (discriminator.compare(account === null || account === void 0 ? void 0 : account.account.data.slice(0, 8))) {\n return null;\n }\n return this._coder.accounts.decode(this._idlAccount.name, account === null || account === void 0 ? void 0 : account.account.data);\n });\n }\n /**\n * Returns all instances of this account type for the program.\n *\n * @param filters User-provided filters to narrow the results from `connection.getProgramAccounts`.\n *\n * When filters are not defined this method returns all\n * the account instances.\n *\n * When filters are of type `Buffer`, the filters are appended\n * after the discriminator.\n *\n * When filters are of type `GetProgramAccountsFilter[]`,\n * filters are appended after the discriminator filter.\n */\n async all(filters) {\n const discriminator = AccountsCoder.accountDiscriminator(this._idlAccount.name);\n let resp = await this._provider.connection.getProgramAccounts(this._programId, {\n commitment: this._provider.connection.commitment,\n filters: [\n {\n memcmp: {\n offset: 0,\n bytes: bs58.encode(filters instanceof Buffer\n ? Buffer.concat([discriminator, filters])\n : discriminator),\n },\n },\n ...(Array.isArray(filters) ? filters : []),\n ],\n });\n return resp.map(({ pubkey, account }) => {\n return {\n publicKey: pubkey,\n account: this._coder.accounts.decode(this._idlAccount.name, account.data),\n };\n });\n }\n /**\n * Returns an `EventEmitter` emitting a \"change\" event whenever the account\n * changes.\n */\n subscribe(address, commitment) {\n const sub = subscriptions.get(address.toString());\n if (sub) {\n return sub.ee;\n }\n const ee = new EventEmitter();\n address = translateAddress(address);\n const listener = this._provider.connection.onAccountChange(address, (acc) => {\n const account = this._coder.accounts.decode(this._idlAccount.name, acc.data);\n ee.emit(\"change\", account);\n }, commitment);\n subscriptions.set(address.toString(), {\n ee,\n listener,\n });\n return ee;\n }\n /**\n * Unsubscribes from the account at the given address.\n */\n async unsubscribe(address) {\n let sub = subscriptions.get(address.toString());\n if (!sub) {\n console.warn(\"Address is not subscribed\");\n return;\n }\n if (subscriptions) {\n await this._provider.connection\n .removeAccountChangeListener(sub.listener)\n .then(() => {\n subscriptions.delete(address.toString());\n })\n .catch(console.error);\n }\n }\n /**\n * Returns an instruction for creating this account.\n */\n async createInstruction(signer, sizeOverride) {\n const size = this.size;\n return SystemProgram.createAccount({\n fromPubkey: this._provider.wallet.publicKey,\n newAccountPubkey: signer.publicKey,\n space: sizeOverride !== null && sizeOverride !== void 0 ? sizeOverride : size,\n lamports: await this._provider.connection.getMinimumBalanceForRentExemption(sizeOverride !== null && sizeOverride !== void 0 ? sizeOverride : size),\n programId: this._programId,\n });\n }\n /**\n * @deprecated since version 14.0.\n *\n * Function returning the associated account. Args are keys to associate.\n * Order matters.\n */\n async associated(...args) {\n const addr = await this.associatedAddress(...args);\n return await this.fetch(addr);\n }\n /**\n * @deprecated since version 14.0.\n *\n * Function returning the associated address. Args are keys to associate.\n * Order matters.\n */\n async associatedAddress(...args) {\n return await pubkeyUtil.associated(this._programId, ...args);\n }\n}\n// Tracks all subscriptions.\nconst subscriptions = new Map();\n//# sourceMappingURL=account.js.map","import assert from \"assert\";\nimport { PublicKey, Transaction, TransactionInstruction, } from \"@solana/web3.js\";\nimport { chunks } from \"../utils/common\";\nimport { translateAddress } from \"../program/common\";\nimport { getProvider } from \"../provider\";\n/**\n * Sends a transaction to a program with the given accounts and instruction\n * data.\n */\nexport async function invoke(programId, accounts, data, provider) {\n programId = translateAddress(programId);\n if (!provider) {\n provider = getProvider();\n }\n const tx = new Transaction();\n tx.add(new TransactionInstruction({\n programId,\n keys: accounts !== null && accounts !== void 0 ? accounts : [],\n data,\n }));\n return await provider.send(tx);\n}\nconst GET_MULTIPLE_ACCOUNTS_LIMIT = 99;\nexport async function getMultipleAccounts(connection, publicKeys) {\n if (publicKeys.length <= GET_MULTIPLE_ACCOUNTS_LIMIT) {\n return await getMultipleAccountsCore(connection, publicKeys);\n }\n else {\n const batches = chunks(publicKeys, GET_MULTIPLE_ACCOUNTS_LIMIT);\n const results = await Promise.all(batches.map((batch) => getMultipleAccountsCore(connection, batch)));\n return results.flat();\n }\n}\nasync function getMultipleAccountsCore(connection, publicKeys) {\n const args = [publicKeys.map((k) => k.toBase58()), { commitment: \"recent\" }];\n // @ts-ignore\n const res = await connection._rpcRequest(\"getMultipleAccounts\", args);\n if (res.error) {\n throw new Error(\"failed to get info about accounts \" +\n publicKeys.map((k) => k.toBase58()).join(\", \") +\n \": \" +\n res.error.message);\n }\n assert(typeof res.result !== \"undefined\");\n const accounts = [];\n for (const account of res.result.value) {\n let value = null;\n if (account === null) {\n accounts.push(null);\n continue;\n }\n if (res.result.value) {\n const { executable, owner, lamports, data } = account;\n assert(data[1] === \"base64\");\n value = {\n executable,\n owner: new PublicKey(owner),\n lamports,\n data: Buffer.from(data[0], \"base64\"),\n };\n }\n if (value === null) {\n throw new Error(\"Invalid response\");\n }\n accounts.push(value);\n }\n return accounts.map((account, idx) => {\n if (account === null) {\n return null;\n }\n return {\n publicKey: publicKeys[idx],\n account,\n };\n });\n}\n//# sourceMappingURL=rpc.js.map","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.deserializeUnchecked = exports.deserialize = exports.serialize = exports.BinaryReader = exports.BinaryWriter = exports.BorshError = exports.baseDecode = exports.baseEncode = void 0;\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst bs58_1 = __importDefault(require(\"bs58\"));\n// TODO: Make sure this polyfill not included when not required\nconst encoding = __importStar(require(\"text-encoding-utf-8\"));\nconst TextDecoder = (typeof global.TextDecoder !== 'function') ? encoding.TextDecoder : global.TextDecoder;\nconst textDecoder = new TextDecoder('utf-8', { fatal: true });\nfunction baseEncode(value) {\n if (typeof (value) === 'string') {\n value = Buffer.from(value, 'utf8');\n }\n return bs58_1.default.encode(Buffer.from(value));\n}\nexports.baseEncode = baseEncode;\nfunction baseDecode(value) {\n return Buffer.from(bs58_1.default.decode(value));\n}\nexports.baseDecode = baseDecode;\nconst INITIAL_LENGTH = 1024;\nclass BorshError extends Error {\n constructor(message) {\n super(message);\n this.fieldPath = [];\n this.originalMessage = message;\n }\n addToFieldPath(fieldName) {\n this.fieldPath.splice(0, 0, fieldName);\n // NOTE: Modifying message directly as jest doesn't use .toString()\n this.message = this.originalMessage + ': ' + this.fieldPath.join('.');\n }\n}\nexports.BorshError = BorshError;\n/// Binary encoder.\nclass BinaryWriter {\n constructor() {\n this.buf = Buffer.alloc(INITIAL_LENGTH);\n this.length = 0;\n }\n maybeResize() {\n if (this.buf.length < 16 + this.length) {\n this.buf = Buffer.concat([this.buf, Buffer.alloc(INITIAL_LENGTH)]);\n }\n }\n writeU8(value) {\n this.maybeResize();\n this.buf.writeUInt8(value, this.length);\n this.length += 1;\n }\n writeU16(value) {\n this.maybeResize();\n this.buf.writeUInt16LE(value, this.length);\n this.length += 2;\n }\n writeU32(value) {\n this.maybeResize();\n this.buf.writeUInt32LE(value, this.length);\n this.length += 4;\n }\n writeU64(value) {\n this.maybeResize();\n this.writeBuffer(Buffer.from(new bn_js_1.default(value).toArray('le', 8)));\n }\n writeU128(value) {\n this.maybeResize();\n this.writeBuffer(Buffer.from(new bn_js_1.default(value).toArray('le', 16)));\n }\n writeU256(value) {\n this.maybeResize();\n this.writeBuffer(Buffer.from(new bn_js_1.default(value).toArray('le', 32)));\n }\n writeU512(value) {\n this.maybeResize();\n this.writeBuffer(Buffer.from(new bn_js_1.default(value).toArray('le', 64)));\n }\n writeBuffer(buffer) {\n // Buffer.from is needed as this.buf.subarray can return plain Uint8Array in browser\n this.buf = Buffer.concat([Buffer.from(this.buf.subarray(0, this.length)), buffer, Buffer.alloc(INITIAL_LENGTH)]);\n this.length += buffer.length;\n }\n writeString(str) {\n this.maybeResize();\n const b = Buffer.from(str, 'utf8');\n this.writeU32(b.length);\n this.writeBuffer(b);\n }\n writeFixedArray(array) {\n this.writeBuffer(Buffer.from(array));\n }\n writeArray(array, fn) {\n this.maybeResize();\n this.writeU32(array.length);\n for (const elem of array) {\n this.maybeResize();\n fn(elem);\n }\n }\n toArray() {\n return this.buf.subarray(0, this.length);\n }\n}\nexports.BinaryWriter = BinaryWriter;\nfunction handlingRangeError(target, propertyKey, propertyDescriptor) {\n const originalMethod = propertyDescriptor.value;\n propertyDescriptor.value = function (...args) {\n try {\n return originalMethod.apply(this, args);\n }\n catch (e) {\n if (e instanceof RangeError) {\n const code = e.code;\n if (['ERR_BUFFER_OUT_OF_BOUNDS', 'ERR_OUT_OF_RANGE'].indexOf(code) >= 0) {\n throw new BorshError('Reached the end of buffer when deserializing');\n }\n }\n throw e;\n }\n };\n}\nclass BinaryReader {\n constructor(buf) {\n this.buf = buf;\n this.offset = 0;\n }\n readU8() {\n const value = this.buf.readUInt8(this.offset);\n this.offset += 1;\n return value;\n }\n readU16() {\n const value = this.buf.readUInt16LE(this.offset);\n this.offset += 2;\n return value;\n }\n readU32() {\n const value = this.buf.readUInt32LE(this.offset);\n this.offset += 4;\n return value;\n }\n readU64() {\n const buf = this.readBuffer(8);\n return new bn_js_1.default(buf, 'le');\n }\n readU128() {\n const buf = this.readBuffer(16);\n return new bn_js_1.default(buf, 'le');\n }\n readU256() {\n const buf = this.readBuffer(32);\n return new bn_js_1.default(buf, 'le');\n }\n readU512() {\n const buf = this.readBuffer(64);\n return new bn_js_1.default(buf, 'le');\n }\n readBuffer(len) {\n if ((this.offset + len) > this.buf.length) {\n throw new BorshError(`Expected buffer length ${len} isn't within bounds`);\n }\n const result = this.buf.slice(this.offset, this.offset + len);\n this.offset += len;\n return result;\n }\n readString() {\n const len = this.readU32();\n const buf = this.readBuffer(len);\n try {\n // NOTE: Using TextDecoder to fail on invalid UTF-8\n return textDecoder.decode(buf);\n }\n catch (e) {\n throw new BorshError(`Error decoding UTF-8 string: ${e}`);\n }\n }\n readFixedArray(len) {\n return new Uint8Array(this.readBuffer(len));\n }\n readArray(fn) {\n const len = this.readU32();\n const result = Array();\n for (let i = 0; i < len; ++i) {\n result.push(fn());\n }\n return result;\n }\n}\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU8\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU16\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU32\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU64\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU128\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU256\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readU512\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readString\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readFixedArray\", null);\n__decorate([\n handlingRangeError\n], BinaryReader.prototype, \"readArray\", null);\nexports.BinaryReader = BinaryReader;\nfunction capitalizeFirstLetter(string) {\n return string.charAt(0).toUpperCase() + string.slice(1);\n}\nfunction serializeField(schema, fieldName, value, fieldType, writer) {\n try {\n // TODO: Handle missing values properly (make sure they never result in just skipped write)\n if (typeof fieldType === 'string') {\n writer[`write${capitalizeFirstLetter(fieldType)}`](value);\n }\n else if (fieldType instanceof Array) {\n if (typeof fieldType[0] === 'number') {\n if (value.length !== fieldType[0]) {\n throw new BorshError(`Expecting byte array of length ${fieldType[0]}, but got ${value.length} bytes`);\n }\n writer.writeFixedArray(value);\n }\n else {\n writer.writeArray(value, (item) => { serializeField(schema, fieldName, item, fieldType[0], writer); });\n }\n }\n else if (fieldType.kind !== undefined) {\n switch (fieldType.kind) {\n case 'option': {\n if (value === null || value === undefined) {\n writer.writeU8(0);\n }\n else {\n writer.writeU8(1);\n serializeField(schema, fieldName, value, fieldType.type, writer);\n }\n break;\n }\n default: throw new BorshError(`FieldType ${fieldType} unrecognized`);\n }\n }\n else {\n serializeStruct(schema, value, writer);\n }\n }\n catch (error) {\n if (error instanceof BorshError) {\n error.addToFieldPath(fieldName);\n }\n throw error;\n }\n}\nfunction serializeStruct(schema, obj, writer) {\n const structSchema = schema.get(obj.constructor);\n if (!structSchema) {\n throw new BorshError(`Class ${obj.constructor.name} is missing in schema`);\n }\n if (structSchema.kind === 'struct') {\n structSchema.fields.map(([fieldName, fieldType]) => {\n serializeField(schema, fieldName, obj[fieldName], fieldType, writer);\n });\n }\n else if (structSchema.kind === 'enum') {\n const name = obj[structSchema.field];\n for (let idx = 0; idx < structSchema.values.length; ++idx) {\n const [fieldName, fieldType] = structSchema.values[idx];\n if (fieldName === name) {\n writer.writeU8(idx);\n serializeField(schema, fieldName, obj[fieldName], fieldType, writer);\n break;\n }\n }\n }\n else {\n throw new BorshError(`Unexpected schema kind: ${structSchema.kind} for ${obj.constructor.name}`);\n }\n}\n/// Serialize given object using schema of the form:\n/// { class_name -> [ [field_name, field_type], .. ], .. }\nfunction serialize(schema, obj) {\n const writer = new BinaryWriter();\n serializeStruct(schema, obj, writer);\n return writer.toArray();\n}\nexports.serialize = serialize;\nfunction deserializeField(schema, fieldName, fieldType, reader) {\n try {\n if (typeof fieldType === 'string') {\n return reader[`read${capitalizeFirstLetter(fieldType)}`]();\n }\n if (fieldType instanceof Array) {\n if (typeof fieldType[0] === 'number') {\n return reader.readFixedArray(fieldType[0]);\n }\n return reader.readArray(() => deserializeField(schema, fieldName, fieldType[0], reader));\n }\n if (fieldType.kind === 'option') {\n const option = reader.readU8();\n if (option) {\n return deserializeField(schema, fieldName, fieldType.type, reader);\n }\n return undefined;\n }\n return deserializeStruct(schema, fieldType, reader);\n }\n catch (error) {\n if (error instanceof BorshError) {\n error.addToFieldPath(fieldName);\n }\n throw error;\n }\n}\nfunction deserializeStruct(schema, classType, reader) {\n const structSchema = schema.get(classType);\n if (!structSchema) {\n throw new BorshError(`Class ${classType.name} is missing in schema`);\n }\n if (structSchema.kind === 'struct') {\n const result = {};\n for (const [fieldName, fieldType] of schema.get(classType).fields) {\n result[fieldName] = deserializeField(schema, fieldName, fieldType, reader);\n }\n return new classType(result);\n }\n if (structSchema.kind === 'enum') {\n const idx = reader.readU8();\n if (idx >= structSchema.values.length) {\n throw new BorshError(`Enum index: ${idx} is out of range`);\n }\n const [fieldName, fieldType] = structSchema.values[idx];\n const fieldValue = deserializeField(schema, fieldName, fieldType, reader);\n return new classType({ [fieldName]: fieldValue });\n }\n throw new BorshError(`Unexpected schema kind: ${structSchema.kind} for ${classType.constructor.name}`);\n}\n/// Deserializes object from bytes using schema.\nfunction deserialize(schema, classType, buffer) {\n const reader = new BinaryReader(buffer);\n const result = deserializeStruct(schema, classType, reader);\n if (reader.offset < buffer.length) {\n throw new BorshError(`Unexpected ${buffer.length - reader.offset} bytes after deserialized data`);\n }\n return result;\n}\nexports.deserialize = deserialize;\n/// Deserializes object from bytes using schema, without checking the length read\nfunction deserializeUnchecked(schema, classType, buffer) {\n const reader = new BinaryReader(buffer);\n return deserializeStruct(schema, classType, reader);\n}\nexports.deserializeUnchecked = deserializeUnchecked;\n","var unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n\n var F = function F() {};\n\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\n\nmodule.exports = _createForOfIteratorHelper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\n\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\n\nvar possibleConstructorReturn = require(\"./possibleConstructorReturn.js\");\n\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return possibleConstructorReturn(this, result);\n };\n}\n\nmodule.exports = _createSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n if (options.type === 'short')\n this.curve = new curve.short(options);\n else if (options.type === 'edwards')\n this.curve = new curve.edwards(options);\n else\n this.curve = new curve.mont(options);\n this.g = this.curve.g;\n this.n = this.curve.n;\n this.hash = options.hash;\n\n assert(this.g.validate(), 'Invalid curve');\n assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n get: function() {\n var curve = new PresetCurve(options);\n Object.defineProperty(curves, name, {\n configurable: true,\n enumerable: true,\n value: curve,\n });\n return curve;\n },\n });\n}\n\ndefineCurve('p192', {\n type: 'short',\n prime: 'p192',\n p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n hash: hash.sha256,\n gRed: false,\n g: [\n '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n ],\n});\n\ndefineCurve('p224', {\n type: 'short',\n prime: 'p224',\n p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n hash: hash.sha256,\n gRed: false,\n g: [\n 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n ],\n});\n\ndefineCurve('p256', {\n type: 'short',\n prime: null,\n p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n hash: hash.sha256,\n gRed: false,\n g: [\n '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n ],\n});\n\ndefineCurve('p384', {\n type: 'short',\n prime: null,\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 ffffffff',\n a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'fffffffe ffffffff 00000000 00000000 fffffffc',\n b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n hash: hash.sha384,\n gRed: false,\n g: [\n 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n '5502f25d bf55296c 3a545e38 72760ab7',\n '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n ],\n});\n\ndefineCurve('p521', {\n type: 'short',\n prime: null,\n p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff',\n a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff ffffffff ffffffff fffffffc',\n b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n hash: hash.sha512,\n gRed: false,\n g: [\n '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n ],\n});\n\ndefineCurve('curve25519', {\n type: 'mont',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '76d06',\n b: '1',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '9',\n ],\n});\n\ndefineCurve('ed25519', {\n type: 'edwards',\n prime: 'p25519',\n p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n a: '-1',\n c: '1',\n // -121665 * (121666^(-1)) (mod P)\n d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n hash: hash.sha256,\n gRed: false,\n g: [\n '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n // 4/5\n '6666666666666666666666666666666666666666666666666666666666666658',\n ],\n});\n\nvar pre;\ntry {\n pre = require('./precomputed/secp256k1');\n} catch (e) {\n pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n type: 'short',\n prime: 'k256',\n p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n a: '0',\n b: '7',\n n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n h: '1',\n hash: hash.sha256,\n\n // Precomputed endomorphism\n beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n basis: [\n {\n a: '3086d221a7d46bcde86c90e49284eb15',\n b: '-e4437ed6010e88286f547fa90abfe4c3',\n },\n {\n a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n b: '3086d221a7d46bcde86c90e49284eb15',\n },\n ],\n\n gRed: false,\n g: [\n '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n pre,\n ],\n});\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n if (isUndefined(debugEnviron))\n debugEnviron = process.env.NODE_DEBUG || '';\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').substr(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.substr(1, name.length - 2);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb, null, ret) },\n function(rej) { process.nextTick(callbackifyOnRejected, rej, cb) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","module.exports = require('./lib')(require('./lib/elliptic'))\n","/**\n * [js-sha3]{@link https://github.com/emn178/js-sha3}\n *\n * @version 0.8.0\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2015-2018\n * @license MIT\n */\n/*jslint bitwise: true */\n(function () {\n 'use strict';\n\n var INPUT_ERROR = 'input is invalid type';\n var FINALIZE_ERROR = 'finalize already called';\n var WINDOW = typeof window === 'object';\n var root = WINDOW ? window : {};\n if (root.JS_SHA3_NO_WINDOW) {\n WINDOW = false;\n }\n var WEB_WORKER = !WINDOW && typeof self === 'object';\n var NODE_JS = !root.JS_SHA3_NO_NODE_JS && typeof process === 'object' && process.versions && process.versions.node;\n if (NODE_JS) {\n root = global;\n } else if (WEB_WORKER) {\n root = self;\n }\n var COMMON_JS = !root.JS_SHA3_NO_COMMON_JS && typeof module === 'object' && module.exports;\n var AMD = typeof define === 'function' && define.amd;\n var ARRAY_BUFFER = !root.JS_SHA3_NO_ARRAY_BUFFER && typeof ArrayBuffer !== 'undefined';\n var HEX_CHARS = '0123456789abcdef'.split('');\n var SHAKE_PADDING = [31, 7936, 2031616, 520093696];\n var CSHAKE_PADDING = [4, 1024, 262144, 67108864];\n var KECCAK_PADDING = [1, 256, 65536, 16777216];\n var PADDING = [6, 1536, 393216, 100663296];\n var SHIFT = [0, 8, 16, 24];\n var RC = [1, 0, 32898, 0, 32906, 2147483648, 2147516416, 2147483648, 32907, 0, 2147483649,\n 0, 2147516545, 2147483648, 32777, 2147483648, 138, 0, 136, 0, 2147516425, 0,\n 2147483658, 0, 2147516555, 0, 139, 2147483648, 32905, 2147483648, 32771,\n 2147483648, 32770, 2147483648, 128, 2147483648, 32778, 0, 2147483658, 2147483648,\n 2147516545, 2147483648, 32896, 2147483648, 2147483649, 0, 2147516424, 2147483648];\n var BITS = [224, 256, 384, 512];\n var SHAKE_BITS = [128, 256];\n var OUTPUT_TYPES = ['hex', 'buffer', 'arrayBuffer', 'array', 'digest'];\n var CSHAKE_BYTEPAD = {\n '128': 168,\n '256': 136\n };\n\n if (root.JS_SHA3_NO_NODE_JS || !Array.isArray) {\n Array.isArray = function (obj) {\n return Object.prototype.toString.call(obj) === '[object Array]';\n };\n }\n\n if (ARRAY_BUFFER && (root.JS_SHA3_NO_ARRAY_BUFFER_IS_VIEW || !ArrayBuffer.isView)) {\n ArrayBuffer.isView = function (obj) {\n return typeof obj === 'object' && obj.buffer && obj.buffer.constructor === ArrayBuffer;\n };\n }\n\n var createOutputMethod = function (bits, padding, outputType) {\n return function (message) {\n return new Keccak(bits, padding, bits).update(message)[outputType]();\n };\n };\n\n var createShakeOutputMethod = function (bits, padding, outputType) {\n return function (message, outputBits) {\n return new Keccak(bits, padding, outputBits).update(message)[outputType]();\n };\n };\n\n var createCshakeOutputMethod = function (bits, padding, outputType) {\n return function (message, outputBits, n, s) {\n return methods['cshake' + bits].update(message, outputBits, n, s)[outputType]();\n };\n };\n\n var createKmacOutputMethod = function (bits, padding, outputType) {\n return function (key, message, outputBits, s) {\n return methods['kmac' + bits].update(key, message, outputBits, s)[outputType]();\n };\n };\n\n var createOutputMethods = function (method, createMethod, bits, padding) {\n for (var i = 0; i < OUTPUT_TYPES.length; ++i) {\n var type = OUTPUT_TYPES[i];\n method[type] = createMethod(bits, padding, type);\n }\n return method;\n };\n\n var createMethod = function (bits, padding) {\n var method = createOutputMethod(bits, padding, 'hex');\n method.create = function () {\n return new Keccak(bits, padding, bits);\n };\n method.update = function (message) {\n return method.create().update(message);\n };\n return createOutputMethods(method, createOutputMethod, bits, padding);\n };\n\n var createShakeMethod = function (bits, padding) {\n var method = createShakeOutputMethod(bits, padding, 'hex');\n method.create = function (outputBits) {\n return new Keccak(bits, padding, outputBits);\n };\n method.update = function (message, outputBits) {\n return method.create(outputBits).update(message);\n };\n return createOutputMethods(method, createShakeOutputMethod, bits, padding);\n };\n\n var createCshakeMethod = function (bits, padding) {\n var w = CSHAKE_BYTEPAD[bits];\n var method = createCshakeOutputMethod(bits, padding, 'hex');\n method.create = function (outputBits, n, s) {\n if (!n && !s) {\n return methods['shake' + bits].create(outputBits);\n } else {\n return new Keccak(bits, padding, outputBits).bytepad([n, s], w);\n }\n };\n method.update = function (message, outputBits, n, s) {\n return method.create(outputBits, n, s).update(message);\n };\n return createOutputMethods(method, createCshakeOutputMethod, bits, padding);\n };\n\n var createKmacMethod = function (bits, padding) {\n var w = CSHAKE_BYTEPAD[bits];\n var method = createKmacOutputMethod(bits, padding, 'hex');\n method.create = function (key, outputBits, s) {\n return new Kmac(bits, padding, outputBits).bytepad(['KMAC', s], w).bytepad([key], w);\n };\n method.update = function (key, message, outputBits, s) {\n return method.create(key, outputBits, s).update(message);\n };\n return createOutputMethods(method, createKmacOutputMethod, bits, padding);\n };\n\n var algorithms = [\n { name: 'keccak', padding: KECCAK_PADDING, bits: BITS, createMethod: createMethod },\n { name: 'sha3', padding: PADDING, bits: BITS, createMethod: createMethod },\n { name: 'shake', padding: SHAKE_PADDING, bits: SHAKE_BITS, createMethod: createShakeMethod },\n { name: 'cshake', padding: CSHAKE_PADDING, bits: SHAKE_BITS, createMethod: createCshakeMethod },\n { name: 'kmac', padding: CSHAKE_PADDING, bits: SHAKE_BITS, createMethod: createKmacMethod }\n ];\n\n var methods = {}, methodNames = [];\n\n for (var i = 0; i < algorithms.length; ++i) {\n var algorithm = algorithms[i];\n var bits = algorithm.bits;\n for (var j = 0; j < bits.length; ++j) {\n var methodName = algorithm.name + '_' + bits[j];\n methodNames.push(methodName);\n methods[methodName] = algorithm.createMethod(bits[j], algorithm.padding);\n if (algorithm.name !== 'sha3') {\n var newMethodName = algorithm.name + bits[j];\n methodNames.push(newMethodName);\n methods[newMethodName] = methods[methodName];\n }\n }\n }\n\n function Keccak(bits, padding, outputBits) {\n this.blocks = [];\n this.s = [];\n this.padding = padding;\n this.outputBits = outputBits;\n this.reset = true;\n this.finalized = false;\n this.block = 0;\n this.start = 0;\n this.blockCount = (1600 - (bits << 1)) >> 5;\n this.byteCount = this.blockCount << 2;\n this.outputBlocks = outputBits >> 5;\n this.extraBytes = (outputBits & 31) >> 3;\n\n for (var i = 0; i < 50; ++i) {\n this.s[i] = 0;\n }\n }\n\n Keccak.prototype.update = function (message) {\n if (this.finalized) {\n throw new Error(FINALIZE_ERROR);\n }\n var notString, type = typeof message;\n if (type !== 'string') {\n if (type === 'object') {\n if (message === null) {\n throw new Error(INPUT_ERROR);\n } else if (ARRAY_BUFFER && message.constructor === ArrayBuffer) {\n message = new Uint8Array(message);\n } else if (!Array.isArray(message)) {\n if (!ARRAY_BUFFER || !ArrayBuffer.isView(message)) {\n throw new Error(INPUT_ERROR);\n }\n }\n } else {\n throw new Error(INPUT_ERROR);\n }\n notString = true;\n }\n var blocks = this.blocks, byteCount = this.byteCount, length = message.length,\n blockCount = this.blockCount, index = 0, s = this.s, i, code;\n\n while (index < length) {\n if (this.reset) {\n this.reset = false;\n blocks[0] = this.block;\n for (i = 1; i < blockCount + 1; ++i) {\n blocks[i] = 0;\n }\n }\n if (notString) {\n for (i = this.start; index < length && i < byteCount; ++index) {\n blocks[i >> 2] |= message[index] << SHIFT[i++ & 3];\n }\n } else {\n for (i = this.start; index < length && i < byteCount; ++index) {\n code = message.charCodeAt(index);\n if (code < 0x80) {\n blocks[i >> 2] |= code << SHIFT[i++ & 3];\n } else if (code < 0x800) {\n blocks[i >> 2] |= (0xc0 | (code >> 6)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n } else if (code < 0xd800 || code >= 0xe000) {\n blocks[i >> 2] |= (0xe0 | (code >> 12)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 6) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n } else {\n code = 0x10000 + (((code & 0x3ff) << 10) | (message.charCodeAt(++index) & 0x3ff));\n blocks[i >> 2] |= (0xf0 | (code >> 18)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 12) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | ((code >> 6) & 0x3f)) << SHIFT[i++ & 3];\n blocks[i >> 2] |= (0x80 | (code & 0x3f)) << SHIFT[i++ & 3];\n }\n }\n }\n this.lastByteIndex = i;\n if (i >= byteCount) {\n this.start = i - byteCount;\n this.block = blocks[blockCount];\n for (i = 0; i < blockCount; ++i) {\n s[i] ^= blocks[i];\n }\n f(s);\n this.reset = true;\n } else {\n this.start = i;\n }\n }\n return this;\n };\n\n Keccak.prototype.encode = function (x, right) {\n var o = x & 255, n = 1;\n var bytes = [o];\n x = x >> 8;\n o = x & 255;\n while (o > 0) {\n bytes.unshift(o);\n x = x >> 8;\n o = x & 255;\n ++n;\n }\n if (right) {\n bytes.push(n);\n } else {\n bytes.unshift(n);\n }\n this.update(bytes);\n return bytes.length;\n };\n\n Keccak.prototype.encodeString = function (str) {\n var notString, type = typeof str;\n if (type !== 'string') {\n if (type === 'object') {\n if (str === null) {\n throw new Error(INPUT_ERROR);\n } else if (ARRAY_BUFFER && str.constructor === ArrayBuffer) {\n str = new Uint8Array(str);\n } else if (!Array.isArray(str)) {\n if (!ARRAY_BUFFER || !ArrayBuffer.isView(str)) {\n throw new Error(INPUT_ERROR);\n }\n }\n } else {\n throw new Error(INPUT_ERROR);\n }\n notString = true;\n }\n var bytes = 0, length = str.length;\n if (notString) {\n bytes = length;\n } else {\n for (var i = 0; i < str.length; ++i) {\n var code = str.charCodeAt(i);\n if (code < 0x80) {\n bytes += 1;\n } else if (code < 0x800) {\n bytes += 2;\n } else if (code < 0xd800 || code >= 0xe000) {\n bytes += 3;\n } else {\n code = 0x10000 + (((code & 0x3ff) << 10) | (str.charCodeAt(++i) & 0x3ff));\n bytes += 4;\n }\n }\n }\n bytes += this.encode(bytes * 8);\n this.update(str);\n return bytes;\n };\n\n Keccak.prototype.bytepad = function (strs, w) {\n var bytes = this.encode(w);\n for (var i = 0; i < strs.length; ++i) {\n bytes += this.encodeString(strs[i]);\n }\n var paddingBytes = w - bytes % w;\n var zeros = [];\n zeros.length = paddingBytes;\n this.update(zeros);\n return this;\n };\n\n Keccak.prototype.finalize = function () {\n if (this.finalized) {\n return;\n }\n this.finalized = true;\n var blocks = this.blocks, i = this.lastByteIndex, blockCount = this.blockCount, s = this.s;\n blocks[i >> 2] |= this.padding[i & 3];\n if (this.lastByteIndex === this.byteCount) {\n blocks[0] = blocks[blockCount];\n for (i = 1; i < blockCount + 1; ++i) {\n blocks[i] = 0;\n }\n }\n blocks[blockCount - 1] |= 0x80000000;\n for (i = 0; i < blockCount; ++i) {\n s[i] ^= blocks[i];\n }\n f(s);\n };\n\n Keccak.prototype.toString = Keccak.prototype.hex = function () {\n this.finalize();\n\n var blockCount = this.blockCount, s = this.s, outputBlocks = this.outputBlocks,\n extraBytes = this.extraBytes, i = 0, j = 0;\n var hex = '', block;\n while (j < outputBlocks) {\n for (i = 0; i < blockCount && j < outputBlocks; ++i, ++j) {\n block = s[i];\n hex += HEX_CHARS[(block >> 4) & 0x0F] + HEX_CHARS[block & 0x0F] +\n HEX_CHARS[(block >> 12) & 0x0F] + HEX_CHARS[(block >> 8) & 0x0F] +\n HEX_CHARS[(block >> 20) & 0x0F] + HEX_CHARS[(block >> 16) & 0x0F] +\n HEX_CHARS[(block >> 28) & 0x0F] + HEX_CHARS[(block >> 24) & 0x0F];\n }\n if (j % blockCount === 0) {\n f(s);\n i = 0;\n }\n }\n if (extraBytes) {\n block = s[i];\n hex += HEX_CHARS[(block >> 4) & 0x0F] + HEX_CHARS[block & 0x0F];\n if (extraBytes > 1) {\n hex += HEX_CHARS[(block >> 12) & 0x0F] + HEX_CHARS[(block >> 8) & 0x0F];\n }\n if (extraBytes > 2) {\n hex += HEX_CHARS[(block >> 20) & 0x0F] + HEX_CHARS[(block >> 16) & 0x0F];\n }\n }\n return hex;\n };\n\n Keccak.prototype.arrayBuffer = function () {\n this.finalize();\n\n var blockCount = this.blockCount, s = this.s, outputBlocks = this.outputBlocks,\n extraBytes = this.extraBytes, i = 0, j = 0;\n var bytes = this.outputBits >> 3;\n var buffer;\n if (extraBytes) {\n buffer = new ArrayBuffer((outputBlocks + 1) << 2);\n } else {\n buffer = new ArrayBuffer(bytes);\n }\n var array = new Uint32Array(buffer);\n while (j < outputBlocks) {\n for (i = 0; i < blockCount && j < outputBlocks; ++i, ++j) {\n array[j] = s[i];\n }\n if (j % blockCount === 0) {\n f(s);\n }\n }\n if (extraBytes) {\n array[i] = s[i];\n buffer = buffer.slice(0, bytes);\n }\n return buffer;\n };\n\n Keccak.prototype.buffer = Keccak.prototype.arrayBuffer;\n\n Keccak.prototype.digest = Keccak.prototype.array = function () {\n this.finalize();\n\n var blockCount = this.blockCount, s = this.s, outputBlocks = this.outputBlocks,\n extraBytes = this.extraBytes, i = 0, j = 0;\n var array = [], offset, block;\n while (j < outputBlocks) {\n for (i = 0; i < blockCount && j < outputBlocks; ++i, ++j) {\n offset = j << 2;\n block = s[i];\n array[offset] = block & 0xFF;\n array[offset + 1] = (block >> 8) & 0xFF;\n array[offset + 2] = (block >> 16) & 0xFF;\n array[offset + 3] = (block >> 24) & 0xFF;\n }\n if (j % blockCount === 0) {\n f(s);\n }\n }\n if (extraBytes) {\n offset = j << 2;\n block = s[i];\n array[offset] = block & 0xFF;\n if (extraBytes > 1) {\n array[offset + 1] = (block >> 8) & 0xFF;\n }\n if (extraBytes > 2) {\n array[offset + 2] = (block >> 16) & 0xFF;\n }\n }\n return array;\n };\n\n function Kmac(bits, padding, outputBits) {\n Keccak.call(this, bits, padding, outputBits);\n }\n\n Kmac.prototype = new Keccak();\n\n Kmac.prototype.finalize = function () {\n this.encode(this.outputBits, true);\n return Keccak.prototype.finalize.call(this);\n };\n\n var f = function (s) {\n var h, l, n, c0, c1, c2, c3, c4, c5, c6, c7, c8, c9,\n b0, b1, b2, b3, b4, b5, b6, b7, b8, b9, b10, b11, b12, b13, b14, b15, b16, b17,\n b18, b19, b20, b21, b22, b23, b24, b25, b26, b27, b28, b29, b30, b31, b32, b33,\n b34, b35, b36, b37, b38, b39, b40, b41, b42, b43, b44, b45, b46, b47, b48, b49;\n for (n = 0; n < 48; n += 2) {\n c0 = s[0] ^ s[10] ^ s[20] ^ s[30] ^ s[40];\n c1 = s[1] ^ s[11] ^ s[21] ^ s[31] ^ s[41];\n c2 = s[2] ^ s[12] ^ s[22] ^ s[32] ^ s[42];\n c3 = s[3] ^ s[13] ^ s[23] ^ s[33] ^ s[43];\n c4 = s[4] ^ s[14] ^ s[24] ^ s[34] ^ s[44];\n c5 = s[5] ^ s[15] ^ s[25] ^ s[35] ^ s[45];\n c6 = s[6] ^ s[16] ^ s[26] ^ s[36] ^ s[46];\n c7 = s[7] ^ s[17] ^ s[27] ^ s[37] ^ s[47];\n c8 = s[8] ^ s[18] ^ s[28] ^ s[38] ^ s[48];\n c9 = s[9] ^ s[19] ^ s[29] ^ s[39] ^ s[49];\n\n h = c8 ^ ((c2 << 1) | (c3 >>> 31));\n l = c9 ^ ((c3 << 1) | (c2 >>> 31));\n s[0] ^= h;\n s[1] ^= l;\n s[10] ^= h;\n s[11] ^= l;\n s[20] ^= h;\n s[21] ^= l;\n s[30] ^= h;\n s[31] ^= l;\n s[40] ^= h;\n s[41] ^= l;\n h = c0 ^ ((c4 << 1) | (c5 >>> 31));\n l = c1 ^ ((c5 << 1) | (c4 >>> 31));\n s[2] ^= h;\n s[3] ^= l;\n s[12] ^= h;\n s[13] ^= l;\n s[22] ^= h;\n s[23] ^= l;\n s[32] ^= h;\n s[33] ^= l;\n s[42] ^= h;\n s[43] ^= l;\n h = c2 ^ ((c6 << 1) | (c7 >>> 31));\n l = c3 ^ ((c7 << 1) | (c6 >>> 31));\n s[4] ^= h;\n s[5] ^= l;\n s[14] ^= h;\n s[15] ^= l;\n s[24] ^= h;\n s[25] ^= l;\n s[34] ^= h;\n s[35] ^= l;\n s[44] ^= h;\n s[45] ^= l;\n h = c4 ^ ((c8 << 1) | (c9 >>> 31));\n l = c5 ^ ((c9 << 1) | (c8 >>> 31));\n s[6] ^= h;\n s[7] ^= l;\n s[16] ^= h;\n s[17] ^= l;\n s[26] ^= h;\n s[27] ^= l;\n s[36] ^= h;\n s[37] ^= l;\n s[46] ^= h;\n s[47] ^= l;\n h = c6 ^ ((c0 << 1) | (c1 >>> 31));\n l = c7 ^ ((c1 << 1) | (c0 >>> 31));\n s[8] ^= h;\n s[9] ^= l;\n s[18] ^= h;\n s[19] ^= l;\n s[28] ^= h;\n s[29] ^= l;\n s[38] ^= h;\n s[39] ^= l;\n s[48] ^= h;\n s[49] ^= l;\n\n b0 = s[0];\n b1 = s[1];\n b32 = (s[11] << 4) | (s[10] >>> 28);\n b33 = (s[10] << 4) | (s[11] >>> 28);\n b14 = (s[20] << 3) | (s[21] >>> 29);\n b15 = (s[21] << 3) | (s[20] >>> 29);\n b46 = (s[31] << 9) | (s[30] >>> 23);\n b47 = (s[30] << 9) | (s[31] >>> 23);\n b28 = (s[40] << 18) | (s[41] >>> 14);\n b29 = (s[41] << 18) | (s[40] >>> 14);\n b20 = (s[2] << 1) | (s[3] >>> 31);\n b21 = (s[3] << 1) | (s[2] >>> 31);\n b2 = (s[13] << 12) | (s[12] >>> 20);\n b3 = (s[12] << 12) | (s[13] >>> 20);\n b34 = (s[22] << 10) | (s[23] >>> 22);\n b35 = (s[23] << 10) | (s[22] >>> 22);\n b16 = (s[33] << 13) | (s[32] >>> 19);\n b17 = (s[32] << 13) | (s[33] >>> 19);\n b48 = (s[42] << 2) | (s[43] >>> 30);\n b49 = (s[43] << 2) | (s[42] >>> 30);\n b40 = (s[5] << 30) | (s[4] >>> 2);\n b41 = (s[4] << 30) | (s[5] >>> 2);\n b22 = (s[14] << 6) | (s[15] >>> 26);\n b23 = (s[15] << 6) | (s[14] >>> 26);\n b4 = (s[25] << 11) | (s[24] >>> 21);\n b5 = (s[24] << 11) | (s[25] >>> 21);\n b36 = (s[34] << 15) | (s[35] >>> 17);\n b37 = (s[35] << 15) | (s[34] >>> 17);\n b18 = (s[45] << 29) | (s[44] >>> 3);\n b19 = (s[44] << 29) | (s[45] >>> 3);\n b10 = (s[6] << 28) | (s[7] >>> 4);\n b11 = (s[7] << 28) | (s[6] >>> 4);\n b42 = (s[17] << 23) | (s[16] >>> 9);\n b43 = (s[16] << 23) | (s[17] >>> 9);\n b24 = (s[26] << 25) | (s[27] >>> 7);\n b25 = (s[27] << 25) | (s[26] >>> 7);\n b6 = (s[36] << 21) | (s[37] >>> 11);\n b7 = (s[37] << 21) | (s[36] >>> 11);\n b38 = (s[47] << 24) | (s[46] >>> 8);\n b39 = (s[46] << 24) | (s[47] >>> 8);\n b30 = (s[8] << 27) | (s[9] >>> 5);\n b31 = (s[9] << 27) | (s[8] >>> 5);\n b12 = (s[18] << 20) | (s[19] >>> 12);\n b13 = (s[19] << 20) | (s[18] >>> 12);\n b44 = (s[29] << 7) | (s[28] >>> 25);\n b45 = (s[28] << 7) | (s[29] >>> 25);\n b26 = (s[38] << 8) | (s[39] >>> 24);\n b27 = (s[39] << 8) | (s[38] >>> 24);\n b8 = (s[48] << 14) | (s[49] >>> 18);\n b9 = (s[49] << 14) | (s[48] >>> 18);\n\n s[0] = b0 ^ (~b2 & b4);\n s[1] = b1 ^ (~b3 & b5);\n s[10] = b10 ^ (~b12 & b14);\n s[11] = b11 ^ (~b13 & b15);\n s[20] = b20 ^ (~b22 & b24);\n s[21] = b21 ^ (~b23 & b25);\n s[30] = b30 ^ (~b32 & b34);\n s[31] = b31 ^ (~b33 & b35);\n s[40] = b40 ^ (~b42 & b44);\n s[41] = b41 ^ (~b43 & b45);\n s[2] = b2 ^ (~b4 & b6);\n s[3] = b3 ^ (~b5 & b7);\n s[12] = b12 ^ (~b14 & b16);\n s[13] = b13 ^ (~b15 & b17);\n s[22] = b22 ^ (~b24 & b26);\n s[23] = b23 ^ (~b25 & b27);\n s[32] = b32 ^ (~b34 & b36);\n s[33] = b33 ^ (~b35 & b37);\n s[42] = b42 ^ (~b44 & b46);\n s[43] = b43 ^ (~b45 & b47);\n s[4] = b4 ^ (~b6 & b8);\n s[5] = b5 ^ (~b7 & b9);\n s[14] = b14 ^ (~b16 & b18);\n s[15] = b15 ^ (~b17 & b19);\n s[24] = b24 ^ (~b26 & b28);\n s[25] = b25 ^ (~b27 & b29);\n s[34] = b34 ^ (~b36 & b38);\n s[35] = b35 ^ (~b37 & b39);\n s[44] = b44 ^ (~b46 & b48);\n s[45] = b45 ^ (~b47 & b49);\n s[6] = b6 ^ (~b8 & b0);\n s[7] = b7 ^ (~b9 & b1);\n s[16] = b16 ^ (~b18 & b10);\n s[17] = b17 ^ (~b19 & b11);\n s[26] = b26 ^ (~b28 & b20);\n s[27] = b27 ^ (~b29 & b21);\n s[36] = b36 ^ (~b38 & b30);\n s[37] = b37 ^ (~b39 & b31);\n s[46] = b46 ^ (~b48 & b40);\n s[47] = b47 ^ (~b49 & b41);\n s[8] = b8 ^ (~b0 & b2);\n s[9] = b9 ^ (~b1 & b3);\n s[18] = b18 ^ (~b10 & b12);\n s[19] = b19 ^ (~b11 & b13);\n s[28] = b28 ^ (~b20 & b22);\n s[29] = b29 ^ (~b21 & b23);\n s[38] = b38 ^ (~b30 & b32);\n s[39] = b39 ^ (~b31 & b33);\n s[48] = b48 ^ (~b40 & b42);\n s[49] = b49 ^ (~b41 & b43);\n\n s[0] ^= RC[n];\n s[1] ^= RC[n + 1];\n }\n };\n\n if (COMMON_JS) {\n module.exports = methods;\n } else {\n for (i = 0; i < methodNames.length; ++i) {\n root[methodNames[i]] = methods[methodNames[i]];\n }\n if (AMD) {\n define(function () {\n return methods;\n });\n }\n }\n})();\n","import { PublicKey } from \"@solana/web3.js\";\nimport * as borsh from \"@project-serum/borsh\";\n// Deterministic IDL address as a function of the program id.\nexport async function idlAddress(programId) {\n const base = (await PublicKey.findProgramAddress([], programId))[0];\n return await PublicKey.createWithSeed(base, seed(), programId);\n}\n// Seed for generating the idlAddress.\nexport function seed() {\n return \"anchor:idl\";\n}\nconst IDL_ACCOUNT_LAYOUT = borsh.struct([\n borsh.publicKey(\"authority\"),\n borsh.vecU8(\"data\"),\n]);\nexport function decodeIdlAccount(data) {\n return IDL_ACCOUNT_LAYOUT.decode(data);\n}\nexport function encodeIdlAccount(acc) {\n const buffer = Buffer.alloc(1000); // TODO: use a tighter buffer.\n const len = IDL_ACCOUNT_LAYOUT.encode(acc, buffer);\n return buffer.slice(0, len);\n}\n//# sourceMappingURL=idl.js.map","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\n\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n if (s === 0)\n return ch32(x, y, z);\n if (s === 1 || s === 3)\n return p32(x, y, z);\n if (s === 2)\n return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n if (!(this instanceof SHA256))\n return new SHA256();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n ];\n this.k = sha256_K;\n this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i++)\n W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n var f = this.h[5];\n var g = this.h[6];\n var h = this.h[7];\n\n assert(this.k.length === W.length);\n for (i = 0; i < W.length; i++) {\n var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n var T2 = sum32(s0_256(a), maj32(a, b, c));\n h = g;\n g = f;\n f = e;\n e = sum32(d, T1);\n d = c;\n c = b;\n b = a;\n a = sum32(T1, T2);\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n this.h[5] = sum32(this.h[5], f);\n this.h[6] = sum32(this.h[6], g);\n this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n if (!(this instanceof SHA512))\n return new SHA512();\n\n BlockHash.call(this);\n this.h = [\n 0x6a09e667, 0xf3bcc908,\n 0xbb67ae85, 0x84caa73b,\n 0x3c6ef372, 0xfe94f82b,\n 0xa54ff53a, 0x5f1d36f1,\n 0x510e527f, 0xade682d1,\n 0x9b05688c, 0x2b3e6c1f,\n 0x1f83d9ab, 0xfb41bd6b,\n 0x5be0cd19, 0x137e2179 ];\n this.k = sha512_K;\n this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n var W = this.W;\n\n // 32 x 32bit words\n for (var i = 0; i < 32; i++)\n W[i] = msg[start + i];\n for (; i < W.length; i += 2) {\n var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2\n var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n var c1_hi = W[i - 14]; // i - 7\n var c1_lo = W[i - 13];\n var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15\n var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n var c3_hi = W[i - 32]; // i - 16\n var c3_lo = W[i - 31];\n\n W[i] = sum64_4_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n W[i + 1] = sum64_4_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo);\n }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n this._prepareBlock(msg, start);\n\n var W = this.W;\n\n var ah = this.h[0];\n var al = this.h[1];\n var bh = this.h[2];\n var bl = this.h[3];\n var ch = this.h[4];\n var cl = this.h[5];\n var dh = this.h[6];\n var dl = this.h[7];\n var eh = this.h[8];\n var el = this.h[9];\n var fh = this.h[10];\n var fl = this.h[11];\n var gh = this.h[12];\n var gl = this.h[13];\n var hh = this.h[14];\n var hl = this.h[15];\n\n assert(this.k.length === W.length);\n for (var i = 0; i < W.length; i += 2) {\n var c0_hi = hh;\n var c0_lo = hl;\n var c1_hi = s1_512_hi(eh, el);\n var c1_lo = s1_512_lo(eh, el);\n var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n var c3_hi = this.k[i];\n var c3_lo = this.k[i + 1];\n var c4_hi = W[i];\n var c4_lo = W[i + 1];\n\n var T1_hi = sum64_5_hi(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n var T1_lo = sum64_5_lo(\n c0_hi, c0_lo,\n c1_hi, c1_lo,\n c2_hi, c2_lo,\n c3_hi, c3_lo,\n c4_hi, c4_lo);\n\n c0_hi = s0_512_hi(ah, al);\n c0_lo = s0_512_lo(ah, al);\n c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n hh = gh;\n hl = gl;\n\n gh = fh;\n gl = fl;\n\n fh = eh;\n fl = el;\n\n eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n dh = ch;\n dl = cl;\n\n ch = bh;\n cl = bl;\n\n bh = ah;\n bl = al;\n\n ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n }\n\n sum64(this.h, 0, ah, al);\n sum64(this.h, 2, bh, bl);\n sum64(this.h, 4, ch, cl);\n sum64(this.h, 6, dh, dl);\n sum64(this.h, 8, eh, el);\n sum64(this.h, 10, fh, fl);\n sum64(this.h, 12, gh, gl);\n sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ ((~xh) & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ ((~xl) & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 28);\n var c1_hi = rotr64_hi(xl, xh, 2); // 34\n var c2_hi = rotr64_hi(xl, xh, 7); // 39\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 28);\n var c1_lo = rotr64_lo(xl, xh, 2); // 34\n var c2_lo = rotr64_lo(xl, xh, 7); // 39\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 14);\n var c1_hi = rotr64_hi(xh, xl, 18);\n var c2_hi = rotr64_hi(xl, xh, 9); // 41\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 14);\n var c1_lo = rotr64_lo(xh, xl, 18);\n var c2_lo = rotr64_lo(xl, xh, 9); // 41\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 1);\n var c1_hi = rotr64_hi(xh, xl, 8);\n var c2_hi = shr64_hi(xh, xl, 7);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 1);\n var c1_lo = rotr64_lo(xh, xl, 8);\n var c2_lo = shr64_lo(xh, xl, 7);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n var c0_hi = rotr64_hi(xh, xl, 19);\n var c1_hi = rotr64_hi(xl, xh, 29); // 61\n var c2_hi = shr64_hi(xh, xl, 6);\n\n var r = c0_hi ^ c1_hi ^ c2_hi;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n var c0_lo = rotr64_lo(xh, xl, 19);\n var c1_lo = rotr64_lo(xl, xh, 29); // 61\n var c2_lo = shr64_lo(xh, xl, 6);\n\n var r = c0_lo ^ c1_lo ^ c2_lo;\n if (r < 0)\n r += 0x100000000;\n return r;\n}\n","/* globals __webpack_amd_options__ */\nmodule.exports = __webpack_amd_options__;\n","/* The MIT License (MIT)\n *\n * Copyright 2015-2018 Peter A. Bigot\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n\n/**\n * Support for translating between Buffer instances and JavaScript\n * native types.\n *\n * {@link module:Layout~Layout|Layout} is the basis of a class\n * hierarchy that associates property names with sequences of encoded\n * bytes.\n *\n * Layouts are supported for these scalar (numeric) types:\n * * {@link module:Layout~UInt|Unsigned integers in little-endian\n * format} with {@link module:Layout.u8|8-bit}, {@link\n * module:Layout.u16|16-bit}, {@link module:Layout.u24|24-bit},\n * {@link module:Layout.u32|32-bit}, {@link\n * module:Layout.u40|40-bit}, and {@link module:Layout.u48|48-bit}\n * representation ranges;\n * * {@link module:Layout~UIntBE|Unsigned integers in big-endian\n * format} with {@link module:Layout.u16be|16-bit}, {@link\n * module:Layout.u24be|24-bit}, {@link module:Layout.u32be|32-bit},\n * {@link module:Layout.u40be|40-bit}, and {@link\n * module:Layout.u48be|48-bit} representation ranges;\n * * {@link module:Layout~Int|Signed integers in little-endian\n * format} with {@link module:Layout.s8|8-bit}, {@link\n * module:Layout.s16|16-bit}, {@link module:Layout.s24|24-bit},\n * {@link module:Layout.s32|32-bit}, {@link\n * module:Layout.s40|40-bit}, and {@link module:Layout.s48|48-bit}\n * representation ranges;\n * * {@link module:Layout~IntBE|Signed integers in big-endian format}\n * with {@link module:Layout.s16be|16-bit}, {@link\n * module:Layout.s24be|24-bit}, {@link module:Layout.s32be|32-bit},\n * {@link module:Layout.s40be|40-bit}, and {@link\n * module:Layout.s48be|48-bit} representation ranges;\n * * 64-bit integral values that decode to an exact (if magnitude is\n * less than 2^53) or nearby integral Number in {@link\n * module:Layout.nu64|unsigned little-endian}, {@link\n * module:Layout.nu64be|unsigned big-endian}, {@link\n * module:Layout.ns64|signed little-endian}, and {@link\n * module:Layout.ns64be|unsigned big-endian} encodings;\n * * 32-bit floating point values with {@link\n * module:Layout.f32|little-endian} and {@link\n * module:Layout.f32be|big-endian} representations;\n * * 64-bit floating point values with {@link\n * module:Layout.f64|little-endian} and {@link\n * module:Layout.f64be|big-endian} representations;\n * * {@link module:Layout.const|Constants} that take no space in the\n * encoded expression.\n *\n * and for these aggregate types:\n * * {@link module:Layout.seq|Sequence}s of instances of a {@link\n * module:Layout~Layout|Layout}, with JavaScript representation as\n * an Array and constant or data-dependent {@link\n * module:Layout~Sequence#count|length};\n * * {@link module:Layout.struct|Structure}s that aggregate a\n * heterogeneous sequence of {@link module:Layout~Layout|Layout}\n * instances, with JavaScript representation as an Object;\n * * {@link module:Layout.union|Union}s that support multiple {@link\n * module:Layout~VariantLayout|variant layouts} over a fixed\n * (padded) or variable (not padded) span of bytes, using an\n * unsigned integer at the start of the data or a separate {@link\n * module:Layout.unionLayoutDiscriminator|layout element} to\n * determine which layout to use when interpreting the buffer\n * contents;\n * * {@link module:Layout.bits|BitStructure}s that contain a sequence\n * of individual {@link\n * module:Layout~BitStructure#addField|BitField}s packed into an 8,\n * 16, 24, or 32-bit unsigned integer starting at the least- or\n * most-significant bit;\n * * {@link module:Layout.cstr|C strings} of varying length;\n * * {@link module:Layout.blob|Blobs} of fixed- or variable-{@link\n * module:Layout~Blob#length|length} raw data.\n *\n * All {@link module:Layout~Layout|Layout} instances are immutable\n * after construction, to prevent internal state from becoming\n * inconsistent.\n *\n * @local Layout\n * @local ExternalLayout\n * @local GreedyCount\n * @local OffsetLayout\n * @local UInt\n * @local UIntBE\n * @local Int\n * @local IntBE\n * @local NearUInt64\n * @local NearUInt64BE\n * @local NearInt64\n * @local NearInt64BE\n * @local Float\n * @local FloatBE\n * @local Double\n * @local DoubleBE\n * @local Sequence\n * @local Structure\n * @local UnionDiscriminator\n * @local UnionLayoutDiscriminator\n * @local Union\n * @local VariantLayout\n * @local BitStructure\n * @local BitField\n * @local Boolean\n * @local Blob\n * @local CString\n * @local Constant\n * @local bindConstructorLayout\n * @module Layout\n * @license MIT\n * @author Peter A. Bigot\n * @see {@link https://github.com/pabigot/buffer-layout|buffer-layout on GitHub}\n */\n\n'use strict';\n\n/**\n * Base class for layout objects.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support the {@link\n * Layout#encode|encode} or {@link Layout#decode|decode} functions.\n *\n * @param {Number} span - Initializer for {@link Layout#span|span}. The\n * parameter must be an integer; a negative value signifies that the\n * span is {@link Layout#getSpan|value-specific}.\n *\n * @param {string} [property] - Initializer for {@link\n * Layout#property|property}.\n *\n * @abstract\n */\nclass Layout {\n constructor(span, property) {\n if (!Number.isInteger(span)) {\n throw new TypeError('span must be an integer');\n }\n\n /** The span of the layout in bytes.\n *\n * Positive values are generally expected.\n *\n * Zero will only appear in {@link Constant}s and in {@link\n * Sequence}s where the {@link Sequence#count|count} is zero.\n *\n * A negative value indicates that the span is value-specific, and\n * must be obtained using {@link Layout#getSpan|getSpan}. */\n this.span = span;\n\n /** The property name used when this layout is represented in an\n * Object.\n *\n * Used only for layouts that {@link Layout#decode|decode} to Object\n * instances. If left undefined the span of the unnamed layout will\n * be treated as padding: it will not be mutated by {@link\n * Layout#encode|encode} nor represented as a property in the\n * decoded Object. */\n this.property = property;\n }\n\n /** Function to create an Object into which decoded properties will\n * be written.\n *\n * Used only for layouts that {@link Layout#decode|decode} to Object\n * instances, which means:\n * * {@link Structure}\n * * {@link Union}\n * * {@link VariantLayout}\n * * {@link BitStructure}\n *\n * If left undefined the JavaScript representation of these layouts\n * will be Object instances.\n *\n * See {@link bindConstructorLayout}.\n */\n makeDestinationObject() {\n return {};\n }\n\n /**\n * Decode from a Buffer into an JavaScript value.\n *\n * @param {Buffer} b - the buffer from which encoded data is read.\n *\n * @param {Number} [offset] - the offset at which the encoded data\n * starts. If absent a zero offset is inferred.\n *\n * @returns {(Number|Array|Object)} - the value of the decoded data.\n *\n * @abstract\n */\n decode(b, offset) {\n throw new Error('Layout is abstract');\n }\n\n /**\n * Encode a JavaScript value into a Buffer.\n *\n * @param {(Number|Array|Object)} src - the value to be encoded into\n * the buffer. The type accepted depends on the (sub-)type of {@link\n * Layout}.\n *\n * @param {Buffer} b - the buffer into which encoded data will be\n * written.\n *\n * @param {Number} [offset] - the offset at which the encoded data\n * starts. If absent a zero offset is inferred.\n *\n * @returns {Number} - the number of bytes encoded, including the\n * space skipped for internal padding, but excluding data such as\n * {@link Sequence#count|lengths} when stored {@link\n * ExternalLayout|externally}. This is the adjustment to `offset`\n * producing the offset where data for the next layout would be\n * written.\n *\n * @abstract\n */\n encode(src, b, offset) {\n throw new Error('Layout is abstract');\n }\n\n /**\n * Calculate the span of a specific instance of a layout.\n *\n * @param {Buffer} b - the buffer that contains an encoded instance.\n *\n * @param {Number} [offset] - the offset at which the encoded instance\n * starts. If absent a zero offset is inferred.\n *\n * @return {Number} - the number of bytes covered by the layout\n * instance. If this method is not overridden in a subclass the\n * definition-time constant {@link Layout#span|span} will be\n * returned.\n *\n * @throws {RangeError} - if the length of the value cannot be\n * determined.\n */\n getSpan(b, offset) {\n if (0 > this.span) {\n throw new RangeError('indeterminate span');\n }\n return this.span;\n }\n\n /**\n * Replicate the layout using a new property.\n *\n * This function must be used to get a structurally-equivalent layout\n * with a different name since all {@link Layout} instances are\n * immutable.\n *\n * **NOTE** This is a shallow copy. All fields except {@link\n * Layout#property|property} are strictly equal to the origin layout.\n *\n * @param {String} property - the value for {@link\n * Layout#property|property} in the replica.\n *\n * @returns {Layout} - the copy with {@link Layout#property|property}\n * set to `property`.\n */\n replicate(property) {\n const rv = Object.create(this.constructor.prototype);\n Object.assign(rv, this);\n rv.property = property;\n return rv;\n }\n\n /**\n * Create an object from layout properties and an array of values.\n *\n * **NOTE** This function returns `undefined` if invoked on a layout\n * that does not return its value as an Object. Objects are\n * returned for things that are a {@link Structure}, which includes\n * {@link VariantLayout|variant layouts} if they are structures, and\n * excludes {@link Union}s. If you want this feature for a union\n * you must use {@link Union.getVariant|getVariant} to select the\n * desired layout.\n *\n * @param {Array} values - an array of values that correspond to the\n * default order for properties. As with {@link Layout#decode|decode}\n * layout elements that have no property name are skipped when\n * iterating over the array values. Only the top-level properties are\n * assigned; arguments are not assigned to properties of contained\n * layouts. Any unused values are ignored.\n *\n * @return {(Object|undefined)}\n */\n fromArray(values) {\n return undefined;\n }\n}\nexports.Layout = Layout;\n\n/* Provide text that carries a name (such as for a function that will\n * be throwing an error) annotated with the property of a given layout\n * (such as one for which the value was unacceptable).\n *\n * @ignore */\nfunction nameWithProperty(name, lo) {\n if (lo.property) {\n return name + '[' + lo.property + ']';\n }\n return name;\n}\nexports.nameWithProperty = nameWithProperty;\n\n/**\n * Augment a class so that instances can be encoded/decoded using a\n * given layout.\n *\n * Calling this function couples `Class` with `layout` in several ways:\n *\n * * `Class.layout_` becomes a static member property equal to `layout`;\n * * `layout.boundConstructor_` becomes a static member property equal\n * to `Class`;\n * * The {@link Layout#makeDestinationObject|makeDestinationObject()}\n * property of `layout` is set to a function that returns a `new\n * Class()`;\n * * `Class.decode(b, offset)` becomes a static member function that\n * delegates to {@link Layout#decode|layout.decode}. The\n * synthesized function may be captured and extended.\n * * `Class.prototype.encode(b, offset)` provides an instance member\n * function that delegates to {@link Layout#encode|layout.encode}\n * with `src` set to `this`. The synthesized function may be\n * captured and extended, but when the extension is invoked `this`\n * must be explicitly bound to the instance.\n *\n * @param {class} Class - a JavaScript class with a nullary\n * constructor.\n *\n * @param {Layout} layout - the {@link Layout} instance used to encode\n * instances of `Class`.\n */\nfunction bindConstructorLayout(Class, layout) {\n if ('function' !== typeof Class) {\n throw new TypeError('Class must be constructor');\n }\n if (Class.hasOwnProperty('layout_')) {\n throw new Error('Class is already bound to a layout');\n }\n if (!(layout && (layout instanceof Layout))) {\n throw new TypeError('layout must be a Layout');\n }\n if (layout.hasOwnProperty('boundConstructor_')) {\n throw new Error('layout is already bound to a constructor');\n }\n Class.layout_ = layout;\n layout.boundConstructor_ = Class;\n layout.makeDestinationObject = (() => new Class());\n Object.defineProperty(Class.prototype, 'encode', {\n value: function(b, offset) {\n return layout.encode(this, b, offset);\n },\n writable: true,\n });\n Object.defineProperty(Class, 'decode', {\n value: function(b, offset) {\n return layout.decode(b, offset);\n },\n writable: true,\n });\n}\nexports.bindConstructorLayout = bindConstructorLayout;\n\n/**\n * An object that behaves like a layout but does not consume space\n * within its containing layout.\n *\n * This is primarily used to obtain metadata about a member, such as a\n * {@link OffsetLayout} that can provide data about a {@link\n * Layout#getSpan|value-specific span}.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support {@link\n * ExternalLayout#isCount|isCount} or other {@link Layout} functions.\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @abstract\n * @augments {Layout}\n */\nclass ExternalLayout extends Layout {\n /**\n * Return `true` iff the external layout decodes to an unsigned\n * integer layout.\n *\n * In that case it can be used as the source of {@link\n * Sequence#count|Sequence counts}, {@link Blob#length|Blob lengths},\n * or as {@link UnionLayoutDiscriminator#layout|external union\n * discriminators}.\n *\n * @abstract\n */\n isCount() {\n throw new Error('ExternalLayout is abstract');\n }\n}\n\n/**\n * An {@link ExternalLayout} that determines its {@link\n * Layout#decode|value} based on offset into and length of the buffer\n * on which it is invoked.\n *\n * *Factory*: {@link module:Layout.greedy|greedy}\n *\n * @param {Number} [elementSpan] - initializer for {@link\n * GreedyCount#elementSpan|elementSpan}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {ExternalLayout}\n */\nclass GreedyCount extends ExternalLayout {\n constructor(elementSpan, property) {\n if (undefined === elementSpan) {\n elementSpan = 1;\n }\n if ((!Number.isInteger(elementSpan)) || (0 >= elementSpan)) {\n throw new TypeError('elementSpan must be a (positive) integer');\n }\n super(-1, property);\n\n /** The layout for individual elements of the sequence. The value\n * must be a positive integer. If not provided, the value will be\n * 1. */\n this.elementSpan = elementSpan;\n }\n\n /** @override */\n isCount() {\n return true;\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const rem = b.length - offset;\n return Math.floor(rem / this.elementSpan);\n }\n\n /** @override */\n encode(src, b, offset) {\n return 0;\n }\n}\n\n/**\n * An {@link ExternalLayout} that supports accessing a {@link Layout}\n * at a fixed offset from the start of another Layout. The offset may\n * be before, within, or after the base layout.\n *\n * *Factory*: {@link module:Layout.offset|offset}\n *\n * @param {Layout} layout - initializer for {@link\n * OffsetLayout#layout|layout}, modulo `property`.\n *\n * @param {Number} [offset] - Initializes {@link\n * OffsetLayout#offset|offset}. Defaults to zero.\n *\n * @param {string} [property] - Optional new property name for a\n * {@link Layout#replicate| replica} of `layout` to be used as {@link\n * OffsetLayout#layout|layout}. If not provided the `layout` is used\n * unchanged.\n *\n * @augments {Layout}\n */\nclass OffsetLayout extends ExternalLayout {\n constructor(layout, offset, property) {\n if (!(layout instanceof Layout)) {\n throw new TypeError('layout must be a Layout');\n }\n\n if (undefined === offset) {\n offset = 0;\n } else if (!Number.isInteger(offset)) {\n throw new TypeError('offset must be integer or undefined');\n }\n\n super(layout.span, property || layout.property);\n\n /** The subordinated layout. */\n this.layout = layout;\n\n /** The location of {@link OffsetLayout#layout} relative to the\n * start of another layout.\n *\n * The value may be positive or negative, but an error will thrown\n * if at the point of use it goes outside the span of the Buffer\n * being accessed. */\n this.offset = offset;\n }\n\n /** @override */\n isCount() {\n return ((this.layout instanceof UInt)\n || (this.layout instanceof UIntBE));\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return this.layout.decode(b, offset + this.offset);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return this.layout.encode(src, b, offset + this.offset);\n }\n}\n\n/**\n * Represent an unsigned integer in little-endian format.\n *\n * *Factory*: {@link module:Layout.u8|u8}, {@link\n * module:Layout.u16|u16}, {@link module:Layout.u24|u24}, {@link\n * module:Layout.u32|u32}, {@link module:Layout.u40|u40}, {@link\n * module:Layout.u48|u48}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass UInt extends Layout {\n constructor(span, property) {\n super(span, property);\n if (6 < this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readUIntLE(offset, this.span);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeUIntLE(src, offset, this.span);\n return this.span;\n }\n}\n\n/**\n * Represent an unsigned integer in big-endian format.\n *\n * *Factory*: {@link module:Layout.u8be|u8be}, {@link\n * module:Layout.u16be|u16be}, {@link module:Layout.u24be|u24be},\n * {@link module:Layout.u32be|u32be}, {@link\n * module:Layout.u40be|u40be}, {@link module:Layout.u48be|u48be}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass UIntBE extends Layout {\n constructor(span, property) {\n super( span, property);\n if (6 < this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readUIntBE(offset, this.span);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeUIntBE(src, offset, this.span);\n return this.span;\n }\n}\n\n/**\n * Represent a signed integer in little-endian format.\n *\n * *Factory*: {@link module:Layout.s8|s8}, {@link\n * module:Layout.s16|s16}, {@link module:Layout.s24|s24}, {@link\n * module:Layout.s32|s32}, {@link module:Layout.s40|s40}, {@link\n * module:Layout.s48|s48}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Int extends Layout {\n constructor(span, property) {\n super(span, property);\n if (6 < this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readIntLE(offset, this.span);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeIntLE(src, offset, this.span);\n return this.span;\n }\n}\n\n/**\n * Represent a signed integer in big-endian format.\n *\n * *Factory*: {@link module:Layout.s8be|s8be}, {@link\n * module:Layout.s16be|s16be}, {@link module:Layout.s24be|s24be},\n * {@link module:Layout.s32be|s32be}, {@link\n * module:Layout.s40be|s40be}, {@link module:Layout.s48be|s48be}\n *\n * @param {Number} span - initializer for {@link Layout#span|span}.\n * The parameter can range from 1 through 6.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass IntBE extends Layout {\n constructor(span, property) {\n super(span, property);\n if (6 < this.span) {\n throw new RangeError('span must not exceed 6 bytes');\n }\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readIntBE(offset, this.span);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeIntBE(src, offset, this.span);\n return this.span;\n }\n}\n\nconst V2E32 = Math.pow(2, 32);\n\n/* True modulus high and low 32-bit words, where low word is always\n * non-negative. */\nfunction divmodInt64(src) {\n const hi32 = Math.floor(src / V2E32);\n const lo32 = src - (hi32 * V2E32);\n return {hi32, lo32};\n}\n/* Reconstruct Number from quotient and non-negative remainder */\nfunction roundedInt64(hi32, lo32) {\n return hi32 * V2E32 + lo32;\n}\n\n/**\n * Represent an unsigned 64-bit integer in little-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.nu64|nu64}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nclass NearUInt64 extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const lo32 = b.readUInt32LE(offset);\n const hi32 = b.readUInt32LE(offset + 4);\n return roundedInt64(hi32, lo32);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const split = divmodInt64(src);\n b.writeUInt32LE(split.lo32, offset);\n b.writeUInt32LE(split.hi32, offset + 4);\n return 8;\n }\n}\n\n/**\n * Represent an unsigned 64-bit integer in big-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.nu64be|nu64be}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nclass NearUInt64BE extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const hi32 = b.readUInt32BE(offset);\n const lo32 = b.readUInt32BE(offset + 4);\n return roundedInt64(hi32, lo32);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const split = divmodInt64(src);\n b.writeUInt32BE(split.hi32, offset);\n b.writeUInt32BE(split.lo32, offset + 4);\n return 8;\n }\n}\n\n/**\n * Represent a signed 64-bit integer in little-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.ns64|ns64}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nclass NearInt64 extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const lo32 = b.readUInt32LE(offset);\n const hi32 = b.readInt32LE(offset + 4);\n return roundedInt64(hi32, lo32);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const split = divmodInt64(src);\n b.writeUInt32LE(split.lo32, offset);\n b.writeInt32LE(split.hi32, offset + 4);\n return 8;\n }\n}\n\n/**\n * Represent a signed 64-bit integer in big-endian format when\n * encoded and as a near integral JavaScript Number when decoded.\n *\n * *Factory*: {@link module:Layout.ns64be|ns64be}\n *\n * **NOTE** Values with magnitude greater than 2^52 may not decode to\n * the exact value of the encoded representation.\n *\n * @augments {Layout}\n */\nclass NearInt64BE extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const hi32 = b.readInt32BE(offset);\n const lo32 = b.readUInt32BE(offset + 4);\n return roundedInt64(hi32, lo32);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const split = divmodInt64(src);\n b.writeInt32BE(split.hi32, offset);\n b.writeUInt32BE(split.lo32, offset + 4);\n return 8;\n }\n}\n\n/**\n * Represent a 32-bit floating point number in little-endian format.\n *\n * *Factory*: {@link module:Layout.f32|f32}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Float extends Layout {\n constructor(property) {\n super(4, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readFloatLE(offset);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeFloatLE(src, offset);\n return 4;\n }\n}\n\n/**\n * Represent a 32-bit floating point number in big-endian format.\n *\n * *Factory*: {@link module:Layout.f32be|f32be}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass FloatBE extends Layout {\n constructor(property) {\n super(4, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readFloatBE(offset);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeFloatBE(src, offset);\n return 4;\n }\n}\n\n/**\n * Represent a 64-bit floating point number in little-endian format.\n *\n * *Factory*: {@link module:Layout.f64|f64}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Double extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readDoubleLE(offset);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeDoubleLE(src, offset);\n return 8;\n }\n}\n\n/**\n * Represent a 64-bit floating point number in big-endian format.\n *\n * *Factory*: {@link module:Layout.f64be|f64be}\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass DoubleBE extends Layout {\n constructor(property) {\n super(8, property);\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n return b.readDoubleBE(offset);\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n b.writeDoubleBE(src, offset);\n return 8;\n }\n}\n\n/**\n * Represent a contiguous sequence of a specific layout as an Array.\n *\n * *Factory*: {@link module:Layout.seq|seq}\n *\n * @param {Layout} elementLayout - initializer for {@link\n * Sequence#elementLayout|elementLayout}.\n *\n * @param {(Number|ExternalLayout)} count - initializer for {@link\n * Sequence#count|count}. The parameter must be either a positive\n * integer or an instance of {@link ExternalLayout}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Sequence extends Layout {\n constructor(elementLayout, count, property) {\n if (!(elementLayout instanceof Layout)) {\n throw new TypeError('elementLayout must be a Layout');\n }\n if (!(((count instanceof ExternalLayout) && count.isCount())\n || (Number.isInteger(count) && (0 <= count)))) {\n throw new TypeError('count must be non-negative integer '\n + 'or an unsigned integer ExternalLayout');\n }\n let span = -1;\n if ((!(count instanceof ExternalLayout))\n && (0 < elementLayout.span)) {\n span = count * elementLayout.span;\n }\n\n super(span, property);\n\n /** The layout for individual elements of the sequence. */\n this.elementLayout = elementLayout;\n\n /** The number of elements in the sequence.\n *\n * This will be either a non-negative integer or an instance of\n * {@link ExternalLayout} for which {@link\n * ExternalLayout#isCount|isCount()} is `true`. */\n this.count = count;\n }\n\n /** @override */\n getSpan(b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n let span = 0;\n let count = this.count;\n if (count instanceof ExternalLayout) {\n count = count.decode(b, offset);\n }\n if (0 < this.elementLayout.span) {\n span = count * this.elementLayout.span;\n } else {\n let idx = 0;\n while (idx < count) {\n span += this.elementLayout.getSpan(b, offset + span);\n ++idx;\n }\n }\n return span;\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const rv = [];\n let i = 0;\n let count = this.count;\n if (count instanceof ExternalLayout) {\n count = count.decode(b, offset);\n }\n while (i < count) {\n rv.push(this.elementLayout.decode(b, offset));\n offset += this.elementLayout.getSpan(b, offset);\n i += 1;\n }\n return rv;\n }\n\n /** Implement {@link Layout#encode|encode} for {@link Sequence}.\n *\n * **NOTE** If `src` is shorter than {@link Sequence#count|count} then\n * the unused space in the buffer is left unchanged. If `src` is\n * longer than {@link Sequence#count|count} the unneeded elements are\n * ignored.\n *\n * **NOTE** If {@link Layout#count|count} is an instance of {@link\n * ExternalLayout} then the length of `src` will be encoded as the\n * count after `src` is encoded. */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const elo = this.elementLayout;\n const span = src.reduce((span, v) => {\n return span + elo.encode(v, b, offset + span);\n }, 0);\n if (this.count instanceof ExternalLayout) {\n this.count.encode(src.length, b, offset);\n }\n return span;\n }\n}\n\n/**\n * Represent a contiguous sequence of arbitrary layout elements as an\n * Object.\n *\n * *Factory*: {@link module:Layout.struct|struct}\n *\n * **NOTE** The {@link Layout#span|span} of the structure is variable\n * if any layout in {@link Structure#fields|fields} has a variable\n * span. When {@link Layout#encode|encoding} we must have a value for\n * all variable-length fields, or we wouldn't be able to figure out\n * how much space to use for storage. We can only identify the value\n * for a field when it has a {@link Layout#property|property}. As\n * such, although a structure may contain both unnamed fields and\n * variable-length fields, it cannot contain an unnamed\n * variable-length field.\n *\n * @param {Layout[]} fields - initializer for {@link\n * Structure#fields|fields}. An error is raised if this contains a\n * variable-length field for which a {@link Layout#property|property}\n * is not defined.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @param {Boolean} [decodePrefixes] - initializer for {@link\n * Structure#decodePrefixes|property}.\n *\n * @throws {Error} - if `fields` contains an unnamed variable-length\n * layout.\n *\n * @augments {Layout}\n */\nclass Structure extends Layout {\n constructor(fields, property, decodePrefixes) {\n if (!(Array.isArray(fields)\n && fields.reduce((acc, v) => acc && (v instanceof Layout), true))) {\n throw new TypeError('fields must be array of Layout instances');\n }\n if (('boolean' === typeof property)\n && (undefined === decodePrefixes)) {\n decodePrefixes = property;\n property = undefined;\n }\n\n /* Verify absence of unnamed variable-length fields. */\n for (const fd of fields) {\n if ((0 > fd.span)\n && (undefined === fd.property)) {\n throw new Error('fields cannot contain unnamed variable-length layout');\n }\n }\n\n let span = -1;\n try {\n span = fields.reduce((span, fd) => span + fd.getSpan(), 0);\n } catch (e) {\n }\n super(span, property);\n\n /** The sequence of {@link Layout} values that comprise the\n * structure.\n *\n * The individual elements need not be the same type, and may be\n * either scalar or aggregate layouts. If a member layout leaves\n * its {@link Layout#property|property} undefined the\n * corresponding region of the buffer associated with the element\n * will not be mutated.\n *\n * @type {Layout[]} */\n this.fields = fields;\n\n /** Control behavior of {@link Layout#decode|decode()} given short\n * buffers.\n *\n * In some situations a structure many be extended with additional\n * fields over time, with older installations providing only a\n * prefix of the full structure. If this property is `true`\n * decoding will accept those buffers and leave subsequent fields\n * undefined, as long as the buffer ends at a field boundary.\n * Defaults to `false`. */\n this.decodePrefixes = !!decodePrefixes;\n }\n\n /** @override */\n getSpan(b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n let span = 0;\n try {\n span = this.fields.reduce((span, fd) => {\n const fsp = fd.getSpan(b, offset);\n offset += fsp;\n return span + fsp;\n }, 0);\n } catch (e) {\n throw new RangeError('indeterminate span');\n }\n return span;\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const dest = this.makeDestinationObject();\n for (const fd of this.fields) {\n if (undefined !== fd.property) {\n dest[fd.property] = fd.decode(b, offset);\n }\n offset += fd.getSpan(b, offset);\n if (this.decodePrefixes\n && (b.length === offset)) {\n break;\n }\n }\n return dest;\n }\n\n /** Implement {@link Layout#encode|encode} for {@link Structure}.\n *\n * If `src` is missing a property for a member with a defined {@link\n * Layout#property|property} the corresponding region of the buffer is\n * left unmodified. */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const firstOffset = offset;\n let lastOffset = 0;\n let lastWrote = 0;\n for (const fd of this.fields) {\n let span = fd.span;\n lastWrote = (0 < span) ? span : 0;\n if (undefined !== fd.property) {\n const fv = src[fd.property];\n if (undefined !== fv) {\n lastWrote = fd.encode(fv, b, offset);\n if (0 > span) {\n /* Read the as-encoded span, which is not necessarily the\n * same as what we wrote. */\n span = fd.getSpan(b, offset);\n }\n }\n }\n lastOffset = offset;\n offset += span;\n }\n /* Use (lastOffset + lastWrote) instead of offset because the last\n * item may have had a dynamic length and we don't want to include\n * the padding between it and the end of the space reserved for\n * it. */\n return (lastOffset + lastWrote) - firstOffset;\n }\n\n /** @override */\n fromArray(values) {\n const dest = this.makeDestinationObject();\n for (const fd of this.fields) {\n if ((undefined !== fd.property)\n && (0 < values.length)) {\n dest[fd.property] = values.shift();\n }\n }\n return dest;\n }\n\n /**\n * Get access to the layout of a given property.\n *\n * @param {String} property - the structure member of interest.\n *\n * @return {Layout} - the layout associated with `property`, or\n * undefined if there is no such property.\n */\n layoutFor(property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n for (const fd of this.fields) {\n if (fd.property === property) {\n return fd;\n }\n }\n }\n\n /**\n * Get the offset of a structure member.\n *\n * @param {String} property - the structure member of interest.\n *\n * @return {Number} - the offset in bytes to the start of `property`\n * within the structure, or undefined if `property` is not a field\n * within the structure. If the property is a member but follows a\n * variable-length structure member a negative number will be\n * returned.\n */\n offsetOf(property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n let offset = 0;\n for (const fd of this.fields) {\n if (fd.property === property) {\n return offset;\n }\n if (0 > fd.span) {\n offset = -1;\n } else if (0 <= offset) {\n offset += fd.span;\n }\n }\n }\n}\n\n/**\n * An object that can provide a {@link\n * Union#discriminator|discriminator} API for {@link Union}.\n *\n * **NOTE** This is an abstract base class; you can create instances\n * if it amuses you, but they won't support the {@link\n * UnionDiscriminator#encode|encode} or {@link\n * UnionDiscriminator#decode|decode} functions.\n *\n * @param {string} [property] - Default for {@link\n * UnionDiscriminator#property|property}.\n *\n * @abstract\n */\nclass UnionDiscriminator {\n constructor(property) {\n /** The {@link Layout#property|property} to be used when the\n * discriminator is referenced in isolation (generally when {@link\n * Union#decode|Union decode} cannot delegate to a specific\n * variant). */\n this.property = property;\n }\n\n /** Analog to {@link Layout#decode|Layout decode} for union discriminators.\n *\n * The implementation of this method need not reference the buffer if\n * variant information is available through other means. */\n decode() {\n throw new Error('UnionDiscriminator is abstract');\n }\n\n /** Analog to {@link Layout#decode|Layout encode} for union discriminators.\n *\n * The implementation of this method need not store the value if\n * variant information is maintained through other means. */\n encode() {\n throw new Error('UnionDiscriminator is abstract');\n }\n}\n\n/**\n * An object that can provide a {@link\n * UnionDiscriminator|discriminator API} for {@link Union} using an\n * unsigned integral {@link Layout} instance located either inside or\n * outside the union.\n *\n * @param {ExternalLayout} layout - initializes {@link\n * UnionLayoutDiscriminator#layout|layout}. Must satisfy {@link\n * ExternalLayout#isCount|isCount()}.\n *\n * @param {string} [property] - Default for {@link\n * UnionDiscriminator#property|property}, superseding the property\n * from `layout`, but defaulting to `variant` if neither `property`\n * nor layout provide a property name.\n *\n * @augments {UnionDiscriminator}\n */\nclass UnionLayoutDiscriminator extends UnionDiscriminator {\n constructor(layout, property) {\n if (!((layout instanceof ExternalLayout)\n && layout.isCount())) {\n throw new TypeError('layout must be an unsigned integer ExternalLayout');\n }\n\n super(property || layout.property || 'variant');\n\n /** The {@link ExternalLayout} used to access the discriminator\n * value. */\n this.layout = layout;\n }\n\n /** Delegate decoding to {@link UnionLayoutDiscriminator#layout|layout}. */\n decode(b, offset) {\n return this.layout.decode(b, offset);\n }\n\n /** Delegate encoding to {@link UnionLayoutDiscriminator#layout|layout}. */\n encode(src, b, offset) {\n return this.layout.encode(src, b, offset);\n }\n}\n\n/**\n * Represent any number of span-compatible layouts.\n *\n * *Factory*: {@link module:Layout.union|union}\n *\n * If the union has a {@link Union#defaultLayout|default layout} that\n * layout must have a non-negative {@link Layout#span|span}. The span\n * of a fixed-span union includes its {@link\n * Union#discriminator|discriminator} if the variant is a {@link\n * Union#usesPrefixDiscriminator|prefix of the union}, plus the span\n * of its {@link Union#defaultLayout|default layout}.\n *\n * If the union does not have a default layout then the encoded span\n * of the union depends on the encoded span of its variant (which may\n * be fixed or variable).\n *\n * {@link VariantLayout#layout|Variant layout}s are added through\n * {@link Union#addVariant|addVariant}. If the union has a default\n * layout, the span of the {@link VariantLayout#layout|layout\n * contained by the variant} must not exceed the span of the {@link\n * Union#defaultLayout|default layout} (minus the span of a {@link\n * Union#usesPrefixDiscriminator|prefix disriminator}, if used). The\n * span of the variant will equal the span of the union itself.\n *\n * The variant for a buffer can only be identified from the {@link\n * Union#discriminator|discriminator} {@link\n * UnionDiscriminator#property|property} (in the case of the {@link\n * Union#defaultLayout|default layout}), or by using {@link\n * Union#getVariant|getVariant} and examining the resulting {@link\n * VariantLayout} instance.\n *\n * A variant compatible with a JavaScript object can be identified\n * using {@link Union#getSourceVariant|getSourceVariant}.\n *\n * @param {(UnionDiscriminator|ExternalLayout|Layout)} discr - How to\n * identify the layout used to interpret the union contents. The\n * parameter must be an instance of {@link UnionDiscriminator}, an\n * {@link ExternalLayout} that satisfies {@link\n * ExternalLayout#isCount|isCount()}, or {@link UInt} (or {@link\n * UIntBE}). When a non-external layout element is passed the layout\n * appears at the start of the union. In all cases the (synthesized)\n * {@link UnionDiscriminator} instance is recorded as {@link\n * Union#discriminator|discriminator}.\n *\n * @param {(Layout|null)} defaultLayout - initializer for {@link\n * Union#defaultLayout|defaultLayout}. If absent defaults to `null`.\n * If `null` there is no default layout: the union has data-dependent\n * length and attempts to decode or encode unrecognized variants will\n * throw an exception. A {@link Layout} instance must have a\n * non-negative {@link Layout#span|span}, and if it lacks a {@link\n * Layout#property|property} the {@link\n * Union#defaultLayout|defaultLayout} will be a {@link\n * Layout#replicate|replica} with property `content`.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Union extends Layout {\n constructor(discr, defaultLayout, property) {\n const upv = ((discr instanceof UInt)\n || (discr instanceof UIntBE));\n if (upv) {\n discr = new UnionLayoutDiscriminator(new OffsetLayout(discr));\n } else if ((discr instanceof ExternalLayout)\n && discr.isCount()) {\n discr = new UnionLayoutDiscriminator(discr);\n } else if (!(discr instanceof UnionDiscriminator)) {\n throw new TypeError('discr must be a UnionDiscriminator '\n + 'or an unsigned integer layout');\n }\n if (undefined === defaultLayout) {\n defaultLayout = null;\n }\n if (!((null === defaultLayout)\n || (defaultLayout instanceof Layout))) {\n throw new TypeError('defaultLayout must be null or a Layout');\n }\n if (null !== defaultLayout) {\n if (0 > defaultLayout.span) {\n throw new Error('defaultLayout must have constant span');\n }\n if (undefined === defaultLayout.property) {\n defaultLayout = defaultLayout.replicate('content');\n }\n }\n\n /* The union span can be estimated only if there's a default\n * layout. The union spans its default layout, plus any prefix\n * variant layout. By construction both layouts, if present, have\n * non-negative span. */\n let span = -1;\n if (defaultLayout) {\n span = defaultLayout.span;\n if ((0 <= span) && upv) {\n span += discr.layout.span;\n }\n }\n super(span, property);\n\n /** The interface for the discriminator value in isolation.\n *\n * This a {@link UnionDiscriminator} either passed to the\n * constructor or synthesized from the `discr` constructor\n * argument. {@link\n * Union#usesPrefixDiscriminator|usesPrefixDiscriminator} will be\n * `true` iff the `discr` parameter was a non-offset {@link\n * Layout} instance. */\n this.discriminator = discr;\n\n /** `true` if the {@link Union#discriminator|discriminator} is the\n * first field in the union.\n *\n * If `false` the discriminator is obtained from somewhere\n * else. */\n this.usesPrefixDiscriminator = upv;\n\n /** The layout for non-discriminator content when the value of the\n * discriminator is not recognized.\n *\n * This is the value passed to the constructor. It is\n * structurally equivalent to the second component of {@link\n * Union#layout|layout} but may have a different property\n * name. */\n this.defaultLayout = defaultLayout;\n\n /** A registry of allowed variants.\n *\n * The keys are unsigned integers which should be compatible with\n * {@link Union.discriminator|discriminator}. The property value\n * is the corresponding {@link VariantLayout} instances assigned\n * to this union by {@link Union#addVariant|addVariant}.\n *\n * **NOTE** The registry remains mutable so that variants can be\n * {@link Union#addVariant|added} at any time. Users should not\n * manipulate the content of this property. */\n this.registry = {};\n\n /* Private variable used when invoking getSourceVariant */\n let boundGetSourceVariant = this.defaultGetSourceVariant.bind(this);\n\n /** Function to infer the variant selected by a source object.\n *\n * Defaults to {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant} but may\n * be overridden using {@link\n * Union#configGetSourceVariant|configGetSourceVariant}.\n *\n * @param {Object} src - as with {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant}.\n *\n * @returns {(undefined|VariantLayout)} The default variant\n * (`undefined`) or first registered variant that uses a property\n * available in `src`. */\n this.getSourceVariant = function(src) {\n return boundGetSourceVariant(src);\n };\n\n /** Function to override the implementation of {@link\n * Union#getSourceVariant|getSourceVariant}.\n *\n * Use this if the desired variant cannot be identified using the\n * algorithm of {@link\n * Union#defaultGetSourceVariant|defaultGetSourceVariant}.\n *\n * **NOTE** The provided function will be invoked bound to this\n * Union instance, providing local access to {@link\n * Union#registry|registry}.\n *\n * @param {Function} gsv - a function that follows the API of\n * {@link Union#defaultGetSourceVariant|defaultGetSourceVariant}. */\n this.configGetSourceVariant = function(gsv) {\n boundGetSourceVariant = gsv.bind(this);\n };\n }\n\n /** @override */\n getSpan(b, offset) {\n if (0 <= this.span) {\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n /* Default layouts always have non-negative span, so we don't have\n * one and we have to recognize the variant which will in turn\n * determine the span. */\n const vlo = this.getVariant(b, offset);\n if (!vlo) {\n throw new Error('unable to determine span for unrecognized variant');\n }\n return vlo.getSpan(b, offset);\n }\n\n /**\n * Method to infer a registered Union variant compatible with `src`.\n *\n * The first satisified rule in the following sequence defines the\n * return value:\n * * If `src` has properties matching the Union discriminator and\n * the default layout, `undefined` is returned regardless of the\n * value of the discriminator property (this ensures the default\n * layout will be used);\n * * If `src` has a property matching the Union discriminator, the\n * value of the discriminator identifies a registered variant, and\n * either (a) the variant has no layout, or (b) `src` has the\n * variant's property, then the variant is returned (because the\n * source satisfies the constraints of the variant it identifies);\n * * If `src` does not have a property matching the Union\n * discriminator, but does have a property matching a registered\n * variant, then the variant is returned (because the source\n * matches a variant without an explicit conflict);\n * * An error is thrown (because we either can't identify a variant,\n * or we were explicitly told the variant but can't satisfy it).\n *\n * @param {Object} src - an object presumed to be compatible with\n * the content of the Union.\n *\n * @return {(undefined|VariantLayout)} - as described above.\n *\n * @throws {Error} - if `src` cannot be associated with a default or\n * registered variant.\n */\n defaultGetSourceVariant(src) {\n if (src.hasOwnProperty(this.discriminator.property)) {\n if (this.defaultLayout\n && src.hasOwnProperty(this.defaultLayout.property)) {\n return undefined;\n }\n const vlo = this.registry[src[this.discriminator.property]];\n if (vlo\n && ((!vlo.layout)\n || src.hasOwnProperty(vlo.property))) {\n return vlo;\n }\n } else {\n for (const tag in this.registry) {\n const vlo = this.registry[tag];\n if (src.hasOwnProperty(vlo.property)) {\n return vlo;\n }\n }\n }\n throw new Error('unable to infer src variant');\n }\n\n /** Implement {@link Layout#decode|decode} for {@link Union}.\n *\n * If the variant is {@link Union#addVariant|registered} the return\n * value is an instance of that variant, with no explicit\n * discriminator. Otherwise the {@link Union#defaultLayout|default\n * layout} is used to decode the content. */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n let dest;\n const dlo = this.discriminator;\n const discr = dlo.decode(b, offset);\n let clo = this.registry[discr];\n if (undefined === clo) {\n let contentOffset = 0;\n clo = this.defaultLayout;\n if (this.usesPrefixDiscriminator) {\n contentOffset = dlo.layout.span;\n }\n dest = this.makeDestinationObject();\n dest[dlo.property] = discr;\n dest[clo.property] = this.defaultLayout.decode(b, offset + contentOffset);\n } else {\n dest = clo.decode(b, offset);\n }\n return dest;\n }\n\n /** Implement {@link Layout#encode|encode} for {@link Union}.\n *\n * This API assumes the `src` object is consistent with the union's\n * {@link Union#defaultLayout|default layout}. To encode variants\n * use the appropriate variant-specific {@link VariantLayout#encode}\n * method. */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const vlo = this.getSourceVariant(src);\n if (undefined === vlo) {\n const dlo = this.discriminator;\n const clo = this.defaultLayout;\n let contentOffset = 0;\n if (this.usesPrefixDiscriminator) {\n contentOffset = dlo.layout.span;\n }\n dlo.encode(src[dlo.property], b, offset);\n return contentOffset + clo.encode(src[clo.property], b,\n offset + contentOffset);\n }\n return vlo.encode(src, b, offset);\n }\n\n /** Register a new variant structure within a union. The newly\n * created variant is returned.\n *\n * @param {Number} variant - initializer for {@link\n * VariantLayout#variant|variant}.\n *\n * @param {Layout} layout - initializer for {@link\n * VariantLayout#layout|layout}.\n *\n * @param {String} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {VariantLayout} */\n addVariant(variant, layout, property) {\n const rv = new VariantLayout(this, variant, layout, property);\n this.registry[variant] = rv;\n return rv;\n }\n\n /**\n * Get the layout associated with a registered variant.\n *\n * If `vb` does not produce a registered variant the function returns\n * `undefined`.\n *\n * @param {(Number|Buffer)} vb - either the variant number, or a\n * buffer from which the discriminator is to be read.\n *\n * @param {Number} offset - offset into `vb` for the start of the\n * union. Used only when `vb` is an instance of {Buffer}.\n *\n * @return {({VariantLayout}|undefined)}\n */\n getVariant(vb, offset) {\n let variant = vb;\n if (Buffer.isBuffer(vb)) {\n if (undefined === offset) {\n offset = 0;\n }\n variant = this.discriminator.decode(vb, offset);\n }\n return this.registry[variant];\n }\n}\n\n/**\n * Represent a specific variant within a containing union.\n *\n * **NOTE** The {@link Layout#span|span} of the variant may include\n * the span of the {@link Union#discriminator|discriminator} used to\n * identify it, but values read and written using the variant strictly\n * conform to the content of {@link VariantLayout#layout|layout}.\n *\n * **NOTE** User code should not invoke this constructor directly. Use\n * the union {@link Union#addVariant|addVariant} helper method.\n *\n * @param {Union} union - initializer for {@link\n * VariantLayout#union|union}.\n *\n * @param {Number} variant - initializer for {@link\n * VariantLayout#variant|variant}.\n *\n * @param {Layout} [layout] - initializer for {@link\n * VariantLayout#layout|layout}. If absent the variant carries no\n * data.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}. Unlike many other layouts, variant\n * layouts normally include a property name so they can be identified\n * within their containing {@link Union}. The property identifier may\n * be absent only if `layout` is is absent.\n *\n * @augments {Layout}\n */\nclass VariantLayout extends Layout {\n constructor(union, variant, layout, property) {\n if (!(union instanceof Union)) {\n throw new TypeError('union must be a Union');\n }\n if ((!Number.isInteger(variant)) || (0 > variant)) {\n throw new TypeError('variant must be a (non-negative) integer');\n }\n if (('string' === typeof layout)\n && (undefined === property)) {\n property = layout;\n layout = null;\n }\n if (layout) {\n if (!(layout instanceof Layout)) {\n throw new TypeError('layout must be a Layout');\n }\n if ((null !== union.defaultLayout)\n && (0 <= layout.span)\n && (layout.span > union.defaultLayout.span)) {\n throw new Error('variant span exceeds span of containing union');\n }\n if ('string' !== typeof property) {\n throw new TypeError('variant must have a String property');\n }\n }\n let span = union.span;\n if (0 > union.span) {\n span = layout ? layout.span : 0;\n if ((0 <= span) && union.usesPrefixDiscriminator) {\n span += union.discriminator.layout.span;\n }\n }\n super(span, property);\n\n /** The {@link Union} to which this variant belongs. */\n this.union = union;\n\n /** The unsigned integral value identifying this variant within\n * the {@link Union#discriminator|discriminator} of the containing\n * union. */\n this.variant = variant;\n\n /** The {@link Layout} to be used when reading/writing the\n * non-discriminator part of the {@link\n * VariantLayout#union|union}. If `null` the variant carries no\n * data. */\n this.layout = layout || null;\n }\n\n /** @override */\n getSpan(b, offset) {\n if (0 <= this.span) {\n /* Will be equal to the containing union span if that is not\n * variable. */\n return this.span;\n }\n if (undefined === offset) {\n offset = 0;\n }\n let contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n /* Span is defined solely by the variant (and prefix discriminator) */\n return contentOffset + this.layout.getSpan(b, offset + contentOffset);\n }\n\n /** @override */\n decode(b, offset) {\n const dest = this.makeDestinationObject();\n if (undefined === offset) {\n offset = 0;\n }\n if (this !== this.union.getVariant(b, offset)) {\n throw new Error('variant mismatch');\n }\n let contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n if (this.layout) {\n dest[this.property] = this.layout.decode(b, offset + contentOffset);\n } else if (this.property) {\n dest[this.property] = true;\n } else if (this.union.usesPrefixDiscriminator) {\n dest[this.union.discriminator.property] = this.variant;\n }\n return dest;\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n let contentOffset = 0;\n if (this.union.usesPrefixDiscriminator) {\n contentOffset = this.union.discriminator.layout.span;\n }\n if (this.layout\n && (!src.hasOwnProperty(this.property))) {\n throw new TypeError('variant lacks property ' + this.property);\n }\n this.union.discriminator.encode(this.variant, b, offset);\n let span = contentOffset;\n if (this.layout) {\n this.layout.encode(src[this.property], b, offset + contentOffset);\n span += this.layout.getSpan(b, offset + contentOffset);\n if ((0 <= this.union.span)\n && (span > this.union.span)) {\n throw new Error('encoded variant overruns containing union');\n }\n }\n return span;\n }\n\n /** Delegate {@link Layout#fromArray|fromArray} to {@link\n * VariantLayout#layout|layout}. */\n fromArray(values) {\n if (this.layout) {\n return this.layout.fromArray(values);\n }\n }\n}\n\n/** JavaScript chose to define bitwise operations as operating on\n * signed 32-bit values in 2's complement form, meaning any integer\n * with bit 31 set is going to look negative. For right shifts that's\n * not a problem, because `>>>` is a logical shift, but for every\n * other bitwise operator we have to compensate for possible negative\n * results. */\nfunction fixBitwiseResult(v) {\n if (0 > v) {\n v += 0x100000000;\n }\n return v;\n}\n\n/**\n * Contain a sequence of bit fields as an unsigned integer.\n *\n * *Factory*: {@link module:Layout.bits|bits}\n *\n * This is a container element; within it there are {@link BitField}\n * instances that provide the extracted properties. The container\n * simply defines the aggregate representation and its bit ordering.\n * The representation is an object containing properties with numeric\n * or {@link Boolean} values.\n *\n * {@link BitField}s are added with the {@link\n * BitStructure#addField|addField} and {@link\n * BitStructure#addBoolean|addBoolean} methods.\n\n * @param {Layout} word - initializer for {@link\n * BitStructure#word|word}. The parameter must be an instance of\n * {@link UInt} (or {@link UIntBE}) that is no more than 4 bytes wide.\n *\n * @param {bool} [msb] - `true` if the bit numbering starts at the\n * most significant bit of the containing word; `false` (default) if\n * it starts at the least significant bit of the containing word. If\n * the parameter at this position is a string and `property` is\n * `undefined` the value of this argument will instead be used as the\n * value of `property`.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass BitStructure extends Layout {\n constructor(word, msb, property) {\n if (!((word instanceof UInt)\n || (word instanceof UIntBE))) {\n throw new TypeError('word must be a UInt or UIntBE layout');\n }\n if (('string' === typeof msb)\n && (undefined === property)) {\n property = msb;\n msb = undefined;\n }\n if (4 < word.span) {\n throw new RangeError('word cannot exceed 32 bits');\n }\n super(word.span, property);\n\n /** The layout used for the packed value. {@link BitField}\n * instances are packed sequentially depending on {@link\n * BitStructure#msb|msb}. */\n this.word = word;\n\n /** Whether the bit sequences are packed starting at the most\n * significant bit growing down (`true`), or the least significant\n * bit growing up (`false`).\n *\n * **NOTE** Regardless of this value, the least significant bit of\n * any {@link BitField} value is the least significant bit of the\n * corresponding section of the packed value. */\n this.msb = !!msb;\n\n /** The sequence of {@link BitField} layouts that comprise the\n * packed structure.\n *\n * **NOTE** The array remains mutable to allow fields to be {@link\n * BitStructure#addField|added} after construction. Users should\n * not manipulate the content of this property.*/\n this.fields = [];\n\n /* Storage for the value. Capture a variable instead of using an\n * instance property because we don't want anything to change the\n * value without going through the mutator. */\n let value = 0;\n this._packedSetValue = function(v) {\n value = fixBitwiseResult(v);\n return this;\n };\n this._packedGetValue = function() {\n return value;\n };\n }\n\n /** @override */\n decode(b, offset) {\n const dest = this.makeDestinationObject();\n if (undefined === offset) {\n offset = 0;\n }\n const value = this.word.decode(b, offset);\n this._packedSetValue(value);\n for (const fd of this.fields) {\n if (undefined !== fd.property) {\n dest[fd.property] = fd.decode(value);\n }\n }\n return dest;\n }\n\n /** Implement {@link Layout#encode|encode} for {@link BitStructure}.\n *\n * If `src` is missing a property for a member with a defined {@link\n * Layout#property|property} the corresponding region of the packed\n * value is left unmodified. Unused bits are also left unmodified. */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n const value = this.word.decode(b, offset);\n this._packedSetValue(value);\n for (const fd of this.fields) {\n if (undefined !== fd.property) {\n const fv = src[fd.property];\n if (undefined !== fv) {\n fd.encode(fv);\n }\n }\n }\n return this.word.encode(this._packedGetValue(), b, offset);\n }\n\n /** Register a new bitfield with a containing bit structure. The\n * resulting bitfield is returned.\n *\n * @param {Number} bits - initializer for {@link BitField#bits|bits}.\n *\n * @param {string} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {BitField} */\n addField(bits, property) {\n const bf = new BitField(this, bits, property);\n this.fields.push(bf);\n return bf;\n }\n\n /** As with {@link BitStructure#addField|addField} for single-bit\n * fields with `boolean` value representation.\n *\n * @param {string} property - initializer for {@link\n * Layout#property|property}.\n *\n * @return {Boolean} */\n addBoolean(property) {\n // This is my Boolean, not the Javascript one.\n // eslint-disable-next-line no-new-wrappers\n const bf = new Boolean(this, property);\n this.fields.push(bf);\n return bf;\n }\n\n /**\n * Get access to the bit field for a given property.\n *\n * @param {String} property - the bit field of interest.\n *\n * @return {BitField} - the field associated with `property`, or\n * undefined if there is no such property.\n */\n fieldFor(property) {\n if ('string' !== typeof property) {\n throw new TypeError('property must be string');\n }\n for (const fd of this.fields) {\n if (fd.property === property) {\n return fd;\n }\n }\n }\n}\n\n/**\n * Represent a sequence of bits within a {@link BitStructure}.\n *\n * All bit field values are represented as unsigned integers.\n *\n * **NOTE** User code should not invoke this constructor directly.\n * Use the container {@link BitStructure#addField|addField} helper\n * method.\n *\n * **NOTE** BitField instances are not instances of {@link Layout}\n * since {@link Layout#span|span} measures 8-bit units.\n *\n * @param {BitStructure} container - initializer for {@link\n * BitField#container|container}.\n *\n * @param {Number} bits - initializer for {@link BitField#bits|bits}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n */\nclass BitField {\n constructor(container, bits, property) {\n if (!(container instanceof BitStructure)) {\n throw new TypeError('container must be a BitStructure');\n }\n if ((!Number.isInteger(bits)) || (0 >= bits)) {\n throw new TypeError('bits must be positive integer');\n }\n const totalBits = 8 * container.span;\n const usedBits = container.fields.reduce((sum, fd) => sum + fd.bits, 0);\n if ((bits + usedBits) > totalBits) {\n throw new Error('bits too long for span remainder ('\n + (totalBits - usedBits) + ' of '\n + totalBits + ' remain)');\n }\n\n /** The {@link BitStructure} instance to which this bit field\n * belongs. */\n this.container = container;\n\n /** The span of this value in bits. */\n this.bits = bits;\n\n /** A mask of {@link BitField#bits|bits} bits isolating value bits\n * that fit within the field.\n *\n * That is, it masks a value that has not yet been shifted into\n * position within its containing packed integer. */\n this.valueMask = (1 << bits) - 1;\n if (32 === bits) { // shifted value out of range\n this.valueMask = 0xFFFFFFFF;\n }\n\n /** The offset of the value within the containing packed unsigned\n * integer. The least significant bit of the packed value is at\n * offset zero, regardless of bit ordering used. */\n this.start = usedBits;\n if (this.container.msb) {\n this.start = totalBits - usedBits - bits;\n }\n\n /** A mask of {@link BitField#bits|bits} isolating the field value\n * within the containing packed unsigned integer. */\n this.wordMask = fixBitwiseResult(this.valueMask << this.start);\n\n /** The property name used when this bitfield is represented in an\n * Object.\n *\n * Intended to be functionally equivalent to {@link\n * Layout#property}.\n *\n * If left undefined the corresponding span of bits will be\n * treated as padding: it will not be mutated by {@link\n * Layout#encode|encode} nor represented as a property in the\n * decoded Object. */\n this.property = property;\n }\n\n /** Store a value into the corresponding subsequence of the containing\n * bit field. */\n decode() {\n const word = this.container._packedGetValue();\n const wordValue = fixBitwiseResult(word & this.wordMask);\n const value = wordValue >>> this.start;\n return value;\n }\n\n /** Store a value into the corresponding subsequence of the containing\n * bit field.\n *\n * **NOTE** This is not a specialization of {@link\n * Layout#encode|Layout.encode} and there is no return value. */\n encode(value) {\n if ((!Number.isInteger(value))\n || (value !== fixBitwiseResult(value & this.valueMask))) {\n throw new TypeError(nameWithProperty('BitField.encode', this)\n + ' value must be integer not exceeding ' + this.valueMask);\n }\n const word = this.container._packedGetValue();\n const wordValue = fixBitwiseResult(value << this.start);\n this.container._packedSetValue(fixBitwiseResult(word & ~this.wordMask)\n | wordValue);\n };\n}\n\n/**\n * Represent a single bit within a {@link BitStructure} as a\n * JavaScript boolean.\n *\n * **NOTE** User code should not invoke this constructor directly.\n * Use the container {@link BitStructure#addBoolean|addBoolean} helper\n * method.\n *\n * @param {BitStructure} container - initializer for {@link\n * BitField#container|container}.\n *\n * @param {string} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {BitField}\n */\n/* eslint-disable no-extend-native */\nclass Boolean extends BitField {\n constructor(container, property) {\n super(container, 1, property);\n }\n\n /** Override {@link BitField#decode|decode} for {@link Boolean|Boolean}.\n *\n * @returns {boolean} */\n decode(b, offset) {\n return !!BitField.prototype.decode.call(this, b, offset);\n }\n\n /** @override */\n encode(value) {\n if ('boolean' === typeof value) {\n // BitField requires integer values\n value = +value;\n }\n return BitField.prototype.encode.call(this, value);\n }\n}\n/* eslint-enable no-extend-native */\n\n/**\n * Contain a fixed-length block of arbitrary data, represented as a\n * Buffer.\n *\n * *Factory*: {@link module:Layout.blob|blob}\n *\n * @param {(Number|ExternalLayout)} length - initializes {@link\n * Blob#length|length}.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Blob extends Layout {\n constructor(length, property) {\n if (!(((length instanceof ExternalLayout) && length.isCount())\n || (Number.isInteger(length) && (0 <= length)))) {\n throw new TypeError('length must be positive integer '\n + 'or an unsigned integer ExternalLayout');\n }\n\n let span = -1;\n if (!(length instanceof ExternalLayout)) {\n span = length;\n }\n super(span, property);\n\n /** The number of bytes in the blob.\n *\n * This may be a non-negative integer, or an instance of {@link\n * ExternalLayout} that satisfies {@link\n * ExternalLayout#isCount|isCount()}. */\n this.length = length;\n }\n\n /** @override */\n getSpan(b, offset) {\n let span = this.span;\n if (0 > span) {\n span = this.length.decode(b, offset);\n }\n return span;\n }\n\n /** @override */\n decode(b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n let span = this.span;\n if (0 > span) {\n span = this.length.decode(b, offset);\n }\n return b.slice(offset, offset + span);\n }\n\n /** Implement {@link Layout#encode|encode} for {@link Blob}.\n *\n * **NOTE** If {@link Layout#count|count} is an instance of {@link\n * ExternalLayout} then the length of `src` will be encoded as the\n * count after `src` is encoded. */\n encode(src, b, offset) {\n let span = this.length;\n if (this.length instanceof ExternalLayout) {\n span = src.length;\n }\n if (!(Buffer.isBuffer(src)\n && (span === src.length))) {\n throw new TypeError(nameWithProperty('Blob.encode', this)\n + ' requires (length ' + span + ') Buffer as src');\n }\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Buffer');\n }\n b.write(src.toString('hex'), offset, span, 'hex');\n if (this.length instanceof ExternalLayout) {\n this.length.encode(span, b, offset);\n }\n return span;\n }\n}\n\n/**\n * Contain a `NUL`-terminated UTF8 string.\n *\n * *Factory*: {@link module:Layout.cstr|cstr}\n *\n * **NOTE** Any UTF8 string that incorporates a zero-valued byte will\n * not be correctly decoded by this layout.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass CString extends Layout {\n constructor(property) {\n super(-1, property);\n }\n\n /** @override */\n getSpan(b, offset) {\n if (!Buffer.isBuffer(b)) {\n throw new TypeError('b must be a Buffer');\n }\n if (undefined === offset) {\n offset = 0;\n }\n let idx = offset;\n while ((idx < b.length) && (0 !== b[idx])) {\n idx += 1;\n }\n return 1 + idx - offset;\n }\n\n /** @override */\n decode(b, offset, dest) {\n if (undefined === offset) {\n offset = 0;\n }\n let span = this.getSpan(b, offset);\n return b.slice(offset, offset + span - 1).toString('utf-8');\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n /* Must force this to a string, lest it be a number and the\n * \"utf8-encoding\" below actually allocate a buffer of length\n * src */\n if ('string' !== typeof src) {\n src = src.toString();\n }\n const srcb = new Buffer(src, 'utf8');\n const span = srcb.length;\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Buffer');\n }\n srcb.copy(b, offset);\n b[offset + span] = 0;\n return span + 1;\n }\n}\n\n/**\n * Contain a UTF8 string with implicit length.\n *\n * *Factory*: {@link module:Layout.utf8|utf8}\n *\n * **NOTE** Because the length is implicit in the size of the buffer\n * this layout should be used only in isolation, or in a situation\n * where the length can be expressed by operating on a slice of the\n * containing buffer.\n *\n * @param {Number} [maxSpan] - the maximum length allowed for encoded\n * string content. If not provided there is no bound on the allowed\n * content.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass UTF8 extends Layout {\n constructor(maxSpan, property) {\n if (('string' === typeof maxSpan)\n && (undefined === property)) {\n property = maxSpan;\n maxSpan = undefined;\n }\n if (undefined === maxSpan) {\n maxSpan = -1;\n } else if (!Number.isInteger(maxSpan)) {\n throw new TypeError('maxSpan must be an integer');\n }\n\n super(-1, property);\n\n /** The maximum span of the layout in bytes.\n *\n * Positive values are generally expected. Zero is abnormal.\n * Attempts to encode or decode a value that exceeds this length\n * will throw a `RangeError`.\n *\n * A negative value indicates that there is no bound on the length\n * of the content. */\n this.maxSpan = maxSpan;\n }\n\n /** @override */\n getSpan(b, offset) {\n if (!Buffer.isBuffer(b)) {\n throw new TypeError('b must be a Buffer');\n }\n if (undefined === offset) {\n offset = 0;\n }\n return b.length - offset;\n }\n\n /** @override */\n decode(b, offset, dest) {\n if (undefined === offset) {\n offset = 0;\n }\n let span = this.getSpan(b, offset);\n if ((0 <= this.maxSpan)\n && (this.maxSpan < span)) {\n throw new RangeError('text length exceeds maxSpan');\n }\n return b.slice(offset, offset + span).toString('utf-8');\n }\n\n /** @override */\n encode(src, b, offset) {\n if (undefined === offset) {\n offset = 0;\n }\n /* Must force this to a string, lest it be a number and the\n * \"utf8-encoding\" below actually allocate a buffer of length\n * src */\n if ('string' !== typeof src) {\n src = src.toString();\n }\n const srcb = new Buffer(src, 'utf8');\n const span = srcb.length;\n if ((0 <= this.maxSpan)\n && (this.maxSpan < span)) {\n throw new RangeError('text length exceeds maxSpan');\n }\n if ((offset + span) > b.length) {\n throw new RangeError('encoding overruns Buffer');\n }\n srcb.copy(b, offset);\n return span;\n }\n}\n\n/**\n * Contain a constant value.\n *\n * This layout may be used in cases where a JavaScript value can be\n * inferred without an expression in the binary encoding. An example\n * would be a {@link VariantLayout|variant layout} where the content\n * is implied by the union {@link Union#discriminator|discriminator}.\n *\n * @param {Object|Number|String} value - initializer for {@link\n * Constant#value|value}. If the value is an object (or array) and\n * the application intends the object to remain unchanged regardless\n * of what is done to values decoded by this layout, the value should\n * be frozen prior passing it to this constructor.\n *\n * @param {String} [property] - initializer for {@link\n * Layout#property|property}.\n *\n * @augments {Layout}\n */\nclass Constant extends Layout {\n constructor(value, property) {\n super(0, property);\n\n /** The value produced by this constant when the layout is {@link\n * Constant#decode|decoded}.\n *\n * Any JavaScript value including `null` and `undefined` is\n * permitted.\n *\n * **WARNING** If `value` passed in the constructor was not\n * frozen, it is possible for users of decoded values to change\n * the content of the value. */\n this.value = value;\n }\n\n /** @override */\n decode(b, offset, dest) {\n return this.value;\n }\n\n /** @override */\n encode(src, b, offset) {\n /* Constants take no space */\n return 0;\n }\n}\n\nexports.ExternalLayout = ExternalLayout;\nexports.GreedyCount = GreedyCount;\nexports.OffsetLayout = OffsetLayout;\nexports.UInt = UInt;\nexports.UIntBE = UIntBE;\nexports.Int = Int;\nexports.IntBE = IntBE;\nexports.Float = Float;\nexports.FloatBE = FloatBE;\nexports.Double = Double;\nexports.DoubleBE = DoubleBE;\nexports.Sequence = Sequence;\nexports.Structure = Structure;\nexports.UnionDiscriminator = UnionDiscriminator;\nexports.UnionLayoutDiscriminator = UnionLayoutDiscriminator;\nexports.Union = Union;\nexports.VariantLayout = VariantLayout;\nexports.BitStructure = BitStructure;\nexports.BitField = BitField;\nexports.Boolean = Boolean;\nexports.Blob = Blob;\nexports.CString = CString;\nexports.UTF8 = UTF8;\nexports.Constant = Constant;\n\n/** Factory for {@link GreedyCount}. */\nexports.greedy = ((elementSpan, property) => new GreedyCount(elementSpan, property));\n\n/** Factory for {@link OffsetLayout}. */\nexports.offset = ((layout, offset, property) => new OffsetLayout(layout, offset, property));\n\n/** Factory for {@link UInt|unsigned int layouts} spanning one\n * byte. */\nexports.u8 = (property => new UInt(1, property));\n\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning two bytes. */\nexports.u16 = (property => new UInt(2, property));\n\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning three bytes. */\nexports.u24 = (property => new UInt(3, property));\n\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning four bytes. */\nexports.u32 = (property => new UInt(4, property));\n\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning five bytes. */\nexports.u40 = (property => new UInt(5, property));\n\n/** Factory for {@link UInt|little-endian unsigned int layouts}\n * spanning six bytes. */\nexports.u48 = (property => new UInt(6, property));\n\n/** Factory for {@link NearUInt64|little-endian unsigned int\n * layouts} interpreted as Numbers. */\nexports.nu64 = (property => new NearUInt64(property));\n\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning two bytes. */\nexports.u16be = (property => new UIntBE(2, property));\n\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning three bytes. */\nexports.u24be = (property => new UIntBE(3, property));\n\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning four bytes. */\nexports.u32be = (property => new UIntBE(4, property));\n\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning five bytes. */\nexports.u40be = (property => new UIntBE(5, property));\n\n/** Factory for {@link UInt|big-endian unsigned int layouts}\n * spanning six bytes. */\nexports.u48be = (property => new UIntBE(6, property));\n\n/** Factory for {@link NearUInt64BE|big-endian unsigned int\n * layouts} interpreted as Numbers. */\nexports.nu64be = (property => new NearUInt64BE(property));\n\n/** Factory for {@link Int|signed int layouts} spanning one\n * byte. */\nexports.s8 = (property => new Int(1, property));\n\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning two bytes. */\nexports.s16 = (property => new Int(2, property));\n\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning three bytes. */\nexports.s24 = (property => new Int(3, property));\n\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning four bytes. */\nexports.s32 = (property => new Int(4, property));\n\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning five bytes. */\nexports.s40 = (property => new Int(5, property));\n\n/** Factory for {@link Int|little-endian signed int layouts}\n * spanning six bytes. */\nexports.s48 = (property => new Int(6, property));\n\n/** Factory for {@link NearInt64|little-endian signed int layouts}\n * interpreted as Numbers. */\nexports.ns64 = (property => new NearInt64(property));\n\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning two bytes. */\nexports.s16be = (property => new IntBE(2, property));\n\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning three bytes. */\nexports.s24be = (property => new IntBE(3, property));\n\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning four bytes. */\nexports.s32be = (property => new IntBE(4, property));\n\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning five bytes. */\nexports.s40be = (property => new IntBE(5, property));\n\n/** Factory for {@link Int|big-endian signed int layouts}\n * spanning six bytes. */\nexports.s48be = (property => new IntBE(6, property));\n\n/** Factory for {@link NearInt64BE|big-endian signed int layouts}\n * interpreted as Numbers. */\nexports.ns64be = (property => new NearInt64BE(property));\n\n/** Factory for {@link Float|little-endian 32-bit floating point} values. */\nexports.f32 = (property => new Float(property));\n\n/** Factory for {@link FloatBE|big-endian 32-bit floating point} values. */\nexports.f32be = (property => new FloatBE(property));\n\n/** Factory for {@link Double|little-endian 64-bit floating point} values. */\nexports.f64 = (property => new Double(property));\n\n/** Factory for {@link DoubleBE|big-endian 64-bit floating point} values. */\nexports.f64be = (property => new DoubleBE(property));\n\n/** Factory for {@link Structure} values. */\nexports.struct = ((fields, property, decodePrefixes) => new Structure(fields, property, decodePrefixes));\n\n/** Factory for {@link BitStructure} values. */\nexports.bits = ((word, msb, property) => new BitStructure(word, msb, property));\n\n/** Factory for {@link Sequence} values. */\nexports.seq = ((elementLayout, count, property) => new Sequence(elementLayout, count, property));\n\n/** Factory for {@link Union} values. */\nexports.union = ((discr, defaultLayout, property) => new Union(discr, defaultLayout, property));\n\n/** Factory for {@link UnionLayoutDiscriminator} values. */\nexports.unionLayoutDiscriminator = ((layout, property) => new UnionLayoutDiscriminator(layout, property));\n\n/** Factory for {@link Blob} values. */\nexports.blob = ((length, property) => new Blob(length, property));\n\n/** Factory for {@link CString} values. */\nexports.cstr = (property => new CString(property));\n\n/** Factory for {@link UTF8} values. */\nexports.utf8 = ((maxSpan, property) => new UTF8(maxSpan, property));\n\n/** Factory for {@link Constant} values. */\nexports.const = ((value, property) => new Constant(value, property));\n","export function encode(data) {\n return data.reduce((str, byte) => str + byte.toString(16).padStart(2, \"0\"), \"0x\");\n}\nexport function decode(data) {\n if (data.indexOf(\"0x\") === 0) {\n data = data.substr(2);\n }\n if (data.length % 2 === 1) {\n data = \"0\" + data;\n }\n let key = data.match(/.{2}/g);\n if (key === null) {\n return Buffer.from([]);\n }\n return Buffer.from(key.map((byte) => parseInt(byte, 16)));\n}\n//# sourceMappingURL=hex.js.map","import * as base64 from \"base64-js\";\nexport function encode(data) {\n return base64.fromByteArray(data);\n}\nexport function decode(data) {\n return Buffer.from(base64.toByteArray(data));\n}\n//# sourceMappingURL=base64.js.map","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nvar getRandomValues;\nvar rnds8 = new Uint8Array(16);\nexport default function rng() {\n // lazy load so that environments that need to polyfill have a chance to do so\n if (!getRandomValues) {\n // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation. Also,\n // find the complete implementation of crypto (msCrypto) on IE11.\n getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);\n\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n }\n\n return getRandomValues(rnds8);\n}","export default /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nvar byteToHex = [];\n\nfor (var i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import rng from './rng.js';\nimport stringify from './stringify.js'; // **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\n\nvar _clockseq; // Previous uuid creation time\n\n\nvar _lastMSecs = 0;\nvar _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || new Array(16);\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n var seedBytes = options.random || (options.rng || rng)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n var msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n var tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || stringify(b);\n}\n\nexport default v1;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n var v;\n var arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import stringify from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n var bytes = [];\n\n for (var i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport var DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport var URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function (name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n var bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return stringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","/*\n * Browser-compatible JavaScript MD5\n *\n * Modification of JavaScript MD5\n * https://github.com/blueimp/JavaScript-MD5\n *\n * Copyright 2011, Sebastian Tschan\n * https://blueimp.net\n *\n * Licensed under the MIT license:\n * https://opensource.org/licenses/MIT\n *\n * Based on\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\nfunction md5(bytes) {\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = new Uint8Array(msg.length);\n\n for (var i = 0; i < msg.length; ++i) {\n bytes[i] = msg.charCodeAt(i);\n }\n }\n\n return md5ToHexEncodedArray(wordsToMd5(bytesToWords(bytes), bytes.length * 8));\n}\n/*\n * Convert an array of little-endian words to an array of bytes\n */\n\n\nfunction md5ToHexEncodedArray(input) {\n var output = [];\n var length32 = input.length * 32;\n var hexTab = '0123456789abcdef';\n\n for (var i = 0; i < length32; i += 8) {\n var x = input[i >> 5] >>> i % 32 & 0xff;\n var hex = parseInt(hexTab.charAt(x >>> 4 & 0x0f) + hexTab.charAt(x & 0x0f), 16);\n output.push(hex);\n }\n\n return output;\n}\n/**\n * Calculate output length with padding and bit length\n */\n\n\nfunction getOutputLength(inputLength8) {\n return (inputLength8 + 64 >>> 9 << 4) + 14 + 1;\n}\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length.\n */\n\n\nfunction wordsToMd5(x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << len % 32;\n x[getOutputLength(len) - 1] = len;\n var a = 1732584193;\n var b = -271733879;\n var c = -1732584194;\n var d = 271733878;\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a;\n var oldb = b;\n var oldc = c;\n var oldd = d;\n a = md5ff(a, b, c, d, x[i], 7, -680876936);\n d = md5ff(d, a, b, c, x[i + 1], 12, -389564586);\n c = md5ff(c, d, a, b, x[i + 2], 17, 606105819);\n b = md5ff(b, c, d, a, x[i + 3], 22, -1044525330);\n a = md5ff(a, b, c, d, x[i + 4], 7, -176418897);\n d = md5ff(d, a, b, c, x[i + 5], 12, 1200080426);\n c = md5ff(c, d, a, b, x[i + 6], 17, -1473231341);\n b = md5ff(b, c, d, a, x[i + 7], 22, -45705983);\n a = md5ff(a, b, c, d, x[i + 8], 7, 1770035416);\n d = md5ff(d, a, b, c, x[i + 9], 12, -1958414417);\n c = md5ff(c, d, a, b, x[i + 10], 17, -42063);\n b = md5ff(b, c, d, a, x[i + 11], 22, -1990404162);\n a = md5ff(a, b, c, d, x[i + 12], 7, 1804603682);\n d = md5ff(d, a, b, c, x[i + 13], 12, -40341101);\n c = md5ff(c, d, a, b, x[i + 14], 17, -1502002290);\n b = md5ff(b, c, d, a, x[i + 15], 22, 1236535329);\n a = md5gg(a, b, c, d, x[i + 1], 5, -165796510);\n d = md5gg(d, a, b, c, x[i + 6], 9, -1069501632);\n c = md5gg(c, d, a, b, x[i + 11], 14, 643717713);\n b = md5gg(b, c, d, a, x[i], 20, -373897302);\n a = md5gg(a, b, c, d, x[i + 5], 5, -701558691);\n d = md5gg(d, a, b, c, x[i + 10], 9, 38016083);\n c = md5gg(c, d, a, b, x[i + 15], 14, -660478335);\n b = md5gg(b, c, d, a, x[i + 4], 20, -405537848);\n a = md5gg(a, b, c, d, x[i + 9], 5, 568446438);\n d = md5gg(d, a, b, c, x[i + 14], 9, -1019803690);\n c = md5gg(c, d, a, b, x[i + 3], 14, -187363961);\n b = md5gg(b, c, d, a, x[i + 8], 20, 1163531501);\n a = md5gg(a, b, c, d, x[i + 13], 5, -1444681467);\n d = md5gg(d, a, b, c, x[i + 2], 9, -51403784);\n c = md5gg(c, d, a, b, x[i + 7], 14, 1735328473);\n b = md5gg(b, c, d, a, x[i + 12], 20, -1926607734);\n a = md5hh(a, b, c, d, x[i + 5], 4, -378558);\n d = md5hh(d, a, b, c, x[i + 8], 11, -2022574463);\n c = md5hh(c, d, a, b, x[i + 11], 16, 1839030562);\n b = md5hh(b, c, d, a, x[i + 14], 23, -35309556);\n a = md5hh(a, b, c, d, x[i + 1], 4, -1530992060);\n d = md5hh(d, a, b, c, x[i + 4], 11, 1272893353);\n c = md5hh(c, d, a, b, x[i + 7], 16, -155497632);\n b = md5hh(b, c, d, a, x[i + 10], 23, -1094730640);\n a = md5hh(a, b, c, d, x[i + 13], 4, 681279174);\n d = md5hh(d, a, b, c, x[i], 11, -358537222);\n c = md5hh(c, d, a, b, x[i + 3], 16, -722521979);\n b = md5hh(b, c, d, a, x[i + 6], 23, 76029189);\n a = md5hh(a, b, c, d, x[i + 9], 4, -640364487);\n d = md5hh(d, a, b, c, x[i + 12], 11, -421815835);\n c = md5hh(c, d, a, b, x[i + 15], 16, 530742520);\n b = md5hh(b, c, d, a, x[i + 2], 23, -995338651);\n a = md5ii(a, b, c, d, x[i], 6, -198630844);\n d = md5ii(d, a, b, c, x[i + 7], 10, 1126891415);\n c = md5ii(c, d, a, b, x[i + 14], 15, -1416354905);\n b = md5ii(b, c, d, a, x[i + 5], 21, -57434055);\n a = md5ii(a, b, c, d, x[i + 12], 6, 1700485571);\n d = md5ii(d, a, b, c, x[i + 3], 10, -1894986606);\n c = md5ii(c, d, a, b, x[i + 10], 15, -1051523);\n b = md5ii(b, c, d, a, x[i + 1], 21, -2054922799);\n a = md5ii(a, b, c, d, x[i + 8], 6, 1873313359);\n d = md5ii(d, a, b, c, x[i + 15], 10, -30611744);\n c = md5ii(c, d, a, b, x[i + 6], 15, -1560198380);\n b = md5ii(b, c, d, a, x[i + 13], 21, 1309151649);\n a = md5ii(a, b, c, d, x[i + 4], 6, -145523070);\n d = md5ii(d, a, b, c, x[i + 11], 10, -1120210379);\n c = md5ii(c, d, a, b, x[i + 2], 15, 718787259);\n b = md5ii(b, c, d, a, x[i + 9], 21, -343485551);\n a = safeAdd(a, olda);\n b = safeAdd(b, oldb);\n c = safeAdd(c, oldc);\n d = safeAdd(d, oldd);\n }\n\n return [a, b, c, d];\n}\n/*\n * Convert an array bytes to an array of little-endian words\n * Characters >255 have their high-byte silently ignored.\n */\n\n\nfunction bytesToWords(input) {\n if (input.length === 0) {\n return [];\n }\n\n var length8 = input.length * 8;\n var output = new Uint32Array(getOutputLength(length8));\n\n for (var i = 0; i < length8; i += 8) {\n output[i >> 5] |= (input[i / 8] & 0xff) << i % 32;\n }\n\n return output;\n}\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\n\n\nfunction safeAdd(x, y) {\n var lsw = (x & 0xffff) + (y & 0xffff);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return msw << 16 | lsw & 0xffff;\n}\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\n\n\nfunction bitRotateLeft(num, cnt) {\n return num << cnt | num >>> 32 - cnt;\n}\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\n\n\nfunction md5cmn(q, a, b, x, s, t) {\n return safeAdd(bitRotateLeft(safeAdd(safeAdd(a, q), safeAdd(x, t)), s), b);\n}\n\nfunction md5ff(a, b, c, d, x, s, t) {\n return md5cmn(b & c | ~b & d, a, b, x, s, t);\n}\n\nfunction md5gg(a, b, c, d, x, s, t) {\n return md5cmn(b & d | c & ~d, a, b, x, s, t);\n}\n\nfunction md5hh(a, b, c, d, x, s, t) {\n return md5cmn(b ^ c ^ d, a, b, x, s, t);\n}\n\nfunction md5ii(a, b, c, d, x, s, t) {\n return md5cmn(c ^ (b | ~d), a, b, x, s, t);\n}\n\nexport default md5;","import v35 from './v35.js';\nimport md5 from './md5.js';\nvar v3 = v35('v3', 0x30, md5);\nexport default v3;","import rng from './rng.js';\nimport stringify from './stringify.js';\n\nfunction v4(options, buf, offset) {\n options = options || {};\n var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return stringify(rnds);\n}\n\nexport default v4;","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return x & y ^ ~x & z;\n\n case 1:\n return x ^ y ^ z;\n\n case 2:\n return x & y ^ x & z ^ y & z;\n\n case 3:\n return x ^ y ^ z;\n }\n}\n\nfunction ROTL(x, n) {\n return x << n | x >>> 32 - n;\n}\n\nfunction sha1(bytes) {\n var K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n var H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = [];\n\n for (var i = 0; i < msg.length; ++i) {\n bytes.push(msg.charCodeAt(i));\n }\n } else if (!Array.isArray(bytes)) {\n // Convert Array-like to Array\n bytes = Array.prototype.slice.call(bytes);\n }\n\n bytes.push(0x80);\n var l = bytes.length / 4 + 2;\n var N = Math.ceil(l / 16);\n var M = new Array(N);\n\n for (var _i = 0; _i < N; ++_i) {\n var arr = new Uint32Array(16);\n\n for (var j = 0; j < 16; ++j) {\n arr[j] = bytes[_i * 64 + j * 4] << 24 | bytes[_i * 64 + j * 4 + 1] << 16 | bytes[_i * 64 + j * 4 + 2] << 8 | bytes[_i * 64 + j * 4 + 3];\n }\n\n M[_i] = arr;\n }\n\n M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = (bytes.length - 1) * 8 & 0xffffffff;\n\n for (var _i2 = 0; _i2 < N; ++_i2) {\n var W = new Uint32Array(80);\n\n for (var t = 0; t < 16; ++t) {\n W[t] = M[_i2][t];\n }\n\n for (var _t = 16; _t < 80; ++_t) {\n W[_t] = ROTL(W[_t - 3] ^ W[_t - 8] ^ W[_t - 14] ^ W[_t - 16], 1);\n }\n\n var a = H[0];\n var b = H[1];\n var c = H[2];\n var d = H[3];\n var e = H[4];\n\n for (var _t2 = 0; _t2 < 80; ++_t2) {\n var s = Math.floor(_t2 / 20);\n var T = ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[_t2] >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n\n H[0] = H[0] + a >>> 0;\n H[1] = H[1] + b >>> 0;\n H[2] = H[2] + c >>> 0;\n H[3] = H[3] + d >>> 0;\n H[4] = H[4] + e >>> 0;\n }\n\n return [H[0] >> 24 & 0xff, H[0] >> 16 & 0xff, H[0] >> 8 & 0xff, H[0] & 0xff, H[1] >> 24 & 0xff, H[1] >> 16 & 0xff, H[1] >> 8 & 0xff, H[1] & 0xff, H[2] >> 24 & 0xff, H[2] >> 16 & 0xff, H[2] >> 8 & 0xff, H[2] & 0xff, H[3] >> 24 & 0xff, H[3] >> 16 & 0xff, H[3] >> 8 & 0xff, H[3] & 0xff, H[4] >> 24 & 0xff, H[4] >> 16 & 0xff, H[4] >> 8 & 0xff, H[4] & 0xff];\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nvar v5 = v35('v5', 0x50, sha1);\nexport default v5;","export default '00000000-0000-0000-0000-000000000000';","import validate from './validate.js';\n\nfunction version(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nexport default version;","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Client = void 0;\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _inherits2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inherits\"));\n\nvar _possibleConstructorReturn2 = _interopRequireDefault(require(\"@babel/runtime/helpers/possibleConstructorReturn\"));\n\nvar _getPrototypeOf2 = _interopRequireDefault(require(\"@babel/runtime/helpers/getPrototypeOf\"));\n\nvar _websocket = _interopRequireDefault(require(\"./lib/client/websocket.browser\"));\n\nvar _client = _interopRequireDefault(require(\"./lib/client\"));\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2[\"default\"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2[\"default\"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2[\"default\"])(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nvar Client = /*#__PURE__*/function (_CommonClient) {\n (0, _inherits2[\"default\"])(Client, _CommonClient);\n\n var _super = _createSuper(Client);\n\n function Client() {\n var address = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : \"ws://localhost:8080\";\n\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$autoconnect = _ref.autoconnect,\n autoconnect = _ref$autoconnect === void 0 ? true : _ref$autoconnect,\n _ref$reconnect = _ref.reconnect,\n reconnect = _ref$reconnect === void 0 ? true : _ref$reconnect,\n _ref$reconnect_interv = _ref.reconnect_interval,\n reconnect_interval = _ref$reconnect_interv === void 0 ? 1000 : _ref$reconnect_interv,\n _ref$max_reconnects = _ref.max_reconnects,\n max_reconnects = _ref$max_reconnects === void 0 ? 5 : _ref$max_reconnects;\n\n var generate_request_id = arguments.length > 2 ? arguments[2] : undefined;\n (0, _classCallCheck2[\"default\"])(this, Client);\n return _super.call(this, _websocket[\"default\"], address, {\n autoconnect: autoconnect,\n reconnect: reconnect,\n reconnect_interval: reconnect_interval,\n max_reconnects: max_reconnects\n }, generate_request_id);\n }\n\n return Client;\n}(_client[\"default\"]);\n\nexports.Client = Client;","'use strict';\n\nconst uuid = require('uuid').v4;\nconst generateRequest = require('../../generateRequest');\n\n/**\n * Constructor for a Jayson Browser Client that does not depend any node.js core libraries\n * @class ClientBrowser\n * @param {Function} callServer Method that calls the server, receives the stringified request and a regular node-style callback\n * @param {Object} [options]\n * @param {Function} [options.reviver] Reviver function for JSON\n * @param {Function} [options.replacer] Replacer function for JSON\n * @param {Number} [options.version=2] JSON-RPC version to use (1|2)\n * @param {Function} [options.generator] Function to use for generating request IDs\n * @param {Boolean} [options.notificationIdNull=false] When true, version 2 requests will set id to null instead of omitting it\n * @return {ClientBrowser}\n */\nconst ClientBrowser = function(callServer, options) {\n if(!(this instanceof ClientBrowser)) {\n return new ClientBrowser(callServer, options);\n }\n\n if (!options) {\n options = {};\n }\n\n this.options = {\n reviver: typeof options.reviver !== 'undefined' ? options.reviver : null,\n replacer: typeof options.replacer !== 'undefined' ? options.replacer : null,\n generator: typeof options.generator !== 'undefined' ? options.generator : function() { return uuid(); },\n version: typeof options.version !== 'undefined' ? options.version : 2,\n notificationIdNull: typeof options.notificationIdNull === 'boolean' ? options.notificationIdNull : false,\n };\n\n this.callServer = callServer;\n};\n\nmodule.exports = ClientBrowser;\n\n/**\n * Creates a request and dispatches it if given a callback.\n * @param {String|Array} method A batch request if passed an Array, or a method name if passed a String\n * @param {Array|Object} [params] Parameters for the method\n * @param {String|Number} [id] Optional id. If undefined an id will be generated. If null it creates a notification request\n * @param {Function} [callback] Request callback. If specified, executes the request rather than only returning it.\n * @throws {TypeError} Invalid parameters\n * @return {Object} JSON-RPC 1.0 or 2.0 compatible request\n */\nClientBrowser.prototype.request = function(method, params, id, callback) {\n const self = this;\n let request = null;\n\n // is this a batch request?\n const isBatch = Array.isArray(method) && typeof params === 'function';\n\n if (this.options.version === 1 && isBatch) {\n throw new TypeError('JSON-RPC 1.0 does not support batching');\n }\n\n // is this a raw request?\n const isRaw = !isBatch && method && typeof method === 'object' && typeof params === 'function';\n\n if(isBatch || isRaw) {\n callback = params;\n request = method;\n } else {\n if(typeof id === 'function') {\n callback = id;\n // specifically undefined because \"null\" is a notification request\n id = undefined;\n }\n\n const hasCallback = typeof callback === 'function';\n\n try {\n request = generateRequest(method, params, id, {\n generator: this.options.generator,\n version: this.options.version,\n notificationIdNull: this.options.notificationIdNull,\n });\n } catch(err) {\n if(hasCallback) {\n return callback(err);\n }\n throw err;\n }\n\n // no callback means we should just return a raw request\n if(!hasCallback) {\n return request;\n }\n\n }\n\n let message;\n try {\n message = JSON.stringify(request, this.options.replacer);\n } catch(err) {\n return callback(err);\n }\n\n this.callServer(message, function(err, response) {\n self._parseResponse(err, response, callback);\n });\n\n // always return the raw request\n return request;\n};\n\n/**\n * Parses a response from a server\n * @param {Object} err Error to pass on that is unrelated to the actual response\n * @param {String} responseText JSON-RPC 1.0 or 2.0 response\n * @param {Function} callback Callback that will receive different arguments depending on the amount of parameters\n * @private\n */\nClientBrowser.prototype._parseResponse = function(err, responseText, callback) {\n if(err) {\n callback(err);\n return;\n }\n\n if(!responseText) {\n // empty response text, assume that is correct because it could be a\n // notification which jayson does not give any body for\n return callback();\n }\n\n let response;\n try {\n response = JSON.parse(responseText, this.options.reviver);\n } catch(err) {\n return callback(err);\n }\n\n if(callback.length === 3) {\n // if callback length is 3, we split callback arguments on error and response\n\n // is batch response?\n if(Array.isArray(response)) {\n\n // neccesary to split strictly on validity according to spec here\n const isError = function(res) {\n return typeof res.error !== 'undefined';\n };\n\n const isNotError = function (res) {\n return !isError(res);\n };\n\n return callback(null, response.filter(isError), response.filter(isNotError));\n \n } else {\n\n // split regardless of validity\n return callback(null, response.error, response.result);\n \n }\n \n }\n\n callback(null, response);\n};\n","var parser = require('./lib/parser');\nvar compiler = require('./lib/compiler');\n\nmodule.exports = {\n parse: function(input) {\n var nodes = parser.parse(input.toString());\n return compiler.compile(nodes);\n }\n};\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","/** @license React v17.0.2\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=require(\"object-assign\"),n=60103,p=60106;exports.Fragment=60107;exports.StrictMode=60108;exports.Profiler=60114;var q=60109,r=60110,t=60112;exports.Suspense=60113;var u=60115,v=60116;\nif(\"function\"===typeof Symbol&&Symbol.for){var w=Symbol.for;n=w(\"react.element\");p=w(\"react.portal\");exports.Fragment=w(\"react.fragment\");exports.StrictMode=w(\"react.strict_mode\");exports.Profiler=w(\"react.profiler\");q=w(\"react.provider\");r=w(\"react.context\");t=w(\"react.forward_ref\");exports.Suspense=w(\"react.suspense\");u=w(\"react.memo\");v=w(\"react.lazy\")}var x=\"function\"===typeof Symbol&&Symbol.iterator;\nfunction y(a){if(null===a||\"object\"!==typeof a)return null;a=x&&a[x]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}function z(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function B(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var D={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){D[a]=new B(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];D[b]=new B(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){D[a]=new B(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){D[a]=new B(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){D[a]=new B(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){D[a]=new B(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){D[a]=new B(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){D[a]=new B(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){D[a]=new B(a,5,!1,a.toLowerCase(),null,!1,!1)});var oa=/[\\-:]([a-z])/g;function pa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(oa,\npa);D[b]=new B(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(oa,pa);D[b]=new B(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(oa,pa);D[b]=new B(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!1,!1)});\nD.xlinkHref=new B(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction qa(a,b,c,d){var e=D.hasOwnProperty(b)?D[b]:null;var f=null!==e?0===e.type:d?!1:!(2h||e[g]!==f[h])return\"\\n\"+e[g].replace(\" at new \",\" at \");while(1<=g&&0<=h)}break}}}finally{Oa=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Na(a):\"\"}\nfunction Qa(a){switch(a.tag){case 5:return Na(a.type);case 16:return Na(\"Lazy\");case 13:return Na(\"Suspense\");case 19:return Na(\"SuspenseList\");case 0:case 2:case 15:return a=Pa(a.type,!1),a;case 11:return a=Pa(a.type.render,!1),a;case 22:return a=Pa(a.type._render,!1),a;case 1:return a=Pa(a.type,!0),a;default:return\"\"}}\nfunction Ra(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ua:return\"Fragment\";case ta:return\"Portal\";case xa:return\"Profiler\";case wa:return\"StrictMode\";case Ba:return\"Suspense\";case Ca:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case za:return(a.displayName||\"Context\")+\".Consumer\";case ya:return(a._context.displayName||\"Context\")+\".Provider\";case Aa:var b=a.render;b=b.displayName||b.name||\"\";\nreturn a.displayName||(\"\"!==b?\"ForwardRef(\"+b+\")\":\"ForwardRef\");case Da:return Ra(a.type);case Fa:return Ra(a._render);case Ea:b=a._payload;a=a._init;try{return Ra(a(b))}catch(c){}}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"object\":case \"string\":case \"undefined\":return a;default:return\"\"}}function Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return m({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function $a(a,b){b=b.checked;null!=b&&qa(a,\"checked\",b,!1)}\nfunction ab(a,b){$a(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?bb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&bb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction cb(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction bb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}function db(a){var b=\"\";aa.Children.forEach(a,function(a){null!=a&&(b+=a)});return b}function eb(a,b){a=m({children:void 0},b);if(b=db(b.children))a.children=b;return a}\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e=c.length))throw Error(y(93));c=c[0]}b=c}null==b&&(b=\"\");c=b}a._wrapperState={initialValue:Sa(c)}}\nfunction ib(a,b){var c=Sa(b.value),d=Sa(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function jb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}var kb={html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"};\nfunction lb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}function mb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?lb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar nb,ob=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(a.namespaceURI!==kb.svg||\"innerHTML\"in a)a.innerHTML=b;else{nb=nb||document.createElement(\"div\");nb.innerHTML=\"\"+b.valueOf().toString()+\"\";for(b=nb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction pb(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar qb={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,\nfloodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},rb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(qb).forEach(function(a){rb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);qb[b]=qb[a]})});function sb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||qb.hasOwnProperty(a)&&qb[a]?(\"\"+b).trim():b+\"px\"}\nfunction tb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=sb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var ub=m({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction vb(a,b){if(b){if(ub[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(y(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(y(60));if(!(\"object\"===typeof b.dangerouslySetInnerHTML&&\"__html\"in b.dangerouslySetInnerHTML))throw Error(y(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(y(62));}}\nfunction wb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(y(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;ad?0:1<c;c++)b.push(a);return b}\nfunction $c(a,b,c){a.pendingLanes|=b;var d=b-1;a.suspendedLanes&=d;a.pingedLanes&=d;a=a.eventTimes;b=31-Vc(b);a[b]=c}var Vc=Math.clz32?Math.clz32:ad,bd=Math.log,cd=Math.LN2;function ad(a){return 0===a?32:31-(bd(a)/cd|0)|0}var dd=r.unstable_UserBlockingPriority,ed=r.unstable_runWithPriority,fd=!0;function gd(a,b,c,d){Kb||Ib();var e=hd,f=Kb;Kb=!0;try{Hb(e,a,b,c,d)}finally{(Kb=f)||Mb()}}function id(a,b,c,d){ed(dd,hd.bind(null,a,b,c,d))}\nfunction hd(a,b,c,d){if(fd){var e;if((e=0===(b&4))&&0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Ke(c)}}function Me(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Me(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Ne(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Oe(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nvar Pe=fa&&\"documentMode\"in document&&11>=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Oe(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Je(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Af||(a.current=zf[Af],zf[Af]=null,Af--)}function I(a,b){Af++;zf[Af]=a.current;a.current=b}var Cf={},M=Bf(Cf),N=Bf(!1),Df=Cf;\nfunction Ef(a,b){var c=a.type.contextTypes;if(!c)return Cf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}function Ff(a){a=a.childContextTypes;return null!==a&&void 0!==a}function Gf(){H(N);H(M)}function Hf(a,b,c){if(M.current!==Cf)throw Error(y(168));I(M,b);I(N,c)}\nfunction If(a,b,c){var d=a.stateNode;a=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in a))throw Error(y(108,Ra(b)||\"Unknown\",e));return m({},c,d)}function Jf(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Cf;Df=M.current;I(M,a);I(N,N.current);return!0}function Kf(a,b,c){var d=a.stateNode;if(!d)throw Error(y(169));c?(a=If(a,b,Df),d.__reactInternalMemoizedMergedChildContext=a,H(N),H(M),I(M,a)):H(N);I(N,c)}\nvar Lf=null,Mf=null,Nf=r.unstable_runWithPriority,Of=r.unstable_scheduleCallback,Pf=r.unstable_cancelCallback,Qf=r.unstable_shouldYield,Rf=r.unstable_requestPaint,Sf=r.unstable_now,Tf=r.unstable_getCurrentPriorityLevel,Uf=r.unstable_ImmediatePriority,Vf=r.unstable_UserBlockingPriority,Wf=r.unstable_NormalPriority,Xf=r.unstable_LowPriority,Yf=r.unstable_IdlePriority,Zf={},$f=void 0!==Rf?Rf:function(){},ag=null,bg=null,cg=!1,dg=Sf(),O=1E4>dg?Sf:function(){return Sf()-dg};\nfunction eg(){switch(Tf()){case Uf:return 99;case Vf:return 98;case Wf:return 97;case Xf:return 96;case Yf:return 95;default:throw Error(y(332));}}function fg(a){switch(a){case 99:return Uf;case 98:return Vf;case 97:return Wf;case 96:return Xf;case 95:return Yf;default:throw Error(y(332));}}function gg(a,b){a=fg(a);return Nf(a,b)}function hg(a,b,c){a=fg(a);return Of(a,b,c)}function ig(){if(null!==bg){var a=bg;bg=null;Pf(a)}jg()}\nfunction jg(){if(!cg&&null!==ag){cg=!0;var a=0;try{var b=ag;gg(99,function(){for(;az?(q=u,u=null):q=u.sibling;var n=p(e,u,h[z],k);if(null===n){null===u&&(u=q);break}a&&u&&null===\nn.alternate&&b(e,u);g=f(n,g,z);null===t?l=n:t.sibling=n;t=n;u=q}if(z===h.length)return c(e,u),l;if(null===u){for(;zz?(q=u,u=null):q=u.sibling;var w=p(e,u,n.value,k);if(null===w){null===u&&(u=q);break}a&&u&&null===w.alternate&&b(e,u);g=f(w,g,z);null===t?l=w:t.sibling=w;t=w;u=q}if(n.done)return c(e,u),l;if(null===u){for(;!n.done;z++,n=h.next())n=A(e,n.value,k),null!==n&&(g=f(n,g,z),null===t?l=n:t.sibling=n,t=n);return l}for(u=d(e,u);!n.done;z++,n=h.next())n=C(u,e,z,n.value,k),null!==n&&(a&&null!==n.alternate&&\nu.delete(null===n.key?z:n.key),g=f(n,g,z),null===t?l=n:t.sibling=n,t=n);a&&u.forEach(function(a){return b(e,a)});return l}return function(a,d,f,h){var k=\"object\"===typeof f&&null!==f&&f.type===ua&&null===f.key;k&&(f=f.props.children);var l=\"object\"===typeof f&&null!==f;if(l)switch(f.$$typeof){case sa:a:{l=f.key;for(k=d;null!==k;){if(k.key===l){switch(k.tag){case 7:if(f.type===ua){c(a,k.sibling);d=e(k,f.props.children);d.return=a;a=d;break a}break;default:if(k.elementType===f.type){c(a,k.sibling);\nd=e(k,f.props);d.ref=Qg(a,k,f);d.return=a;a=d;break a}}c(a,k);break}else b(a,k);k=k.sibling}f.type===ua?(d=Xg(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=Vg(f.type,f.key,f.props,null,a.mode,h),h.ref=Qg(a,d,f),h.return=a,a=h)}return g(a);case ta:a:{for(k=f.key;null!==d;){if(d.key===k)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=\nWg(f,a.mode,h);d.return=a;a=d}return g(a)}if(\"string\"===typeof f||\"number\"===typeof f)return f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):(c(a,d),d=Ug(f,a.mode,h),d.return=a,a=d),g(a);if(Pg(f))return x(a,d,f,h);if(La(f))return w(a,d,f,h);l&&Rg(a,f);if(\"undefined\"===typeof f&&!k)switch(a.tag){case 1:case 22:case 0:case 11:case 15:throw Error(y(152,Ra(a.type)||\"Component\"));}return c(a,d)}}var Yg=Sg(!0),Zg=Sg(!1),$g={},ah=Bf($g),bh=Bf($g),ch=Bf($g);\nfunction dh(a){if(a===$g)throw Error(y(174));return a}function eh(a,b){I(ch,b);I(bh,a);I(ah,$g);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:mb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=mb(b,a)}H(ah);I(ah,b)}function fh(){H(ah);H(bh);H(ch)}function gh(a){dh(ch.current);var b=dh(ah.current);var c=mb(b,a.type);b!==c&&(I(bh,a),I(ah,c))}function hh(a){bh.current===a&&(H(ah),H(bh))}var P=Bf(0);\nfunction ih(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&64))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var jh=null,kh=null,lh=!1;\nfunction mh(a,b){var c=nh(5,null,null,0);c.elementType=\"DELETED\";c.type=\"DELETED\";c.stateNode=b;c.return=a;c.flags=8;null!==a.lastEffect?(a.lastEffect.nextEffect=c,a.lastEffect=c):a.firstEffect=a.lastEffect=c}function oh(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,!0):!1;case 13:return!1;default:return!1}}\nfunction ph(a){if(lh){var b=kh;if(b){var c=b;if(!oh(a,b)){b=rf(c.nextSibling);if(!b||!oh(a,b)){a.flags=a.flags&-1025|2;lh=!1;jh=a;return}mh(jh,c)}jh=a;kh=rf(b.firstChild)}else a.flags=a.flags&-1025|2,lh=!1,jh=a}}function qh(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;jh=a}\nfunction rh(a){if(a!==jh)return!1;if(!lh)return qh(a),lh=!0,!1;var b=a.type;if(5!==a.tag||\"head\"!==b&&\"body\"!==b&&!nf(b,a.memoizedProps))for(b=kh;b;)mh(a,b),b=rf(b.nextSibling);qh(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(y(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(\"/$\"===c){if(0===b){kh=rf(a.nextSibling);break a}b--}else\"$\"!==c&&\"$!\"!==c&&\"$?\"!==c||b++}a=a.nextSibling}kh=null}}else kh=jh?rf(a.stateNode.nextSibling):null;return!0}\nfunction sh(){kh=jh=null;lh=!1}var th=[];function uh(){for(var a=0;af))throw Error(y(301));f+=1;T=S=null;b.updateQueue=null;vh.current=Fh;a=c(d,e)}while(zh)}vh.current=Gh;b=null!==S&&null!==S.next;xh=0;T=S=R=null;yh=!1;if(b)throw Error(y(300));return a}function Hh(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===T?R.memoizedState=T=a:T=T.next=a;return T}\nfunction Ih(){if(null===S){var a=R.alternate;a=null!==a?a.memoizedState:null}else a=S.next;var b=null===T?R.memoizedState:T.next;if(null!==b)T=b,S=a;else{if(null===a)throw Error(y(310));S=a;a={memoizedState:S.memoizedState,baseState:S.baseState,baseQueue:S.baseQueue,queue:S.queue,next:null};null===T?R.memoizedState=T=a:T=T.next=a}return T}function Jh(a,b){return\"function\"===typeof b?b(a):b}\nfunction Kh(a){var b=Ih(),c=b.queue;if(null===c)throw Error(y(311));c.lastRenderedReducer=a;var d=S,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){e=e.next;d=d.baseState;var h=g=f=null,k=e;do{var l=k.lane;if((xh&l)===l)null!==h&&(h=h.next={lane:0,action:k.action,eagerReducer:k.eagerReducer,eagerState:k.eagerState,next:null}),d=k.eagerReducer===a?k.eagerState:a(d,k.action);else{var n={lane:l,action:k.action,eagerReducer:k.eagerReducer,\neagerState:k.eagerState,next:null};null===h?(g=h=n,f=d):h=h.next=n;R.lanes|=l;Dg|=l}k=k.next}while(null!==k&&k!==e);null===h?f=d:h.next=g;He(d,b.memoizedState)||(ug=!0);b.memoizedState=d;b.baseState=f;b.baseQueue=h;c.lastRenderedState=d}return[b.memoizedState,c.dispatch]}\nfunction Lh(a){var b=Ih(),c=b.queue;if(null===c)throw Error(y(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);He(f,b.memoizedState)||(ug=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}\nfunction Mh(a,b,c){var d=b._getVersion;d=d(b._source);var e=b._workInProgressVersionPrimary;if(null!==e)a=e===d;else if(a=a.mutableReadLanes,a=(xh&a)===a)b._workInProgressVersionPrimary=d,th.push(b);if(a)return c(b._source);th.push(b);throw Error(y(350));}\nfunction Nh(a,b,c,d){var e=U;if(null===e)throw Error(y(349));var f=b._getVersion,g=f(b._source),h=vh.current,k=h.useState(function(){return Mh(e,b,c)}),l=k[1],n=k[0];k=T;var A=a.memoizedState,p=A.refs,C=p.getSnapshot,x=A.source;A=A.subscribe;var w=R;a.memoizedState={refs:p,source:b,subscribe:d};h.useEffect(function(){p.getSnapshot=c;p.setSnapshot=l;var a=f(b._source);if(!He(g,a)){a=c(b._source);He(n,a)||(l(a),a=Ig(w),e.mutableReadLanes|=a&e.pendingLanes);a=e.mutableReadLanes;e.entangledLanes|=a;for(var d=\ne.entanglements,h=a;0c?98:c,function(){a(!0)});gg(97\\x3c/script>\",a=a.removeChild(a.firstChild)):\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[wf]=b;a[xf]=d;Bi(a,b,!1,!1);b.stateNode=a;g=wb(c,d);switch(c){case \"dialog\":G(\"cancel\",a);G(\"close\",a);\ne=d;break;case \"iframe\":case \"object\":case \"embed\":G(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eJi&&(b.flags|=64,f=!0,Fi(d,!1),b.lanes=33554432)}else{if(!f)if(a=ih(g),null!==a){if(b.flags|=64,f=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Fi(d,!0),null===d.tail&&\"hidden\"===d.tailMode&&!g.alternate&&!lh)return b=b.lastEffect=d.lastEffect,null!==b&&(b.nextEffect=null),null}else 2*O()-d.renderingStartTime>Ji&&1073741824!==c&&(b.flags|=\n64,f=!0,Fi(d,!1),b.lanes=33554432);d.isBackwards?(g.sibling=b.child,b.child=g):(c=d.last,null!==c?c.sibling=g:b.child=g,d.last=g)}return null!==d.tail?(c=d.tail,d.rendering=c,d.tail=c.sibling,d.lastEffect=b.lastEffect,d.renderingStartTime=O(),c.sibling=null,b=P.current,I(P,f?b&1|2:b&1),c):null;case 23:case 24:return Ki(),null!==a&&null!==a.memoizedState!==(null!==b.memoizedState)&&\"unstable-defer-without-hiding\"!==d.mode&&(b.flags|=4),null}throw Error(y(156,b.tag));}\nfunction Li(a){switch(a.tag){case 1:Ff(a.type)&&Gf();var b=a.flags;return b&4096?(a.flags=b&-4097|64,a):null;case 3:fh();H(N);H(M);uh();b=a.flags;if(0!==(b&64))throw Error(y(285));a.flags=b&-4097|64;return a;case 5:return hh(a),null;case 13:return H(P),b=a.flags,b&4096?(a.flags=b&-4097|64,a):null;case 19:return H(P),null;case 4:return fh(),null;case 10:return rg(a),null;case 23:case 24:return Ki(),null;default:return null}}\nfunction Mi(a,b){try{var c=\"\",d=b;do c+=Qa(d),d=d.return;while(d);var e=c}catch(f){e=\"\\nError generating stack: \"+f.message+\"\\n\"+f.stack}return{value:a,source:b,stack:e}}function Ni(a,b){try{console.error(b.value)}catch(c){setTimeout(function(){throw c;})}}var Oi=\"function\"===typeof WeakMap?WeakMap:Map;function Pi(a,b,c){c=zg(-1,c);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){Qi||(Qi=!0,Ri=d);Ni(a,b)};return c}\nfunction Si(a,b,c){c=zg(-1,c);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){Ni(a,b);return d(e)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){\"function\"!==typeof d&&(null===Ti?Ti=new Set([this]):Ti.add(this),Ni(a,b));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}var Ui=\"function\"===typeof WeakSet?WeakSet:Set;\nfunction Vi(a){var b=a.ref;if(null!==b)if(\"function\"===typeof b)try{b(null)}catch(c){Wi(a,c)}else b.current=null}function Xi(a,b){switch(b.tag){case 0:case 11:case 15:case 22:return;case 1:if(b.flags&256&&null!==a){var c=a.memoizedProps,d=a.memoizedState;a=b.stateNode;b=a.getSnapshotBeforeUpdate(b.elementType===b.type?c:lg(b.type,c),d);a.__reactInternalSnapshotBeforeUpdate=b}return;case 3:b.flags&256&&qf(b.stateNode.containerInfo);return;case 5:case 6:case 4:case 17:return}throw Error(y(163));}\nfunction Yi(a,b,c){switch(c.tag){case 0:case 11:case 15:case 22:b=c.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){a=b=b.next;do{if(3===(a.tag&3)){var d=a.create;a.destroy=d()}a=a.next}while(a!==b)}b=c.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){a=b=b.next;do{var e=a;d=e.next;e=e.tag;0!==(e&4)&&0!==(e&1)&&(Zi(c,a),$i(c,a));a=d}while(a!==b)}return;case 1:a=c.stateNode;c.flags&4&&(null===b?a.componentDidMount():(d=c.elementType===c.type?b.memoizedProps:lg(c.type,b.memoizedProps),a.componentDidUpdate(d,\nb.memoizedState,a.__reactInternalSnapshotBeforeUpdate)));b=c.updateQueue;null!==b&&Eg(c,b,a);return;case 3:b=c.updateQueue;if(null!==b){a=null;if(null!==c.child)switch(c.child.tag){case 5:a=c.child.stateNode;break;case 1:a=c.child.stateNode}Eg(c,b,a)}return;case 5:a=c.stateNode;null===b&&c.flags&4&&mf(c.type,c.memoizedProps)&&a.focus();return;case 6:return;case 4:return;case 12:return;case 13:null===c.memoizedState&&(c=c.alternate,null!==c&&(c=c.memoizedState,null!==c&&(c=c.dehydrated,null!==c&&Cc(c))));\nreturn;case 19:case 17:case 20:case 21:case 23:case 24:return}throw Error(y(163));}\nfunction aj(a,b){for(var c=a;;){if(5===c.tag){var d=c.stateNode;if(b)d=d.style,\"function\"===typeof d.setProperty?d.setProperty(\"display\",\"none\",\"important\"):d.display=\"none\";else{d=c.stateNode;var e=c.memoizedProps.style;e=void 0!==e&&null!==e&&e.hasOwnProperty(\"display\")?e.display:null;d.style.display=sb(\"display\",e)}}else if(6===c.tag)c.stateNode.nodeValue=b?\"\":c.memoizedProps;else if((23!==c.tag&&24!==c.tag||null===c.memoizedState||c===a)&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===\na)break;for(;null===c.sibling;){if(null===c.return||c.return===a)return;c=c.return}c.sibling.return=c.return;c=c.sibling}}\nfunction bj(a,b){if(Mf&&\"function\"===typeof Mf.onCommitFiberUnmount)try{Mf.onCommitFiberUnmount(Lf,b)}catch(f){}switch(b.tag){case 0:case 11:case 14:case 15:case 22:a=b.updateQueue;if(null!==a&&(a=a.lastEffect,null!==a)){var c=a=a.next;do{var d=c,e=d.destroy;d=d.tag;if(void 0!==e)if(0!==(d&4))Zi(b,c);else{d=b;try{e()}catch(f){Wi(d,f)}}c=c.next}while(c!==a)}break;case 1:Vi(b);a=b.stateNode;if(\"function\"===typeof a.componentWillUnmount)try{a.props=b.memoizedProps,a.state=b.memoizedState,a.componentWillUnmount()}catch(f){Wi(b,\nf)}break;case 5:Vi(b);break;case 4:cj(a,b)}}function dj(a){a.alternate=null;a.child=null;a.dependencies=null;a.firstEffect=null;a.lastEffect=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.return=null;a.updateQueue=null}function ej(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction fj(a){a:{for(var b=a.return;null!==b;){if(ej(b))break a;b=b.return}throw Error(y(160));}var c=b;b=c.stateNode;switch(c.tag){case 5:var d=!1;break;case 3:b=b.containerInfo;d=!0;break;case 4:b=b.containerInfo;d=!0;break;default:throw Error(y(161));}c.flags&16&&(pb(b,\"\"),c.flags&=-17);a:b:for(c=a;;){for(;null===c.sibling;){if(null===c.return||ej(c.return)){c=null;break a}c=c.return}c.sibling.return=c.return;for(c=c.sibling;5!==c.tag&&6!==c.tag&&18!==c.tag;){if(c.flags&2)continue b;if(null===\nc.child||4===c.tag)continue b;else c.child.return=c,c=c.child}if(!(c.flags&2)){c=c.stateNode;break a}}d?gj(a,c,b):hj(a,c,b)}\nfunction gj(a,b,c){var d=a.tag,e=5===d||6===d;if(e)a=e?a.stateNode:a.stateNode.instance,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=jf));else if(4!==d&&(a=a.child,null!==a))for(gj(a,b,c),a=a.sibling;null!==a;)gj(a,b,c),a=a.sibling}\nfunction hj(a,b,c){var d=a.tag,e=5===d||6===d;if(e)a=e?a.stateNode:a.stateNode.instance,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(hj(a,b,c),a=a.sibling;null!==a;)hj(a,b,c),a=a.sibling}\nfunction cj(a,b){for(var c=b,d=!1,e,f;;){if(!d){d=c.return;a:for(;;){if(null===d)throw Error(y(160));e=d.stateNode;switch(d.tag){case 5:f=!1;break a;case 3:e=e.containerInfo;f=!0;break a;case 4:e=e.containerInfo;f=!0;break a}d=d.return}d=!0}if(5===c.tag||6===c.tag){a:for(var g=a,h=c,k=h;;)if(bj(g,k),null!==k.child&&4!==k.tag)k.child.return=k,k=k.child;else{if(k===h)break a;for(;null===k.sibling;){if(null===k.return||k.return===h)break a;k=k.return}k.sibling.return=k.return;k=k.sibling}f?(g=e,h=c.stateNode,\n8===g.nodeType?g.parentNode.removeChild(h):g.removeChild(h)):e.removeChild(c.stateNode)}else if(4===c.tag){if(null!==c.child){e=c.stateNode.containerInfo;f=!0;c.child.return=c;c=c.child;continue}}else if(bj(a,c),null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return;4===c.tag&&(d=!1)}c.sibling.return=c.return;c=c.sibling}}\nfunction ij(a,b){switch(b.tag){case 0:case 11:case 14:case 15:case 22:var c=b.updateQueue;c=null!==c?c.lastEffect:null;if(null!==c){var d=c=c.next;do 3===(d.tag&3)&&(a=d.destroy,d.destroy=void 0,void 0!==a&&a()),d=d.next;while(d!==c)}return;case 1:return;case 5:c=b.stateNode;if(null!=c){d=b.memoizedProps;var e=null!==a?a.memoizedProps:d;a=b.type;var f=b.updateQueue;b.updateQueue=null;if(null!==f){c[xf]=d;\"input\"===a&&\"radio\"===d.type&&null!=d.name&&$a(c,d);wb(a,e);b=wb(a,d);for(e=0;ee&&(e=g);c&=~f}c=e;c=O()-c;c=(120>c?120:480>c?480:1080>c?1080:1920>c?1920:3E3>c?3E3:4320>\nc?4320:1960*nj(c/1960))-c;if(10 component higher in the tree to provide a loading indicator or placeholder to display.\")}5!==V&&(V=2);k=Mi(k,h);p=\ng;do{switch(p.tag){case 3:f=k;p.flags|=4096;b&=-b;p.lanes|=b;var J=Pi(p,f,b);Bg(p,J);break a;case 1:f=k;var K=p.type,Q=p.stateNode;if(0===(p.flags&64)&&(\"function\"===typeof K.getDerivedStateFromError||null!==Q&&\"function\"===typeof Q.componentDidCatch&&(null===Ti||!Ti.has(Q)))){p.flags|=4096;b&=-b;p.lanes|=b;var L=Si(p,f,b);Bg(p,L);break a}}p=p.return}while(null!==p)}Zj(c)}catch(va){b=va;Y===c&&null!==c&&(Y=c=c.return);continue}break}while(1)}\nfunction Pj(){var a=oj.current;oj.current=Gh;return null===a?Gh:a}function Tj(a,b){var c=X;X|=16;var d=Pj();U===a&&W===b||Qj(a,b);do try{ak();break}catch(e){Sj(a,e)}while(1);qg();X=c;oj.current=d;if(null!==Y)throw Error(y(261));U=null;W=0;return V}function ak(){for(;null!==Y;)bk(Y)}function Rj(){for(;null!==Y&&!Qf();)bk(Y)}function bk(a){var b=ck(a.alternate,a,qj);a.memoizedProps=a.pendingProps;null===b?Zj(a):Y=b;pj.current=null}\nfunction Zj(a){var b=a;do{var c=b.alternate;a=b.return;if(0===(b.flags&2048)){c=Gi(c,b,qj);if(null!==c){Y=c;return}c=b;if(24!==c.tag&&23!==c.tag||null===c.memoizedState||0!==(qj&1073741824)||0===(c.mode&4)){for(var d=0,e=c.child;null!==e;)d|=e.lanes|e.childLanes,e=e.sibling;c.childLanes=d}null!==a&&0===(a.flags&2048)&&(null===a.firstEffect&&(a.firstEffect=b.firstEffect),null!==b.lastEffect&&(null!==a.lastEffect&&(a.lastEffect.nextEffect=b.firstEffect),a.lastEffect=b.lastEffect),1g&&(h=g,g=J,J=h),h=Le(t,J),f=Le(t,g),h&&f&&(1!==v.rangeCount||v.anchorNode!==h.node||v.anchorOffset!==h.offset||v.focusNode!==f.node||v.focusOffset!==f.offset)&&(q=q.createRange(),q.setStart(h.node,h.offset),v.removeAllRanges(),J>g?(v.addRange(q),v.extend(f.node,f.offset)):(q.setEnd(f.node,f.offset),v.addRange(q))))));q=[];for(v=t;v=v.parentNode;)1===v.nodeType&&q.push({element:v,left:v.scrollLeft,top:v.scrollTop});\"function\"===typeof t.focus&&t.focus();for(t=\n0;tO()-jj?Qj(a,0):uj|=c);Mj(a,b)}function lj(a,b){var c=a.stateNode;null!==c&&c.delete(b);b=0;0===b&&(b=a.mode,0===(b&2)?b=1:0===(b&4)?b=99===eg()?1:2:(0===Gj&&(Gj=tj),b=Yc(62914560&~Gj),0===b&&(b=4194304)));c=Hg();a=Kj(a,b);null!==a&&($c(a,b,c),Mj(a,c))}var ck;\nck=function(a,b,c){var d=b.lanes;if(null!==a)if(a.memoizedProps!==b.pendingProps||N.current)ug=!0;else if(0!==(c&d))ug=0!==(a.flags&16384)?!0:!1;else{ug=!1;switch(b.tag){case 3:ri(b);sh();break;case 5:gh(b);break;case 1:Ff(b.type)&&Jf(b);break;case 4:eh(b,b.stateNode.containerInfo);break;case 10:d=b.memoizedProps.value;var e=b.type._context;I(mg,e._currentValue);e._currentValue=d;break;case 13:if(null!==b.memoizedState){if(0!==(c&b.child.childLanes))return ti(a,b,c);I(P,P.current&1);b=hi(a,b,c);return null!==\nb?b.sibling:null}I(P,P.current&1);break;case 19:d=0!==(c&b.childLanes);if(0!==(a.flags&64)){if(d)return Ai(a,b,c);b.flags|=64}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null,e.lastEffect=null);I(P,P.current);if(d)break;else return null;case 23:case 24:return b.lanes=0,mi(a,b,c)}return hi(a,b,c)}else ug=!1;b.lanes=0;switch(b.tag){case 2:d=b.type;null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2);a=b.pendingProps;e=Ef(b,M.current);tg(b,c);e=Ch(null,b,d,a,e,c);b.flags|=1;if(\"object\"===\ntypeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof){b.tag=1;b.memoizedState=null;b.updateQueue=null;if(Ff(d)){var f=!0;Jf(b)}else f=!1;b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null;xg(b);var g=d.getDerivedStateFromProps;\"function\"===typeof g&&Gg(b,d,g,a);e.updater=Kg;b.stateNode=e;e._reactInternals=b;Og(b,d,a,c);b=qi(null,b,d,!0,f,c)}else b.tag=0,fi(null,b,e,c),b=b.child;return b;case 16:e=b.elementType;a:{null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2);\na=b.pendingProps;f=e._init;e=f(e._payload);b.type=e;f=b.tag=hk(e);a=lg(e,a);switch(f){case 0:b=li(null,b,e,a,c);break a;case 1:b=pi(null,b,e,a,c);break a;case 11:b=gi(null,b,e,a,c);break a;case 14:b=ii(null,b,e,lg(e.type,a),d,c);break a}throw Error(y(306,e,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),li(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),pi(a,b,d,e,c);case 3:ri(b);d=b.updateQueue;if(null===a||null===d)throw Error(y(282));\nd=b.pendingProps;e=b.memoizedState;e=null!==e?e.element:null;yg(a,b);Cg(b,d,null,c);d=b.memoizedState.element;if(d===e)sh(),b=hi(a,b,c);else{e=b.stateNode;if(f=e.hydrate)kh=rf(b.stateNode.containerInfo.firstChild),jh=b,f=lh=!0;if(f){a=e.mutableSourceEagerHydrationData;if(null!=a)for(e=0;e=\nE};k=function(){};exports.unstable_forceFrameRate=function(a){0>a||125>>1,e=a[d];if(void 0!==e&&0I(n,c))void 0!==r&&0>I(r,n)?(a[d]=r,a[v]=c,d=v):(a[d]=n,a[m]=c,d=m);else if(void 0!==r&&0>I(r,c))a[d]=r,a[v]=c,d=v;else break a}}return b}return null}function I(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}var L=[],M=[],N=1,O=null,P=3,Q=!1,R=!1,S=!1;\nfunction T(a){for(var b=J(M);null!==b;){if(null===b.callback)K(M);else if(b.startTime<=a)K(M),b.sortIndex=b.expirationTime,H(L,b);else break;b=J(M)}}function U(a){S=!1;T(a);if(!R)if(null!==J(L))R=!0,f(V);else{var b=J(M);null!==b&&g(U,b.startTime-a)}}\nfunction V(a,b){R=!1;S&&(S=!1,h());Q=!0;var c=P;try{T(b);for(O=J(L);null!==O&&(!(O.expirationTime>b)||a&&!exports.unstable_shouldYield());){var d=O.callback;if(\"function\"===typeof d){O.callback=null;P=O.priorityLevel;var e=d(O.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?O.callback=e:O===J(L)&&K(L);T(b)}else K(L);O=J(L)}if(null!==O)var m=!0;else{var n=J(M);null!==n&&g(U,n.startTime-b);m=!1}return m}finally{O=null,P=c,Q=!1}}var W=k;exports.unstable_IdlePriority=5;\nexports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){R||Q||(R=!0,f(V))};exports.unstable_getCurrentPriorityLevel=function(){return P};exports.unstable_getFirstCallbackNode=function(){return J(L)};\nexports.unstable_next=function(a){switch(P){case 1:case 2:case 3:var b=3;break;default:b=P}var c=P;P=b;try{return a()}finally{P=c}};exports.unstable_pauseExecution=function(){};exports.unstable_requestPaint=W;exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=P;P=a;try{return b()}finally{P=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();\"object\"===typeof c&&null!==c?(c=c.delay,c=\"number\"===typeof c&&0d?(a.sortIndex=c,H(M,a),null===J(L)&&a===J(M)&&(S?h():S=!0,g(U,c-d))):(a.sortIndex=e,H(L,a),R||Q||(R=!0,f(V)));return a};\nexports.unstable_wrapCallback=function(a){var b=P;return function(){var c=P;P=b;try{return a.apply(this,arguments)}finally{P=c}}};\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n define(Gp, \"constructor\", GeneratorFunctionPrototype);\n define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction);\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict'\n// base-x encoding / decoding\n// Copyright (c) 2018 base-x contributors\n// Copyright (c) 2014-2018 The Bitcoin Core developers (base58.cpp)\n// Distributed under the MIT software license, see the accompanying\n// file LICENSE or http://www.opensource.org/licenses/mit-license.php.\n// @ts-ignore\nvar _Buffer = require('safe-buffer').Buffer\nfunction base (ALPHABET) {\n if (ALPHABET.length >= 255) { throw new TypeError('Alphabet too long') }\n var BASE_MAP = new Uint8Array(256)\n for (var j = 0; j < BASE_MAP.length; j++) {\n BASE_MAP[j] = 255\n }\n for (var i = 0; i < ALPHABET.length; i++) {\n var x = ALPHABET.charAt(i)\n var xc = x.charCodeAt(0)\n if (BASE_MAP[xc] !== 255) { throw new TypeError(x + ' is ambiguous') }\n BASE_MAP[xc] = i\n }\n var BASE = ALPHABET.length\n var LEADER = ALPHABET.charAt(0)\n var FACTOR = Math.log(BASE) / Math.log(256) // log(BASE) / log(256), rounded up\n var iFACTOR = Math.log(256) / Math.log(BASE) // log(256) / log(BASE), rounded up\n function encode (source) {\n if (Array.isArray(source) || source instanceof Uint8Array) { source = _Buffer.from(source) }\n if (!_Buffer.isBuffer(source)) { throw new TypeError('Expected Buffer') }\n if (source.length === 0) { return '' }\n // Skip & count leading zeroes.\n var zeroes = 0\n var length = 0\n var pbegin = 0\n var pend = source.length\n while (pbegin !== pend && source[pbegin] === 0) {\n pbegin++\n zeroes++\n }\n // Allocate enough space in big-endian base58 representation.\n var size = ((pend - pbegin) * iFACTOR + 1) >>> 0\n var b58 = new Uint8Array(size)\n // Process the bytes.\n while (pbegin !== pend) {\n var carry = source[pbegin]\n // Apply \"b58 = b58 * 256 + ch\".\n var i = 0\n for (var it1 = size - 1; (carry !== 0 || i < length) && (it1 !== -1); it1--, i++) {\n carry += (256 * b58[it1]) >>> 0\n b58[it1] = (carry % BASE) >>> 0\n carry = (carry / BASE) >>> 0\n }\n if (carry !== 0) { throw new Error('Non-zero carry') }\n length = i\n pbegin++\n }\n // Skip leading zeroes in base58 result.\n var it2 = size - length\n while (it2 !== size && b58[it2] === 0) {\n it2++\n }\n // Translate the result into a string.\n var str = LEADER.repeat(zeroes)\n for (; it2 < size; ++it2) { str += ALPHABET.charAt(b58[it2]) }\n return str\n }\n function decodeUnsafe (source) {\n if (typeof source !== 'string') { throw new TypeError('Expected String') }\n if (source.length === 0) { return _Buffer.alloc(0) }\n var psz = 0\n // Skip and count leading '1's.\n var zeroes = 0\n var length = 0\n while (source[psz] === LEADER) {\n zeroes++\n psz++\n }\n // Allocate enough space in big-endian base256 representation.\n var size = (((source.length - psz) * FACTOR) + 1) >>> 0 // log(58) / log(256), rounded up.\n var b256 = new Uint8Array(size)\n // Process the characters.\n while (source[psz]) {\n // Decode character\n var carry = BASE_MAP[source.charCodeAt(psz)]\n // Invalid character\n if (carry === 255) { return }\n var i = 0\n for (var it3 = size - 1; (carry !== 0 || i < length) && (it3 !== -1); it3--, i++) {\n carry += (BASE * b256[it3]) >>> 0\n b256[it3] = (carry % 256) >>> 0\n carry = (carry / 256) >>> 0\n }\n if (carry !== 0) { throw new Error('Non-zero carry') }\n length = i\n psz++\n }\n // Skip leading zeroes in b256.\n var it4 = size - length\n while (it4 !== size && b256[it4] === 0) {\n it4++\n }\n var vch = _Buffer.allocUnsafe(zeroes + (size - it4))\n vch.fill(0x00, 0, zeroes)\n var j = zeroes\n while (it4 !== size) {\n vch[j++] = b256[it4++]\n }\n return vch\n }\n function decode (string) {\n var buffer = decodeUnsafe(string)\n if (buffer) { return buffer }\n throw new Error('Non-base' + BASE + ' character')\n }\n return {\n encode: encode,\n decodeUnsafe: decodeUnsafe,\n decode: decode\n }\n}\nmodule.exports = base\n","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableRest = require(\"./nonIterableRest.js\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\n\nvar setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nvar isNativeFunction = require(\"./isNativeFunction.js\");\n\nvar construct = require(\"./construct.js\");\n\nfunction _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n module.exports = _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _wrapNativeSuper(Class);\n}\n\nmodule.exports = _wrapNativeSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}\n\nmodule.exports = _isNativeFunction, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\n\nfunction _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n module.exports = _construct = Reflect.construct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n\n return _construct.apply(null, arguments);\n}\n\nmodule.exports = _construct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\n// This is free and unencumbered software released into the public domain.\n// See LICENSE.md for more information.\n\n//\n// Utilities\n//\n\n/**\n * @param {number} a The number to test.\n * @param {number} min The minimum value in the range, inclusive.\n * @param {number} max The maximum value in the range, inclusive.\n * @return {boolean} True if a >= min and a <= max.\n */\nfunction inRange(a, min, max) {\n return min <= a && a <= max;\n}\n\n/**\n * @param {*} o\n * @return {Object}\n */\nfunction ToDictionary(o) {\n if (o === undefined) return {};\n if (o === Object(o)) return o;\n throw TypeError('Could not convert argument to dictionary');\n}\n\n/**\n * @param {string} string Input string of UTF-16 code units.\n * @return {!Array.} Code points.\n */\nfunction stringToCodePoints(string) {\n // https://heycam.github.io/webidl/#dfn-obtain-unicode\n\n // 1. Let S be the DOMString value.\n var s = String(string);\n\n // 2. Let n be the length of S.\n var n = s.length;\n\n // 3. Initialize i to 0.\n var i = 0;\n\n // 4. Initialize U to be an empty sequence of Unicode characters.\n var u = [];\n\n // 5. While i < n:\n while (i < n) {\n\n // 1. Let c be the code unit in S at index i.\n var c = s.charCodeAt(i);\n\n // 2. Depending on the value of c:\n\n // c < 0xD800 or c > 0xDFFF\n if (c < 0xD800 || c > 0xDFFF) {\n // Append to U the Unicode character with code point c.\n u.push(c);\n }\n\n // 0xDC00 ≤ c ≤ 0xDFFF\n else if (0xDC00 <= c && c <= 0xDFFF) {\n // Append to U a U+FFFD REPLACEMENT CHARACTER.\n u.push(0xFFFD);\n }\n\n // 0xD800 ≤ c ≤ 0xDBFF\n else if (0xD800 <= c && c <= 0xDBFF) {\n // 1. If i = n−1, then append to U a U+FFFD REPLACEMENT\n // CHARACTER.\n if (i === n - 1) {\n u.push(0xFFFD);\n }\n // 2. Otherwise, i < n−1:\n else {\n // 1. Let d be the code unit in S at index i+1.\n var d = string.charCodeAt(i + 1);\n\n // 2. If 0xDC00 ≤ d ≤ 0xDFFF, then:\n if (0xDC00 <= d && d <= 0xDFFF) {\n // 1. Let a be c & 0x3FF.\n var a = c & 0x3FF;\n\n // 2. Let b be d & 0x3FF.\n var b = d & 0x3FF;\n\n // 3. Append to U the Unicode character with code point\n // 2^16+2^10*a+b.\n u.push(0x10000 + (a << 10) + b);\n\n // 4. Set i to i+1.\n i += 1;\n }\n\n // 3. Otherwise, d < 0xDC00 or d > 0xDFFF. Append to U a\n // U+FFFD REPLACEMENT CHARACTER.\n else {\n u.push(0xFFFD);\n }\n }\n }\n\n // 3. Set i to i+1.\n i += 1;\n }\n\n // 6. Return U.\n return u;\n}\n\n/**\n * @param {!Array.} code_points Array of code points.\n * @return {string} string String of UTF-16 code units.\n */\nfunction codePointsToString(code_points) {\n var s = '';\n for (var i = 0; i < code_points.length; ++i) {\n var cp = code_points[i];\n if (cp <= 0xFFFF) {\n s += String.fromCharCode(cp);\n } else {\n cp -= 0x10000;\n s += String.fromCharCode((cp >> 10) + 0xD800,\n (cp & 0x3FF) + 0xDC00);\n }\n }\n return s;\n}\n\n\n//\n// Implementation of Encoding specification\n// https://encoding.spec.whatwg.org/\n//\n\n//\n// 3. Terminology\n//\n\n/**\n * End-of-stream is a special token that signifies no more tokens\n * are in the stream.\n * @const\n */ var end_of_stream = -1;\n\n/**\n * A stream represents an ordered sequence of tokens.\n *\n * @constructor\n * @param {!(Array.|Uint8Array)} tokens Array of tokens that provide the\n * stream.\n */\nfunction Stream(tokens) {\n /** @type {!Array.} */\n this.tokens = [].slice.call(tokens);\n}\n\nStream.prototype = {\n /**\n * @return {boolean} True if end-of-stream has been hit.\n */\n endOfStream: function() {\n return !this.tokens.length;\n },\n\n /**\n * When a token is read from a stream, the first token in the\n * stream must be returned and subsequently removed, and\n * end-of-stream must be returned otherwise.\n *\n * @return {number} Get the next token from the stream, or\n * end_of_stream.\n */\n read: function() {\n if (!this.tokens.length)\n return end_of_stream;\n return this.tokens.shift();\n },\n\n /**\n * When one or more tokens are prepended to a stream, those tokens\n * must be inserted, in given order, before the first token in the\n * stream.\n *\n * @param {(number|!Array.)} token The token(s) to prepend to the stream.\n */\n prepend: function(token) {\n if (Array.isArray(token)) {\n var tokens = /**@type {!Array.}*/(token);\n while (tokens.length)\n this.tokens.unshift(tokens.pop());\n } else {\n this.tokens.unshift(token);\n }\n },\n\n /**\n * When one or more tokens are pushed to a stream, those tokens\n * must be inserted, in given order, after the last token in the\n * stream.\n *\n * @param {(number|!Array.)} token The tokens(s) to prepend to the stream.\n */\n push: function(token) {\n if (Array.isArray(token)) {\n var tokens = /**@type {!Array.}*/(token);\n while (tokens.length)\n this.tokens.push(tokens.shift());\n } else {\n this.tokens.push(token);\n }\n }\n};\n\n//\n// 4. Encodings\n//\n\n// 4.1 Encoders and decoders\n\n/** @const */\nvar finished = -1;\n\n/**\n * @param {boolean} fatal If true, decoding errors raise an exception.\n * @param {number=} opt_code_point Override the standard fallback code point.\n * @return {number} The code point to insert on a decoding error.\n */\nfunction decoderError(fatal, opt_code_point) {\n if (fatal)\n throw TypeError('Decoder error');\n return opt_code_point || 0xFFFD;\n}\n\n/** @interface */\nfunction Decoder() {}\nDecoder.prototype = {\n /**\n * @param {Stream} stream The stream of bytes being decoded.\n * @param {number} bite The next byte read from the stream.\n * @return {?(number|!Array.)} The next code point(s)\n * decoded, or null if not enough data exists in the input\n * stream to decode a complete code point, or |finished|.\n */\n handler: function(stream, bite) {}\n};\n\n/** @interface */\nfunction Encoder() {}\nEncoder.prototype = {\n /**\n * @param {Stream} stream The stream of code points being encoded.\n * @param {number} code_point Next code point read from the stream.\n * @return {(number|!Array.)} Byte(s) to emit, or |finished|.\n */\n handler: function(stream, code_point) {}\n};\n\n//\n// 7. API\n//\n\n/** @const */ var DEFAULT_ENCODING = 'utf-8';\n\n// 7.1 Interface TextDecoder\n\n/**\n * @constructor\n * @param {string=} encoding The label of the encoding;\n * defaults to 'utf-8'.\n * @param {Object=} options\n */\nfunction TextDecoder(encoding, options) {\n if (!(this instanceof TextDecoder)) {\n return new TextDecoder(encoding, options);\n }\n encoding = encoding !== undefined ? String(encoding).toLowerCase() : DEFAULT_ENCODING;\n if (encoding !== DEFAULT_ENCODING) {\n throw new Error('Encoding not supported. Only utf-8 is supported');\n }\n options = ToDictionary(options);\n\n /** @private @type {boolean} */\n this._streaming = false;\n /** @private @type {boolean} */\n this._BOMseen = false;\n /** @private @type {?Decoder} */\n this._decoder = null;\n /** @private @type {boolean} */\n this._fatal = Boolean(options['fatal']);\n /** @private @type {boolean} */\n this._ignoreBOM = Boolean(options['ignoreBOM']);\n\n Object.defineProperty(this, 'encoding', {value: 'utf-8'});\n Object.defineProperty(this, 'fatal', {value: this._fatal});\n Object.defineProperty(this, 'ignoreBOM', {value: this._ignoreBOM});\n}\n\nTextDecoder.prototype = {\n /**\n * @param {ArrayBufferView=} input The buffer of bytes to decode.\n * @param {Object=} options\n * @return {string} The decoded string.\n */\n decode: function decode(input, options) {\n var bytes;\n if (typeof input === 'object' && input instanceof ArrayBuffer) {\n bytes = new Uint8Array(input);\n } else if (typeof input === 'object' && 'buffer' in input &&\n input.buffer instanceof ArrayBuffer) {\n bytes = new Uint8Array(input.buffer,\n input.byteOffset,\n input.byteLength);\n } else {\n bytes = new Uint8Array(0);\n }\n\n options = ToDictionary(options);\n\n if (!this._streaming) {\n this._decoder = new UTF8Decoder({fatal: this._fatal});\n this._BOMseen = false;\n }\n this._streaming = Boolean(options['stream']);\n\n var input_stream = new Stream(bytes);\n\n var code_points = [];\n\n /** @type {?(number|!Array.)} */\n var result;\n\n while (!input_stream.endOfStream()) {\n result = this._decoder.handler(input_stream, input_stream.read());\n if (result === finished)\n break;\n if (result === null)\n continue;\n if (Array.isArray(result))\n code_points.push.apply(code_points, /**@type {!Array.}*/(result));\n else\n code_points.push(result);\n }\n if (!this._streaming) {\n do {\n result = this._decoder.handler(input_stream, input_stream.read());\n if (result === finished)\n break;\n if (result === null)\n continue;\n if (Array.isArray(result))\n code_points.push.apply(code_points, /**@type {!Array.}*/(result));\n else\n code_points.push(result);\n } while (!input_stream.endOfStream());\n this._decoder = null;\n }\n\n if (code_points.length) {\n // If encoding is one of utf-8, utf-16be, and utf-16le, and\n // ignore BOM flag and BOM seen flag are unset, run these\n // subsubsteps:\n if (['utf-8'].indexOf(this.encoding) !== -1 &&\n !this._ignoreBOM && !this._BOMseen) {\n // If token is U+FEFF, set BOM seen flag.\n if (code_points[0] === 0xFEFF) {\n this._BOMseen = true;\n code_points.shift();\n } else {\n // Otherwise, if token is not end-of-stream, set BOM seen\n // flag and append token to output.\n this._BOMseen = true;\n }\n }\n }\n\n return codePointsToString(code_points);\n }\n};\n\n// 7.2 Interface TextEncoder\n\n/**\n * @constructor\n * @param {string=} encoding The label of the encoding;\n * defaults to 'utf-8'.\n * @param {Object=} options\n */\nfunction TextEncoder(encoding, options) {\n if (!(this instanceof TextEncoder))\n return new TextEncoder(encoding, options);\n encoding = encoding !== undefined ? String(encoding).toLowerCase() : DEFAULT_ENCODING;\n if (encoding !== DEFAULT_ENCODING) {\n throw new Error('Encoding not supported. Only utf-8 is supported');\n }\n options = ToDictionary(options);\n\n /** @private @type {boolean} */\n this._streaming = false;\n /** @private @type {?Encoder} */\n this._encoder = null;\n /** @private @type {{fatal: boolean}} */\n this._options = {fatal: Boolean(options['fatal'])};\n\n Object.defineProperty(this, 'encoding', {value: 'utf-8'});\n}\n\nTextEncoder.prototype = {\n /**\n * @param {string=} opt_string The string to encode.\n * @param {Object=} options\n * @return {Uint8Array} Encoded bytes, as a Uint8Array.\n */\n encode: function encode(opt_string, options) {\n opt_string = opt_string ? String(opt_string) : '';\n options = ToDictionary(options);\n\n // NOTE: This option is nonstandard. None of the encodings\n // permitted for encoding (i.e. UTF-8, UTF-16) are stateful,\n // so streaming is not necessary.\n if (!this._streaming)\n this._encoder = new UTF8Encoder(this._options);\n this._streaming = Boolean(options['stream']);\n\n var bytes = [];\n var input_stream = new Stream(stringToCodePoints(opt_string));\n /** @type {?(number|!Array.)} */\n var result;\n while (!input_stream.endOfStream()) {\n result = this._encoder.handler(input_stream, input_stream.read());\n if (result === finished)\n break;\n if (Array.isArray(result))\n bytes.push.apply(bytes, /**@type {!Array.}*/(result));\n else\n bytes.push(result);\n }\n if (!this._streaming) {\n while (true) {\n result = this._encoder.handler(input_stream, input_stream.read());\n if (result === finished)\n break;\n if (Array.isArray(result))\n bytes.push.apply(bytes, /**@type {!Array.}*/(result));\n else\n bytes.push(result);\n }\n this._encoder = null;\n }\n return new Uint8Array(bytes);\n }\n};\n\n//\n// 8. The encoding\n//\n\n// 8.1 utf-8\n\n/**\n * @constructor\n * @implements {Decoder}\n * @param {{fatal: boolean}} options\n */\nfunction UTF8Decoder(options) {\n var fatal = options.fatal;\n\n // utf-8's decoder's has an associated utf-8 code point, utf-8\n // bytes seen, and utf-8 bytes needed (all initially 0), a utf-8\n // lower boundary (initially 0x80), and a utf-8 upper boundary\n // (initially 0xBF).\n var /** @type {number} */ utf8_code_point = 0,\n /** @type {number} */ utf8_bytes_seen = 0,\n /** @type {number} */ utf8_bytes_needed = 0,\n /** @type {number} */ utf8_lower_boundary = 0x80,\n /** @type {number} */ utf8_upper_boundary = 0xBF;\n\n /**\n * @param {Stream} stream The stream of bytes being decoded.\n * @param {number} bite The next byte read from the stream.\n * @return {?(number|!Array.)} The next code point(s)\n * decoded, or null if not enough data exists in the input\n * stream to decode a complete code point.\n */\n this.handler = function(stream, bite) {\n // 1. If byte is end-of-stream and utf-8 bytes needed is not 0,\n // set utf-8 bytes needed to 0 and return error.\n if (bite === end_of_stream && utf8_bytes_needed !== 0) {\n utf8_bytes_needed = 0;\n return decoderError(fatal);\n }\n\n // 2. If byte is end-of-stream, return finished.\n if (bite === end_of_stream)\n return finished;\n\n // 3. If utf-8 bytes needed is 0, based on byte:\n if (utf8_bytes_needed === 0) {\n\n // 0x00 to 0x7F\n if (inRange(bite, 0x00, 0x7F)) {\n // Return a code point whose value is byte.\n return bite;\n }\n\n // 0xC2 to 0xDF\n if (inRange(bite, 0xC2, 0xDF)) {\n // Set utf-8 bytes needed to 1 and utf-8 code point to byte\n // − 0xC0.\n utf8_bytes_needed = 1;\n utf8_code_point = bite - 0xC0;\n }\n\n // 0xE0 to 0xEF\n else if (inRange(bite, 0xE0, 0xEF)) {\n // 1. If byte is 0xE0, set utf-8 lower boundary to 0xA0.\n if (bite === 0xE0)\n utf8_lower_boundary = 0xA0;\n // 2. If byte is 0xED, set utf-8 upper boundary to 0x9F.\n if (bite === 0xED)\n utf8_upper_boundary = 0x9F;\n // 3. Set utf-8 bytes needed to 2 and utf-8 code point to\n // byte − 0xE0.\n utf8_bytes_needed = 2;\n utf8_code_point = bite - 0xE0;\n }\n\n // 0xF0 to 0xF4\n else if (inRange(bite, 0xF0, 0xF4)) {\n // 1. If byte is 0xF0, set utf-8 lower boundary to 0x90.\n if (bite === 0xF0)\n utf8_lower_boundary = 0x90;\n // 2. If byte is 0xF4, set utf-8 upper boundary to 0x8F.\n if (bite === 0xF4)\n utf8_upper_boundary = 0x8F;\n // 3. Set utf-8 bytes needed to 3 and utf-8 code point to\n // byte − 0xF0.\n utf8_bytes_needed = 3;\n utf8_code_point = bite - 0xF0;\n }\n\n // Otherwise\n else {\n // Return error.\n return decoderError(fatal);\n }\n\n // Then (byte is in the range 0xC2 to 0xF4) set utf-8 code\n // point to utf-8 code point << (6 × utf-8 bytes needed) and\n // return continue.\n utf8_code_point = utf8_code_point << (6 * utf8_bytes_needed);\n return null;\n }\n\n // 4. If byte is not in the range utf-8 lower boundary to utf-8\n // upper boundary, run these substeps:\n if (!inRange(bite, utf8_lower_boundary, utf8_upper_boundary)) {\n\n // 1. Set utf-8 code point, utf-8 bytes needed, and utf-8\n // bytes seen to 0, set utf-8 lower boundary to 0x80, and set\n // utf-8 upper boundary to 0xBF.\n utf8_code_point = utf8_bytes_needed = utf8_bytes_seen = 0;\n utf8_lower_boundary = 0x80;\n utf8_upper_boundary = 0xBF;\n\n // 2. Prepend byte to stream.\n stream.prepend(bite);\n\n // 3. Return error.\n return decoderError(fatal);\n }\n\n // 5. Set utf-8 lower boundary to 0x80 and utf-8 upper boundary\n // to 0xBF.\n utf8_lower_boundary = 0x80;\n utf8_upper_boundary = 0xBF;\n\n // 6. Increase utf-8 bytes seen by one and set utf-8 code point\n // to utf-8 code point + (byte − 0x80) << (6 × (utf-8 bytes\n // needed − utf-8 bytes seen)).\n utf8_bytes_seen += 1;\n utf8_code_point += (bite - 0x80) << (6 * (utf8_bytes_needed - utf8_bytes_seen));\n\n // 7. If utf-8 bytes seen is not equal to utf-8 bytes needed,\n // continue.\n if (utf8_bytes_seen !== utf8_bytes_needed)\n return null;\n\n // 8. Let code point be utf-8 code point.\n var code_point = utf8_code_point;\n\n // 9. Set utf-8 code point, utf-8 bytes needed, and utf-8 bytes\n // seen to 0.\n utf8_code_point = utf8_bytes_needed = utf8_bytes_seen = 0;\n\n // 10. Return a code point whose value is code point.\n return code_point;\n };\n}\n\n/**\n * @constructor\n * @implements {Encoder}\n * @param {{fatal: boolean}} options\n */\nfunction UTF8Encoder(options) {\n var fatal = options.fatal;\n /**\n * @param {Stream} stream Input stream.\n * @param {number} code_point Next code point read from the stream.\n * @return {(number|!Array.)} Byte(s) to emit.\n */\n this.handler = function(stream, code_point) {\n // 1. If code point is end-of-stream, return finished.\n if (code_point === end_of_stream)\n return finished;\n\n // 2. If code point is in the range U+0000 to U+007F, return a\n // byte whose value is code point.\n if (inRange(code_point, 0x0000, 0x007f))\n return code_point;\n\n // 3. Set count and offset based on the range code point is in:\n var count, offset;\n // U+0080 to U+07FF: 1 and 0xC0\n if (inRange(code_point, 0x0080, 0x07FF)) {\n count = 1;\n offset = 0xC0;\n }\n // U+0800 to U+FFFF: 2 and 0xE0\n else if (inRange(code_point, 0x0800, 0xFFFF)) {\n count = 2;\n offset = 0xE0;\n }\n // U+10000 to U+10FFFF: 3 and 0xF0\n else if (inRange(code_point, 0x10000, 0x10FFFF)) {\n count = 3;\n offset = 0xF0;\n }\n\n // 4.Let bytes be a byte sequence whose first byte is (code\n // point >> (6 × count)) + offset.\n var bytes = [(code_point >> (6 * count)) + offset];\n\n // 5. Run these substeps while count is greater than 0:\n while (count > 0) {\n\n // 1. Set temp to code point >> (6 × (count − 1)).\n var temp = code_point >> (6 * (count - 1));\n\n // 2. Append to bytes 0x80 | (temp & 0x3F).\n bytes.push(0x80 | (temp & 0x3F));\n\n // 3. Decrease count by one.\n count -= 1;\n }\n\n // 6. Return bytes bytes, in order.\n return bytes;\n };\n}\n\nexport {TextEncoder, TextDecoder};\n","/**\n * WebSocket implements a browser-side WebSocket specification.\n * @module Client\n */\n\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = _default;\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _createClass2 = _interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));\n\nvar _inherits2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inherits\"));\n\nvar _possibleConstructorReturn2 = _interopRequireDefault(require(\"@babel/runtime/helpers/possibleConstructorReturn\"));\n\nvar _getPrototypeOf2 = _interopRequireDefault(require(\"@babel/runtime/helpers/getPrototypeOf\"));\n\nvar _eventemitter = require(\"eventemitter3\");\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2[\"default\"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2[\"default\"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2[\"default\"])(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nvar WebSocketBrowserImpl = /*#__PURE__*/function (_EventEmitter) {\n (0, _inherits2[\"default\"])(WebSocketBrowserImpl, _EventEmitter);\n\n var _super = _createSuper(WebSocketBrowserImpl);\n\n /** Instantiate a WebSocket class\n * @constructor\n * @param {String} address - url to a websocket server\n * @param {(Object)} options - websocket options\n * @param {(String|Array)} protocols - a list of protocols\n * @return {WebSocketBrowserImpl} - returns a WebSocket instance\n */\n function WebSocketBrowserImpl(address, options, protocols) {\n var _this;\n\n (0, _classCallCheck2[\"default\"])(this, WebSocketBrowserImpl);\n _this = _super.call(this);\n _this.socket = new window.WebSocket(address, protocols);\n\n _this.socket.onopen = function () {\n return _this.emit(\"open\");\n };\n\n _this.socket.onmessage = function (event) {\n return _this.emit(\"message\", event.data);\n };\n\n _this.socket.onerror = function (error) {\n return _this.emit(\"error\", error);\n };\n\n _this.socket.onclose = function (event) {\n _this.emit(\"close\", event.code, event.reason);\n };\n\n return _this;\n }\n /**\n * Sends data through a websocket connection\n * @method\n * @param {(String|Object)} data - data to be sent via websocket\n * @param {Object} optionsOrCallback - ws options\n * @param {Function} callback - a callback called once the data is sent\n * @return {Undefined}\n */\n\n\n (0, _createClass2[\"default\"])(WebSocketBrowserImpl, [{\n key: \"send\",\n value: function send(data, optionsOrCallback, callback) {\n var cb = callback || optionsOrCallback;\n\n try {\n this.socket.send(data);\n cb();\n } catch (error) {\n cb(error);\n }\n }\n /**\n * Closes an underlying socket\n * @method\n * @param {Number} code - status code explaining why the connection is being closed\n * @param {String} reason - a description why the connection is closing\n * @return {Undefined}\n * @throws {Error}\n */\n\n }, {\n key: \"close\",\n value: function close(code, reason) {\n this.socket.close(code, reason);\n }\n }, {\n key: \"addEventListener\",\n value: function addEventListener(type, listener, options) {\n this.socket.addEventListener(type, listener, options);\n }\n }]);\n return WebSocketBrowserImpl;\n}(_eventemitter.EventEmitter);\n/**\n * factory method for common WebSocket instance\n * @method\n * @param {String} address - url to a websocket server\n * @param {(Object)} options - websocket options\n * @return {Undefined}\n */\n\n\nfunction _default(address, options) {\n return new WebSocketBrowserImpl(address, options);\n}","/**\n * \"Client\" wraps \"ws\" or a browser-implemented \"WebSocket\" library\n * according to the environment providing JSON RPC 2.0 support on top.\n * @module Client\n */\n\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _createClass2 = _interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));\n\nvar _inherits2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inherits\"));\n\nvar _possibleConstructorReturn2 = _interopRequireDefault(require(\"@babel/runtime/helpers/possibleConstructorReturn\"));\n\nvar _getPrototypeOf2 = _interopRequireDefault(require(\"@babel/runtime/helpers/getPrototypeOf\"));\n\nvar _eventemitter = require(\"eventemitter3\");\n\nvar _circularJson = _interopRequireDefault(require(\"circular-json\"));\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2[\"default\"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2[\"default\"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2[\"default\"])(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nvar __rest = void 0 && (void 0).__rest || function (s, e) {\n var t = {};\n\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n }\n\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n}; // @ts-ignore\n\n\nvar CommonClient = /*#__PURE__*/function (_EventEmitter) {\n (0, _inherits2[\"default\"])(CommonClient, _EventEmitter);\n\n var _super = _createSuper(CommonClient);\n\n /**\n * Instantiate a Client class.\n * @constructor\n * @param {webSocketFactory} webSocketFactory - factory method for WebSocket\n * @param {String} address - url to a websocket server\n * @param {Object} options - ws options object with reconnect parameters\n * @param {Function} generate_request_id - custom generation request Id\n * @return {CommonClient}\n */\n function CommonClient(webSocketFactory) {\n var _this;\n\n var address = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : \"ws://localhost:8080\";\n\n var _a = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n var generate_request_id = arguments.length > 3 ? arguments[3] : undefined;\n (0, _classCallCheck2[\"default\"])(this, CommonClient);\n\n var _a$autoconnect = _a.autoconnect,\n autoconnect = _a$autoconnect === void 0 ? true : _a$autoconnect,\n _a$reconnect = _a.reconnect,\n reconnect = _a$reconnect === void 0 ? true : _a$reconnect,\n _a$reconnect_interval = _a.reconnect_interval,\n reconnect_interval = _a$reconnect_interval === void 0 ? 1000 : _a$reconnect_interval,\n _a$max_reconnects = _a.max_reconnects,\n max_reconnects = _a$max_reconnects === void 0 ? 5 : _a$max_reconnects,\n rest_options = __rest(_a, [\"autoconnect\", \"reconnect\", \"reconnect_interval\", \"max_reconnects\"]);\n\n _this = _super.call(this);\n _this.webSocketFactory = webSocketFactory;\n _this.queue = {};\n _this.rpc_id = 0;\n _this.address = address;\n _this.autoconnect = autoconnect;\n _this.ready = false;\n _this.reconnect = reconnect;\n _this.reconnect_interval = reconnect_interval;\n _this.max_reconnects = max_reconnects;\n _this.rest_options = rest_options;\n _this.current_reconnects = 0;\n\n _this.generate_request_id = generate_request_id || function () {\n return ++_this.rpc_id;\n };\n\n if (_this.autoconnect) _this._connect(_this.address, Object.assign({\n autoconnect: _this.autoconnect,\n reconnect: _this.reconnect,\n reconnect_interval: _this.reconnect_interval,\n max_reconnects: _this.max_reconnects\n }, _this.rest_options));\n return _this;\n }\n /**\n * Connects to a defined server if not connected already.\n * @method\n * @return {Undefined}\n */\n\n\n (0, _createClass2[\"default\"])(CommonClient, [{\n key: \"connect\",\n value: function connect() {\n if (this.socket) return;\n\n this._connect(this.address, Object.assign({\n autoconnect: this.autoconnect,\n reconnect: this.reconnect,\n reconnect_interval: this.reconnect_interval,\n max_reconnects: this.max_reconnects\n }, this.rest_options));\n }\n /**\n * Calls a registered RPC method on server.\n * @method\n * @param {String} method - RPC method name\n * @param {Object|Array} params - optional method parameters\n * @param {Number} timeout - RPC reply timeout value\n * @param {Object} ws_opts - options passed to ws\n * @return {Promise}\n */\n\n }, {\n key: \"call\",\n value: function call(method, params, timeout, ws_opts) {\n var _this2 = this;\n\n if (!ws_opts && \"object\" === (0, _typeof2[\"default\"])(timeout)) {\n ws_opts = timeout;\n timeout = null;\n }\n\n return new Promise(function (resolve, reject) {\n if (!_this2.ready) return reject(new Error(\"socket not ready\"));\n\n var rpc_id = _this2.generate_request_id(method, params);\n\n var message = {\n jsonrpc: \"2.0\",\n method: method,\n params: params || null,\n id: rpc_id\n };\n\n _this2.socket.send(JSON.stringify(message), ws_opts, function (error) {\n if (error) return reject(error);\n _this2.queue[rpc_id] = {\n promise: [resolve, reject]\n };\n\n if (timeout) {\n _this2.queue[rpc_id].timeout = setTimeout(function () {\n delete _this2.queue[rpc_id];\n reject(new Error(\"reply timeout\"));\n }, timeout);\n }\n });\n });\n }\n /**\n * Logins with the other side of the connection.\n * @method\n * @param {Object} params - Login credentials object\n * @return {Promise}\n */\n\n }, {\n key: \"login\",\n value: function () {\n var _login = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee(params) {\n var resp;\n return _regenerator[\"default\"].wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return this.call(\"rpc.login\", params);\n\n case 2:\n resp = _context.sent;\n\n if (resp) {\n _context.next = 5;\n break;\n }\n\n throw new Error(\"authentication failed\");\n\n case 5:\n return _context.abrupt(\"return\", resp);\n\n case 6:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function login(_x) {\n return _login.apply(this, arguments);\n }\n\n return login;\n }()\n /**\n * Fetches a list of client's methods registered on server.\n * @method\n * @return {Array}\n */\n\n }, {\n key: \"listMethods\",\n value: function () {\n var _listMethods = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee2() {\n return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _context2.next = 2;\n return this.call(\"__listMethods\");\n\n case 2:\n return _context2.abrupt(\"return\", _context2.sent);\n\n case 3:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function listMethods() {\n return _listMethods.apply(this, arguments);\n }\n\n return listMethods;\n }()\n /**\n * Sends a JSON-RPC 2.0 notification to server.\n * @method\n * @param {String} method - RPC method name\n * @param {Object} params - optional method parameters\n * @return {Promise}\n */\n\n }, {\n key: \"notify\",\n value: function notify(method, params) {\n var _this3 = this;\n\n return new Promise(function (resolve, reject) {\n if (!_this3.ready) return reject(new Error(\"socket not ready\"));\n var message = {\n jsonrpc: \"2.0\",\n method: method,\n params: params || null\n };\n\n _this3.socket.send(JSON.stringify(message), function (error) {\n if (error) return reject(error);\n resolve();\n });\n });\n }\n /**\n * Subscribes for a defined event.\n * @method\n * @param {String|Array} event - event name\n * @return {Undefined}\n * @throws {Error}\n */\n\n }, {\n key: \"subscribe\",\n value: function () {\n var _subscribe = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee3(event) {\n var result;\n return _regenerator[\"default\"].wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n if (typeof event === \"string\") event = [event];\n _context3.next = 3;\n return this.call(\"rpc.on\", event);\n\n case 3:\n result = _context3.sent;\n\n if (!(typeof event === \"string\" && result[event] !== \"ok\")) {\n _context3.next = 6;\n break;\n }\n\n throw new Error(\"Failed subscribing to an event '\" + event + \"' with: \" + result[event]);\n\n case 6:\n return _context3.abrupt(\"return\", result);\n\n case 7:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function subscribe(_x2) {\n return _subscribe.apply(this, arguments);\n }\n\n return subscribe;\n }()\n /**\n * Unsubscribes from a defined event.\n * @method\n * @param {String|Array} event - event name\n * @return {Undefined}\n * @throws {Error}\n */\n\n }, {\n key: \"unsubscribe\",\n value: function () {\n var _unsubscribe = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee4(event) {\n var result;\n return _regenerator[\"default\"].wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n if (typeof event === \"string\") event = [event];\n _context4.next = 3;\n return this.call(\"rpc.off\", event);\n\n case 3:\n result = _context4.sent;\n\n if (!(typeof event === \"string\" && result[event] !== \"ok\")) {\n _context4.next = 6;\n break;\n }\n\n throw new Error(\"Failed unsubscribing from an event with: \" + result);\n\n case 6:\n return _context4.abrupt(\"return\", result);\n\n case 7:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function unsubscribe(_x3) {\n return _unsubscribe.apply(this, arguments);\n }\n\n return unsubscribe;\n }()\n /**\n * Closes a WebSocket connection gracefully.\n * @method\n * @param {Number} code - socket close code\n * @param {String} data - optional data to be sent before closing\n * @return {Undefined}\n */\n\n }, {\n key: \"close\",\n value: function close(code, data) {\n this.socket.close(code || 1000, data);\n }\n /**\n * Connection/Message handler.\n * @method\n * @private\n * @param {String} address - WebSocket API address\n * @param {Object} options - ws options object\n * @return {Undefined}\n */\n\n }, {\n key: \"_connect\",\n value: function _connect(address, options) {\n var _this4 = this;\n\n this.socket = this.webSocketFactory(address, options);\n this.socket.addEventListener(\"open\", function () {\n _this4.ready = true;\n\n _this4.emit(\"open\");\n\n _this4.current_reconnects = 0;\n });\n this.socket.addEventListener(\"message\", function (_ref) {\n var message = _ref.data;\n if (message instanceof ArrayBuffer) message = Buffer.from(message).toString();\n\n try {\n message = _circularJson[\"default\"].parse(message);\n } catch (error) {\n return;\n } // check if any listeners are attached and forward event\n\n\n if (message.notification && _this4.listeners(message.notification).length) {\n if (!Object.keys(message.params).length) return _this4.emit(message.notification);\n var args = [message.notification];\n if (message.params.constructor === Object) args.push(message.params);else // using for-loop instead of unshift/spread because performance is better\n for (var i = 0; i < message.params.length; i++) {\n args.push(message.params[i]);\n } // run as microtask so that pending queue messages are resolved first\n // eslint-disable-next-line prefer-spread\n\n return Promise.resolve().then(function () {\n _this4.emit.apply(_this4, args);\n });\n }\n\n if (!_this4.queue[message.id]) {\n // general JSON RPC 2.0 events\n if (message.method && message.params) {\n // run as microtask so that pending queue messages are resolved first\n return Promise.resolve().then(function () {\n _this4.emit(message.method, message.params);\n });\n }\n\n return;\n } // reject early since server's response is invalid\n\n\n if (\"error\" in message === \"result\" in message) _this4.queue[message.id].promise[1](new Error(\"Server response malformed. Response must include either \\\"result\\\"\" + \" or \\\"error\\\", but not both.\"));\n if (_this4.queue[message.id].timeout) clearTimeout(_this4.queue[message.id].timeout);\n if (message.error) _this4.queue[message.id].promise[1](message.error);else _this4.queue[message.id].promise[0](message.result);\n delete _this4.queue[message.id];\n });\n this.socket.addEventListener(\"error\", function (error) {\n return _this4.emit(\"error\", error);\n });\n this.socket.addEventListener(\"close\", function (_ref2) {\n var code = _ref2.code,\n reason = _ref2.reason;\n if (_this4.ready) // Delay close event until internal state is updated\n setTimeout(function () {\n return _this4.emit(\"close\", code, reason);\n }, 0);\n _this4.ready = false;\n _this4.socket = undefined;\n if (code === 1000) return;\n _this4.current_reconnects++;\n if (_this4.reconnect && (_this4.max_reconnects > _this4.current_reconnects || _this4.max_reconnects === 0)) setTimeout(function () {\n return _this4._connect(address, options);\n }, _this4.reconnect_interval);\n });\n }\n }]);\n return CommonClient;\n}(_eventemitter.EventEmitter);\n\nexports[\"default\"] = CommonClient;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/*!\nCopyright (C) 2013-2017 by Andrea Giammarchi - @WebReflection\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n\n*/\nvar\n // should be a not so common char\n // possibly one JSON does not encode\n // possibly one encodeURIComponent does not encode\n // right now this char is '~' but this might change in the future\n specialChar = '~',\n safeSpecialChar = '\\\\x' + (\n '0' + specialChar.charCodeAt(0).toString(16)\n ).slice(-2),\n escapedSafeSpecialChar = '\\\\' + safeSpecialChar,\n specialCharRG = new RegExp(safeSpecialChar, 'g'),\n safeSpecialCharRG = new RegExp(escapedSafeSpecialChar, 'g'),\n\n safeStartWithSpecialCharRG = new RegExp('(?:^|([^\\\\\\\\]))' + escapedSafeSpecialChar),\n\n indexOf = [].indexOf || function(v){\n for(var i=this.length;i--&&this[i]!==v;);\n return i;\n },\n $String = String // there's no way to drop warnings in JSHint\n // about new String ... well, I need that here!\n // faked, and happy linter!\n;\n\nfunction generateReplacer(value, replacer, resolve) {\n var\n doNotIgnore = false,\n inspect = !!replacer,\n path = [],\n all = [value],\n seen = [value],\n mapp = [resolve ? specialChar : '[Circular]'],\n last = value,\n lvl = 1,\n i, fn\n ;\n if (inspect) {\n fn = typeof replacer === 'object' ?\n function (key, value) {\n return key !== '' && replacer.indexOf(key) < 0 ? void 0 : value;\n } :\n replacer;\n }\n return function(key, value) {\n // the replacer has rights to decide\n // if a new object should be returned\n // or if there's some key to drop\n // let's call it here rather than \"too late\"\n if (inspect) value = fn.call(this, key, value);\n\n // first pass should be ignored, since it's just the initial object\n if (doNotIgnore) {\n if (last !== this) {\n i = lvl - indexOf.call(all, this) - 1;\n lvl -= i;\n all.splice(lvl, all.length);\n path.splice(lvl - 1, path.length);\n last = this;\n }\n // console.log(lvl, key, path);\n if (typeof value === 'object' && value) {\n \t// if object isn't referring to parent object, add to the\n // object path stack. Otherwise it is already there.\n if (indexOf.call(all, value) < 0) {\n all.push(last = value);\n }\n lvl = all.length;\n i = indexOf.call(seen, value);\n if (i < 0) {\n i = seen.push(value) - 1;\n if (resolve) {\n // key cannot contain specialChar but could be not a string\n path.push(('' + key).replace(specialCharRG, safeSpecialChar));\n mapp[i] = specialChar + path.join(specialChar);\n } else {\n mapp[i] = mapp[0];\n }\n } else {\n value = mapp[i];\n }\n } else {\n if (typeof value === 'string' && resolve) {\n // ensure no special char involved on deserialization\n // in this case only first char is important\n // no need to replace all value (better performance)\n value = value .replace(safeSpecialChar, escapedSafeSpecialChar)\n .replace(specialChar, safeSpecialChar);\n }\n }\n } else {\n doNotIgnore = true;\n }\n return value;\n };\n}\n\nfunction retrieveFromPath(current, keys) {\n for(var i = 0, length = keys.length; i < length; current = current[\n // keys should be normalized back here\n keys[i++].replace(safeSpecialCharRG, specialChar)\n ]);\n return current;\n}\n\nfunction generateReviver(reviver) {\n return function(key, value) {\n var isString = typeof value === 'string';\n if (isString && value.charAt(0) === specialChar) {\n return new $String(value.slice(1));\n }\n if (key === '') value = regenerate(value, value, {});\n // again, only one needed, do not use the RegExp for this replacement\n // only keys need the RegExp\n if (isString) value = value .replace(safeStartWithSpecialCharRG, '$1' + specialChar)\n .replace(escapedSafeSpecialChar, safeSpecialChar);\n return reviver ? reviver.call(this, key, value) : value;\n };\n}\n\nfunction regenerateArray(root, current, retrieve) {\n for (var i = 0, length = current.length; i < length; i++) {\n current[i] = regenerate(root, current[i], retrieve);\n }\n return current;\n}\n\nfunction regenerateObject(root, current, retrieve) {\n for (var key in current) {\n if (current.hasOwnProperty(key)) {\n current[key] = regenerate(root, current[key], retrieve);\n }\n }\n return current;\n}\n\nfunction regenerate(root, current, retrieve) {\n return current instanceof Array ?\n // fast Array reconstruction\n regenerateArray(root, current, retrieve) :\n (\n current instanceof $String ?\n (\n // root is an empty string\n current.length ?\n (\n retrieve.hasOwnProperty(current) ?\n retrieve[current] :\n retrieve[current] = retrieveFromPath(\n root, current.split(specialChar)\n )\n ) :\n root\n ) :\n (\n current instanceof Object ?\n // dedicated Object parser\n regenerateObject(root, current, retrieve) :\n // value as it is\n current\n )\n )\n ;\n}\n\nvar CircularJSON = {\n stringify: function stringify(value, replacer, space, doNotResolve) {\n return CircularJSON.parser.stringify(\n value,\n generateReplacer(value, replacer, !doNotResolve),\n space\n );\n },\n parse: function parse(text, reviver) {\n return CircularJSON.parser.parse(\n text,\n generateReviver(reviver)\n );\n },\n // A parser should be an API 1:1 compatible with JSON\n // it should expose stringify and parse methods.\n // The default parser is the native JSON.\n parser: JSON\n};\n\nmodule.exports = CircularJSON;\n","'use strict';\n\nconst uuid = require('uuid').v4;\n\n/**\n * Generates a JSON-RPC 1.0 or 2.0 request\n * @param {String} method Name of method to call\n * @param {Array|Object} params Array of parameters passed to the method as specified, or an object of parameter names and corresponding value\n * @param {String|Number|null} [id] Request ID can be a string, number, null for explicit notification or left out for automatic generation\n * @param {Object} [options]\n * @param {Number} [options.version=2] JSON-RPC version to use (1 or 2)\n * @param {Boolean} [options.notificationIdNull=false] When true, version 2 requests will set id to null instead of omitting it\n * @param {Function} [options.generator] Passed the request, and the options object and is expected to return a request ID\n * @throws {TypeError} If any of the parameters are invalid\n * @return {Object} A JSON-RPC 1.0 or 2.0 request\n * @memberOf Utils\n */\nconst generateRequest = function(method, params, id, options) {\n if(typeof method !== 'string') {\n throw new TypeError(method + ' must be a string');\n }\n\n options = options || {};\n\n // check valid version provided\n const version = typeof options.version === 'number' ? options.version : 2;\n if (version !== 1 && version !== 2) {\n throw new TypeError(version + ' must be 1 or 2');\n }\n\n const request = {\n method: method\n };\n\n if(version === 2) {\n request.jsonrpc = '2.0';\n }\n\n if(params) {\n // params given, but invalid?\n if(typeof params !== 'object' && !Array.isArray(params)) {\n throw new TypeError(params + ' must be an object, array or omitted');\n }\n request.params = params;\n }\n\n // if id was left out, generate one (null means explicit notification)\n if(typeof(id) === 'undefined') {\n const generator = typeof options.generator === 'function' ? options.generator : function() { return uuid(); };\n request.id = generator(request, options);\n } else if (version === 2 && id === null) {\n // we have a version 2 notification\n if (options.notificationIdNull) {\n request.id = null; // id will not be set at all unless option provided\n }\n } else {\n request.id = id;\n }\n\n return request;\n};\n\nmodule.exports = generateRequest;\n","const errors = {\n IMPOSSIBLE_CASE: 'Impossible case. Please create issue.',\n TWEAK_ADD:\n 'The tweak was out of range or the resulted private key is invalid',\n TWEAK_MUL: 'The tweak was out of range or equal to zero',\n CONTEXT_RANDOMIZE_UNKNOW: 'Unknow error on context randomization',\n SECKEY_INVALID: 'Private Key is invalid',\n PUBKEY_PARSE: 'Public Key could not be parsed',\n PUBKEY_SERIALIZE: 'Public Key serialization error',\n PUBKEY_COMBINE: 'The sum of the public keys is not valid',\n SIG_PARSE: 'Signature could not be parsed',\n SIGN: 'The nonce generation function failed, or the private key was invalid',\n RECOVER: 'Public key could not be recover',\n ECDH: 'Scalar was invalid (zero or overflow)'\n}\n\nfunction assert (cond, msg) {\n if (!cond) throw new Error(msg)\n}\n\nfunction isUint8Array (name, value, length) {\n assert(value instanceof Uint8Array, `Expected ${name} to be an Uint8Array`)\n\n if (length !== undefined) {\n if (Array.isArray(length)) {\n const numbers = length.join(', ')\n const msg = `Expected ${name} to be an Uint8Array with length [${numbers}]`\n assert(length.includes(value.length), msg)\n } else {\n const msg = `Expected ${name} to be an Uint8Array with length ${length}`\n assert(value.length === length, msg)\n }\n }\n}\n\nfunction isCompressed (value) {\n assert(toTypeString(value) === 'Boolean', 'Expected compressed to be a Boolean')\n}\n\nfunction getAssertedOutput (output = (len) => new Uint8Array(len), length) {\n if (typeof output === 'function') output = output(length)\n isUint8Array('output', output, length)\n return output\n}\n\nfunction toTypeString (value) {\n return Object.prototype.toString.call(value).slice(8, -1)\n}\n\nmodule.exports = (secp256k1) => {\n return {\n contextRandomize (seed) {\n assert(\n seed === null || seed instanceof Uint8Array,\n 'Expected seed to be an Uint8Array or null'\n )\n if (seed !== null) isUint8Array('seed', seed, 32)\n\n switch (secp256k1.contextRandomize(seed)) {\n case 1:\n throw new Error(errors.CONTEXT_RANDOMIZE_UNKNOW)\n }\n },\n\n privateKeyVerify (seckey) {\n isUint8Array('private key', seckey, 32)\n\n return secp256k1.privateKeyVerify(seckey) === 0\n },\n\n privateKeyNegate (seckey) {\n isUint8Array('private key', seckey, 32)\n\n switch (secp256k1.privateKeyNegate(seckey)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakAdd(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n privateKeyTweakMul (seckey, tweak) {\n isUint8Array('private key', seckey, 32)\n isUint8Array('tweak', tweak, 32)\n\n switch (secp256k1.privateKeyTweakMul(seckey, tweak)) {\n case 0:\n return seckey\n case 1:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n publicKeyVerify (pubkey) {\n isUint8Array('public key', pubkey, [33, 65])\n\n return secp256k1.publicKeyVerify(pubkey) === 0\n },\n\n publicKeyCreate (seckey, compressed = true, output) {\n isUint8Array('private key', seckey, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCreate(output, seckey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SECKEY_INVALID)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyConvert (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyConvert(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyNegate (pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyNegate(output, pubkey)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyCombine (pubkeys, compressed = true, output) {\n assert(Array.isArray(pubkeys), 'Expected public keys to be an Array')\n assert(pubkeys.length > 0, 'Expected public keys array will have more than zero items')\n for (const pubkey of pubkeys) {\n isUint8Array('public key', pubkey, [33, 65])\n }\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyCombine(output, pubkeys)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_COMBINE)\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE)\n }\n },\n\n publicKeyTweakAdd (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakAdd(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_ADD)\n }\n },\n\n publicKeyTweakMul (pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('tweak', tweak, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.publicKeyTweakMul(output, pubkey, tweak)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.TWEAK_MUL)\n }\n },\n\n signatureNormalize (sig) {\n isUint8Array('signature', sig, 64)\n\n switch (secp256k1.signatureNormalize(sig)) {\n case 0:\n return sig\n case 1:\n throw new Error(errors.SIG_PARSE)\n }\n },\n\n signatureExport (sig, output) {\n isUint8Array('signature', sig, 64)\n output = getAssertedOutput(output, 72)\n\n const obj = { output, outputlen: 72 }\n switch (secp256k1.signatureExport(obj, sig)) {\n case 0:\n return output.slice(0, obj.outputlen)\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n signatureImport (sig, output) {\n isUint8Array('signature', sig)\n output = getAssertedOutput(output, 64)\n\n switch (secp256k1.signatureImport(output, sig)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaSign (msg32, seckey, options = {}, output) {\n isUint8Array('message', msg32, 32)\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.noncefn !== undefined) assert(toTypeString(options.noncefn) === 'Function', 'Expected options.noncefn to be a Function')\n output = getAssertedOutput(output, 64)\n\n const obj = { signature: output, recid: null }\n switch (secp256k1.ecdsaSign(obj, msg32, seckey, options.data, options.noncefn)) {\n case 0:\n return obj\n case 1:\n throw new Error(errors.SIGN)\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n isUint8Array('signature', sig, 64)\n isUint8Array('message', msg32, 32)\n isUint8Array('public key', pubkey, [33, 65])\n\n switch (secp256k1.ecdsaVerify(sig, msg32, pubkey)) {\n case 0:\n return true\n case 3:\n return false\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.PUBKEY_PARSE)\n }\n },\n\n ecdsaRecover (sig, recid, msg32, compressed = true, output) {\n isUint8Array('signature', sig, 64)\n assert(\n toTypeString(recid) === 'Number' &&\n recid >= 0 &&\n recid <= 3,\n 'Expected recovery id to be a Number within interval [0, 3]'\n )\n isUint8Array('message', msg32, 32)\n isCompressed(compressed)\n output = getAssertedOutput(output, compressed ? 33 : 65)\n\n switch (secp256k1.ecdsaRecover(output, sig, recid, msg32)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.SIG_PARSE)\n case 2:\n throw new Error(errors.RECOVER)\n case 3:\n throw new Error(errors.IMPOSSIBLE_CASE)\n }\n },\n\n ecdh (pubkey, seckey, options = {}, output) {\n isUint8Array('public key', pubkey, [33, 65])\n isUint8Array('private key', seckey, 32)\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object')\n if (options.data !== undefined) isUint8Array('options.data', options.data)\n if (options.hashfn !== undefined) {\n assert(toTypeString(options.hashfn) === 'Function', 'Expected options.hashfn to be a Function')\n if (options.xbuf !== undefined) isUint8Array('options.xbuf', options.xbuf, 32)\n if (options.ybuf !== undefined) isUint8Array('options.ybuf', options.ybuf, 32)\n isUint8Array('output', output)\n } else {\n output = getAssertedOutput(output, 32)\n }\n\n switch (secp256k1.ecdh(output, pubkey, seckey, options.data, options.hashfn, options.xbuf, options.ybuf)) {\n case 0:\n return output\n case 1:\n throw new Error(errors.PUBKEY_PARSE)\n case 2:\n throw new Error(errors.ECDH)\n }\n }\n }\n}\n","const EC = require('elliptic').ec\n\nconst ec = new EC('secp256k1')\nconst ecparams = ec.curve\n\n// Hack, we can not use bn.js@5, while elliptic uses bn.js@4\n// See https://github.com/indutny/elliptic/issues/191#issuecomment-569888758\nconst BN = ecparams.n.constructor\n\nfunction loadCompressedPublicKey (first, xbuf) {\n let x = new BN(xbuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0) return null\n x = x.toRed(ecparams.red)\n\n // compute corresponding Y\n let y = x.redSqr().redIMul(x).redIAdd(ecparams.b).redSqrt()\n if ((first === 0x03) !== y.isOdd()) y = y.redNeg()\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadUncompressedPublicKey (first, xbuf, ybuf) {\n let x = new BN(xbuf)\n let y = new BN(ybuf)\n\n // overflow\n if (x.cmp(ecparams.p) >= 0 || y.cmp(ecparams.p) >= 0) return null\n\n x = x.toRed(ecparams.red)\n y = y.toRed(ecparams.red)\n\n // is odd flag\n if ((first === 0x06 || first === 0x07) && y.isOdd() !== (first === 0x07)) return null\n\n // x*x*x + b = y*y\n const x3 = x.redSqr().redIMul(x)\n if (!y.redSqr().redISub(x3.redIAdd(ecparams.b)).isZero()) return null\n\n return ec.keyPair({ pub: { x: x, y: y } })\n}\n\nfunction loadPublicKey (pubkey) {\n // length should be validated in interface\n const first = pubkey[0]\n switch (first) {\n case 0x02:\n case 0x03:\n if (pubkey.length !== 33) return null\n return loadCompressedPublicKey(first, pubkey.subarray(1, 33))\n case 0x04:\n case 0x06:\n case 0x07:\n if (pubkey.length !== 65) return null\n return loadUncompressedPublicKey(first, pubkey.subarray(1, 33), pubkey.subarray(33, 65))\n default:\n return null\n }\n}\n\nfunction savePublicKey (output, point) {\n const pubkey = point.encode(null, output.length === 33)\n // Loop should be faster because we do not need create extra Uint8Array\n // output.set(new Uint8Array(pubkey))\n for (let i = 0; i < output.length; ++i) output[i] = pubkey[i]\n}\n\nmodule.exports = {\n contextRandomize () {\n return 0\n },\n\n privateKeyVerify (seckey) {\n const bn = new BN(seckey)\n return bn.cmp(ecparams.n) < 0 && !bn.isZero() ? 0 : 1\n },\n\n privateKeyNegate (seckey) {\n const bn = new BN(seckey)\n const negate = ecparams.n.sub(bn).umod(ecparams.n).toArrayLike(Uint8Array, 'be', 32)\n seckey.set(negate)\n return 0\n },\n\n privateKeyTweakAdd (seckey, tweak) {\n const bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0) return 1\n\n bn.iadd(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn.isub(ecparams.n)\n if (bn.isZero()) return 1\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n privateKeyTweakMul (seckey, tweak) {\n let bn = new BN(tweak)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n bn.imul(new BN(seckey))\n if (bn.cmp(ecparams.n) >= 0) bn = bn.umod(ecparams.n)\n\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32)\n seckey.set(tweaked)\n\n return 0\n },\n\n publicKeyVerify (pubkey) {\n const pair = loadPublicKey(pubkey)\n return pair === null ? 1 : 0\n },\n\n publicKeyCreate (output, seckey) {\n const bn = new BN(seckey)\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1\n\n const point = ec.keyFromPrivate(seckey).getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyConvert (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyNegate (output, pubkey) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const point = pair.getPublic()\n point.y = point.y.redNeg()\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyCombine (output, pubkeys) {\n const pairs = new Array(pubkeys.length)\n for (let i = 0; i < pubkeys.length; ++i) {\n pairs[i] = loadPublicKey(pubkeys[i])\n if (pairs[i] === null) return 1\n }\n\n let point = pairs[0].getPublic()\n for (let i = 1; i < pairs.length; ++i) point = point.add(pairs[i].pub)\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakAdd (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0) return 2\n\n const point = pair.getPublic().add(ecparams.g.mul(tweak))\n if (point.isInfinity()) return 2\n\n savePublicKey(output, point)\n\n return 0\n },\n\n publicKeyTweakMul (output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n tweak = new BN(tweak)\n if (tweak.cmp(ecparams.n) >= 0 || tweak.isZero()) return 2\n\n const point = pair.getPublic().mul(tweak)\n savePublicKey(output, point)\n\n return 0\n },\n\n signatureNormalize (sig) {\n const r = new BN(sig.subarray(0, 32))\n const s = new BN(sig.subarray(32, 64))\n if (r.cmp(ecparams.n) >= 0 || s.cmp(ecparams.n) >= 0) return 1\n\n if (s.cmp(ec.nh) === 1) {\n sig.set(ecparams.n.sub(s).toArrayLike(Uint8Array, 'be', 32), 32)\n }\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureExport (obj, sig) {\n const sigR = sig.subarray(0, 32)\n const sigS = sig.subarray(32, 64)\n if (new BN(sigR).cmp(ecparams.n) >= 0) return 1\n if (new BN(sigS).cmp(ecparams.n) >= 0) return 1\n\n const { output } = obj\n\n // Prepare R\n let r = output.subarray(4, 4 + 33)\n r[0] = 0x00\n r.set(sigR, 1)\n\n let lenR = 33\n let posR = 0\n for (; lenR > 1 && r[posR] === 0x00 && !(r[posR + 1] & 0x80); --lenR, ++posR);\n\n r = r.subarray(posR)\n if (r[0] & 0x80) return 1\n if (lenR > 1 && (r[0] === 0x00) && !(r[1] & 0x80)) return 1\n\n // Prepare S\n let s = output.subarray(6 + 33, 6 + 33 + 33)\n s[0] = 0x00\n s.set(sigS, 1)\n\n let lenS = 33\n let posS = 0\n for (; lenS > 1 && s[posS] === 0x00 && !(s[posS + 1] & 0x80); --lenS, ++posS);\n\n s = s.subarray(posS)\n if (s[0] & 0x80) return 1\n if (lenS > 1 && (s[0] === 0x00) && !(s[1] & 0x80)) return 1\n\n // Set output length for return\n obj.outputlen = 6 + lenR + lenS\n\n // Output in specified format\n // 0x30 [total-length] 0x02 [R-length] [R] 0x02 [S-length] [S]\n output[0] = 0x30\n output[1] = obj.outputlen - 2\n output[2] = 0x02\n output[3] = r.length\n output.set(r, 4)\n output[4 + lenR] = 0x02\n output[5 + lenR] = s.length\n output.set(s, 6 + lenR)\n\n return 0\n },\n\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureImport (output, sig) {\n if (sig.length < 8) return 1\n if (sig.length > 72) return 1\n if (sig[0] !== 0x30) return 1\n if (sig[1] !== sig.length - 2) return 1\n if (sig[2] !== 0x02) return 1\n\n const lenR = sig[3]\n if (lenR === 0) return 1\n if (5 + lenR >= sig.length) return 1\n if (sig[4 + lenR] !== 0x02) return 1\n\n const lenS = sig[5 + lenR]\n if (lenS === 0) return 1\n if ((6 + lenR + lenS) !== sig.length) return 1\n\n if (sig[4] & 0x80) return 1\n if (lenR > 1 && (sig[4] === 0x00) && !(sig[5] & 0x80)) return 1\n\n if (sig[lenR + 6] & 0x80) return 1\n if (lenS > 1 && (sig[lenR + 6] === 0x00) && !(sig[lenR + 7] & 0x80)) return 1\n\n let sigR = sig.subarray(4, 4 + lenR)\n if (sigR.length === 33 && sigR[0] === 0x00) sigR = sigR.subarray(1)\n if (sigR.length > 32) return 1\n\n let sigS = sig.subarray(6 + lenR)\n if (sigS.length === 33 && sigS[0] === 0x00) sigS = sigS.slice(1)\n if (sigS.length > 32) throw new Error('S length is too long')\n\n let r = new BN(sigR)\n if (r.cmp(ecparams.n) >= 0) r = new BN(0)\n\n let s = new BN(sig.subarray(6 + lenR))\n if (s.cmp(ecparams.n) >= 0) s = new BN(0)\n\n output.set(r.toArrayLike(Uint8Array, 'be', 32), 0)\n output.set(s.toArrayLike(Uint8Array, 'be', 32), 32)\n\n return 0\n },\n\n ecdsaSign (obj, message, seckey, data, noncefn) {\n if (noncefn) {\n const _noncefn = noncefn\n noncefn = (counter) => {\n const nonce = _noncefn(message, seckey, null, data, counter)\n\n const isValid = nonce instanceof Uint8Array && nonce.length === 32\n if (!isValid) throw new Error('This is the way')\n\n return new BN(nonce)\n }\n }\n\n const d = new BN(seckey)\n if (d.cmp(ecparams.n) >= 0 || d.isZero()) return 1\n\n let sig\n try {\n sig = ec.sign(message, seckey, { canonical: true, k: noncefn, pers: data })\n } catch (err) {\n return 1\n }\n\n obj.signature.set(sig.r.toArrayLike(Uint8Array, 'be', 32), 0)\n obj.signature.set(sig.s.toArrayLike(Uint8Array, 'be', 32), 32)\n obj.recid = sig.recoveryParam\n\n return 0\n },\n\n ecdsaVerify (sig, msg32, pubkey) {\n const sigObj = { r: sig.subarray(0, 32), s: sig.subarray(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n if (sigs.cmp(ec.nh) === 1 || sigr.isZero() || sigs.isZero()) return 3\n\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 2\n\n const point = pair.getPublic()\n const isValid = ec.verify(msg32, sigObj, point)\n return isValid ? 0 : 3\n },\n\n ecdsaRecover (output, sig, recid, msg32) {\n const sigObj = { r: sig.slice(0, 32), s: sig.slice(32, 64) }\n\n const sigr = new BN(sigObj.r)\n const sigs = new BN(sigObj.s)\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1\n\n if (sigr.isZero() || sigs.isZero()) return 2\n\n // Can throw `throw new Error('Unable to find sencond key candinate');`\n let point\n try {\n point = ec.recoverPubKey(msg32, sigObj, recid)\n } catch (err) {\n return 2\n }\n\n savePublicKey(output, point)\n\n return 0\n },\n\n ecdh (output, pubkey, seckey, data, hashfn, xbuf, ybuf) {\n const pair = loadPublicKey(pubkey)\n if (pair === null) return 1\n\n const scalar = new BN(seckey)\n if (scalar.cmp(ecparams.n) >= 0 || scalar.isZero()) return 2\n\n const point = pair.getPublic().mul(scalar)\n\n if (hashfn === undefined) {\n const data = point.encode(null, true)\n const sha256 = ec.hash().update(data).digest()\n for (let i = 0; i < 32; ++i) output[i] = sha256[i]\n } else {\n if (!xbuf) xbuf = new Uint8Array(32)\n const x = point.getX().toArray('be', 32)\n for (let i = 0; i < 32; ++i) xbuf[i] = x[i]\n\n if (!ybuf) ybuf = new Uint8Array(32)\n const y = point.getY().toArray('be', 32)\n for (let i = 0; i < 32; ++i) ybuf[i] = y[i]\n\n const hash = hashfn(xbuf, ybuf, data)\n\n const isValid = hash instanceof Uint8Array && hash.length === output.length\n if (!isValid) return 2\n\n output.set(hash)\n }\n\n return 0\n }\n}\n","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n Base.call(this, 'short', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.tinv = this.two.redInvm();\n\n this.zeroA = this.a.fromRed().cmpn(0) === 0;\n this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n // If the curve is endomorphic, precalculate beta and lambda\n this.endo = this._getEndomorphism(conf);\n this._endoWnafT1 = new Array(4);\n this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n // No efficient endomorphism\n if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n return;\n\n // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n var beta;\n var lambda;\n if (conf.beta) {\n beta = new BN(conf.beta, 16).toRed(this.red);\n } else {\n var betas = this._getEndoRoots(this.p);\n // Choose the smallest beta\n beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n beta = beta.toRed(this.red);\n }\n if (conf.lambda) {\n lambda = new BN(conf.lambda, 16);\n } else {\n // Choose the lambda that is matching selected beta\n var lambdas = this._getEndoRoots(this.n);\n if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n lambda = lambdas[0];\n } else {\n lambda = lambdas[1];\n assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n }\n }\n\n // Get basis vectors, used for balanced length-two representation\n var basis;\n if (conf.basis) {\n basis = conf.basis.map(function(vec) {\n return {\n a: new BN(vec.a, 16),\n b: new BN(vec.b, 16),\n };\n });\n } else {\n basis = this._getEndoBasis(lambda);\n }\n\n return {\n beta: beta,\n lambda: lambda,\n basis: basis,\n };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n // Find roots of for x^2 + x + 1 in F\n // Root = (-1 +- Sqrt(-3)) / 2\n //\n var red = num === this.p ? this.red : BN.mont(num);\n var tinv = new BN(2).toRed(red).redInvm();\n var ntinv = tinv.redNeg();\n\n var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n var l1 = ntinv.redAdd(s).fromRed();\n var l2 = ntinv.redSub(s).fromRed();\n return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n // aprxSqrt >= sqrt(this.n)\n var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n // 3.74\n // Run EGCD, until r(L + 1) < aprxSqrt\n var u = lambda;\n var v = this.n.clone();\n var x1 = new BN(1);\n var y1 = new BN(0);\n var x2 = new BN(0);\n var y2 = new BN(1);\n\n // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n var a0;\n var b0;\n // First vector\n var a1;\n var b1;\n // Second vector\n var a2;\n var b2;\n\n var prevR;\n var i = 0;\n var r;\n var x;\n while (u.cmpn(0) !== 0) {\n var q = v.div(u);\n r = v.sub(q.mul(u));\n x = x2.sub(q.mul(x1));\n var y = y2.sub(q.mul(y1));\n\n if (!a1 && r.cmp(aprxSqrt) < 0) {\n a0 = prevR.neg();\n b0 = x1;\n a1 = r.neg();\n b1 = x;\n } else if (a1 && ++i === 2) {\n break;\n }\n prevR = r;\n\n v = u;\n u = r;\n x2 = x1;\n x1 = x;\n y2 = y1;\n y1 = y;\n }\n a2 = r.neg();\n b2 = x;\n\n var len1 = a1.sqr().add(b1.sqr());\n var len2 = a2.sqr().add(b2.sqr());\n if (len2.cmp(len1) >= 0) {\n a2 = a0;\n b2 = b0;\n }\n\n // Normalize signs\n if (a1.negative) {\n a1 = a1.neg();\n b1 = b1.neg();\n }\n if (a2.negative) {\n a2 = a2.neg();\n b2 = b2.neg();\n }\n\n return [\n { a: a1, b: b1 },\n { a: a2, b: b2 },\n ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n var basis = this.endo.basis;\n var v1 = basis[0];\n var v2 = basis[1];\n\n var c1 = v2.b.mul(k).divRound(this.n);\n var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n var p1 = c1.mul(v1.a);\n var p2 = c2.mul(v2.a);\n var q1 = c1.mul(v1.b);\n var q2 = c2.mul(v2.b);\n\n // Calculate answer\n var k1 = k.sub(p1).sub(p2);\n var k2 = q1.add(q2).neg();\n return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n // XXX Is there any way to tell if the number is odd without converting it\n // to non-red form?\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n if (point.inf)\n return true;\n\n var x = point.x;\n var y = point.y;\n\n var ax = this.a.redMul(x);\n var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n var npoints = this._endoWnafT1;\n var ncoeffs = this._endoWnafT2;\n for (var i = 0; i < points.length; i++) {\n var split = this._endoSplit(coeffs[i]);\n var p = points[i];\n var beta = p._getBeta();\n\n if (split.k1.negative) {\n split.k1.ineg();\n p = p.neg(true);\n }\n if (split.k2.negative) {\n split.k2.ineg();\n beta = beta.neg(true);\n }\n\n npoints[i * 2] = p;\n npoints[i * 2 + 1] = beta;\n ncoeffs[i * 2] = split.k1;\n ncoeffs[i * 2 + 1] = split.k2;\n }\n var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n // Clean-up references to points and coefficients\n for (var j = 0; j < i * 2; j++) {\n npoints[j] = null;\n ncoeffs[j] = null;\n }\n return res;\n };\n\nfunction Point(curve, x, y, isRed) {\n Base.BasePoint.call(this, curve, 'affine');\n if (x === null && y === null) {\n this.x = null;\n this.y = null;\n this.inf = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n // Force redgomery representation when loading from JSON\n if (isRed) {\n this.x.forceRed(this.curve.red);\n this.y.forceRed(this.curve.red);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n this.inf = false;\n }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n if (!this.curve.endo)\n return;\n\n var pre = this.precomputed;\n if (pre && pre.beta)\n return pre.beta;\n\n var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n if (pre) {\n var curve = this.curve;\n var endoMul = function(p) {\n return curve.point(p.x.redMul(curve.endo.beta), p.y);\n };\n pre.beta = beta;\n beta.precomputed = {\n beta: null,\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(endoMul),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(endoMul),\n },\n };\n }\n return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n if (!this.precomputed)\n return [ this.x, this.y ];\n\n return [ this.x, this.y, this.precomputed && {\n doubles: this.precomputed.doubles && {\n step: this.precomputed.doubles.step,\n points: this.precomputed.doubles.points.slice(1),\n },\n naf: this.precomputed.naf && {\n wnd: this.precomputed.naf.wnd,\n points: this.precomputed.naf.points.slice(1),\n },\n } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n if (typeof obj === 'string')\n obj = JSON.parse(obj);\n var res = curve.point(obj[0], obj[1], red);\n if (!obj[2])\n return res;\n\n function obj2point(obj) {\n return curve.point(obj[0], obj[1], red);\n }\n\n var pre = obj[2];\n res.precomputed = {\n beta: null,\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: [ res ].concat(pre.doubles.points.map(obj2point)),\n },\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: [ res ].concat(pre.naf.points.map(obj2point)),\n },\n };\n return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.inf)\n return p;\n\n // P + O = P\n if (p.inf)\n return this;\n\n // P + P = 2P\n if (this.eq(p))\n return this.dbl();\n\n // P + (-P) = O\n if (this.neg().eq(p))\n return this.curve.point(null, null);\n\n // P + Q = O\n if (this.x.cmp(p.x) === 0)\n return this.curve.point(null, null);\n\n var c = this.y.redSub(p.y);\n if (c.cmpn(0) !== 0)\n c = c.redMul(this.x.redSub(p.x).redInvm());\n var nx = c.redSqr().redISub(this.x).redISub(p.x);\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.inf)\n return this;\n\n // 2P = O\n var ys1 = this.y.redAdd(this.y);\n if (ys1.cmpn(0) === 0)\n return this.curve.point(null, null);\n\n var a = this.curve.a;\n\n var x2 = this.x.redSqr();\n var dyinv = ys1.redInvm();\n var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n k = new BN(k, 16);\n if (this.isInfinity())\n return this;\n else if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else if (this.curve.endo)\n return this.curve._endoWnafMulAdd([ this ], [ k ]);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n var points = [ this, p2 ];\n var coeffs = [ k1, k2 ];\n if (this.curve.endo)\n return this.curve._endoWnafMulAdd(points, coeffs, true);\n else\n return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n return this === p ||\n this.inf === p.inf &&\n (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n if (this.inf)\n return this;\n\n var res = this.curve.point(this.x, this.y.redNeg());\n if (_precompute && this.precomputed) {\n var pre = this.precomputed;\n var negate = function(p) {\n return p.neg();\n };\n res.precomputed = {\n naf: pre.naf && {\n wnd: pre.naf.wnd,\n points: pre.naf.points.map(negate),\n },\n doubles: pre.doubles && {\n step: pre.doubles.step,\n points: pre.doubles.points.map(negate),\n },\n };\n }\n return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n if (this.inf)\n return this.curve.jpoint(null, null, null);\n\n var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n Base.BasePoint.call(this, curve, 'jacobian');\n if (x === null && y === null && z === null) {\n this.x = this.curve.one;\n this.y = this.curve.one;\n this.z = new BN(0);\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = new BN(z, 16);\n }\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n\n this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n if (this.isInfinity())\n return this.curve.point(null, null);\n\n var zinv = this.z.redInvm();\n var zinv2 = zinv.redSqr();\n var ax = this.x.redMul(zinv2);\n var ay = this.y.redMul(zinv2).redMul(zinv);\n\n return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n // O + P = P\n if (this.isInfinity())\n return p;\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 12M + 4S + 7A\n var pz2 = p.z.redSqr();\n var z2 = this.z.redSqr();\n var u1 = this.x.redMul(pz2);\n var u2 = p.x.redMul(z2);\n var s1 = this.y.redMul(pz2.redMul(p.z));\n var s2 = p.y.redMul(z2.redMul(this.z));\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(p.z).redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n // O + P = P\n if (this.isInfinity())\n return p.toJ();\n\n // P + O = P\n if (p.isInfinity())\n return this;\n\n // 8M + 3S + 7A\n var z2 = this.z.redSqr();\n var u1 = this.x;\n var u2 = p.x.redMul(z2);\n var s1 = this.y;\n var s2 = p.y.redMul(z2).redMul(this.z);\n\n var h = u1.redSub(u2);\n var r = s1.redSub(s2);\n if (h.cmpn(0) === 0) {\n if (r.cmpn(0) !== 0)\n return this.curve.jpoint(null, null, null);\n else\n return this.dbl();\n }\n\n var h2 = h.redSqr();\n var h3 = h2.redMul(h);\n var v = u1.redMul(h2);\n\n var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n var nz = this.z.redMul(h);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n if (pow === 0)\n return this;\n if (this.isInfinity())\n return this;\n if (!pow)\n return this.dbl();\n\n var i;\n if (this.curve.zeroA || this.curve.threeA) {\n var r = this;\n for (i = 0; i < pow; i++)\n r = r.dbl();\n return r;\n }\n\n // 1M + 2S + 1A + N * (4S + 5M + 8A)\n // N = 1 => 6M + 6S + 9A\n var a = this.curve.a;\n var tinv = this.curve.tinv;\n\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n // Reuse results\n var jyd = jy.redAdd(jy);\n for (i = 0; i < pow; i++) {\n var jx2 = jx.redSqr();\n var jyd2 = jyd.redSqr();\n var jyd4 = jyd2.redSqr();\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var t1 = jx.redMul(jyd2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n var dny = c.redMul(t2);\n dny = dny.redIAdd(dny).redISub(jyd4);\n var nz = jyd.redMul(jz);\n if (i + 1 < pow)\n jz4 = jz4.redMul(jyd4);\n\n jx = nx;\n jz = nz;\n jyd = dny;\n }\n\n return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n if (this.curve.zeroA)\n return this._zeroDbl();\n else if (this.curve.threeA)\n return this._threeDbl();\n else\n return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 14A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // T = M ^ 2 - 2*S\n var t = m.redSqr().redISub(s).redISub(s);\n\n // 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2*Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n // #doubling-dbl-2009-l\n // 2M + 5S + 13A\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = B^2\n var c = b.redSqr();\n // D = 2 * ((X1 + B)^2 - A - C)\n var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n d = d.redIAdd(d);\n // E = 3 * A\n var e = a.redAdd(a).redIAdd(a);\n // F = E^2\n var f = e.redSqr();\n\n // 8 * C\n var c8 = c.redIAdd(c);\n c8 = c8.redIAdd(c8);\n c8 = c8.redIAdd(c8);\n\n // X3 = F - 2 * D\n nx = f.redISub(d).redISub(d);\n // Y3 = E * (D - X3) - 8 * C\n ny = e.redMul(d.redISub(nx)).redISub(c8);\n // Z3 = 2 * Y1 * Z1\n nz = this.y.redMul(this.z);\n nz = nz.redIAdd(nz);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n var nx;\n var ny;\n var nz;\n // Z = 1\n if (this.zOne) {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n // #doubling-mdbl-2007-bl\n // 1M + 5S + 15A\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n s = s.redIAdd(s);\n // M = 3 * XX + a\n var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n // T = M^2 - 2 * S\n var t = m.redSqr().redISub(s).redISub(s);\n // X3 = T\n nx = t;\n // Y3 = M * (S - T) - 8 * YYYY\n var yyyy8 = yyyy.redIAdd(yyyy);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n yyyy8 = yyyy8.redIAdd(yyyy8);\n ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n // Z3 = 2 * Y1\n nz = this.y.redAdd(this.y);\n } else {\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n // 3M + 5S\n\n // delta = Z1^2\n var delta = this.z.redSqr();\n // gamma = Y1^2\n var gamma = this.y.redSqr();\n // beta = X1 * gamma\n var beta = this.x.redMul(gamma);\n // alpha = 3 * (X1 - delta) * (X1 + delta)\n var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n alpha = alpha.redAdd(alpha).redIAdd(alpha);\n // X3 = alpha^2 - 8 * beta\n var beta4 = beta.redIAdd(beta);\n beta4 = beta4.redIAdd(beta4);\n var beta8 = beta4.redAdd(beta4);\n nx = alpha.redSqr().redISub(beta8);\n // Z3 = (Y1 + Z1)^2 - gamma - delta\n nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n var ggamma8 = gamma.redSqr();\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ggamma8 = ggamma8.redIAdd(ggamma8);\n ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n }\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n var a = this.curve.a;\n\n // 4M + 6S + 10A\n var jx = this.x;\n var jy = this.y;\n var jz = this.z;\n var jz4 = jz.redSqr().redSqr();\n\n var jx2 = jx.redSqr();\n var jy2 = jy.redSqr();\n\n var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n var jxd4 = jx.redAdd(jx);\n jxd4 = jxd4.redIAdd(jxd4);\n var t1 = jxd4.redMul(jy2);\n var nx = c.redSqr().redISub(t1.redAdd(t1));\n var t2 = t1.redISub(nx);\n\n var jyd8 = jy2.redSqr();\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n jyd8 = jyd8.redIAdd(jyd8);\n var ny = c.redMul(t2).redISub(jyd8);\n var nz = jy.redAdd(jy).redMul(jz);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n if (!this.curve.zeroA)\n return this.dbl().add(this);\n\n // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n // 5M + 10S + ...\n\n // XX = X1^2\n var xx = this.x.redSqr();\n // YY = Y1^2\n var yy = this.y.redSqr();\n // ZZ = Z1^2\n var zz = this.z.redSqr();\n // YYYY = YY^2\n var yyyy = yy.redSqr();\n // M = 3 * XX + a * ZZ2; a = 0\n var m = xx.redAdd(xx).redIAdd(xx);\n // MM = M^2\n var mm = m.redSqr();\n // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n e = e.redIAdd(e);\n e = e.redAdd(e).redIAdd(e);\n e = e.redISub(mm);\n // EE = E^2\n var ee = e.redSqr();\n // T = 16*YYYY\n var t = yyyy.redIAdd(yyyy);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n t = t.redIAdd(t);\n // U = (M + E)^2 - MM - EE - T\n var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n // X3 = 4 * (X1 * EE - 4 * YY * U)\n var yyu4 = yy.redMul(u);\n yyu4 = yyu4.redIAdd(yyu4);\n yyu4 = yyu4.redIAdd(yyu4);\n var nx = this.x.redMul(ee).redISub(yyu4);\n nx = nx.redIAdd(nx);\n nx = nx.redIAdd(nx);\n // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n ny = ny.redIAdd(ny);\n // Z3 = (Z1 + E)^2 - ZZ - EE\n var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n k = new BN(k, kbase);\n\n return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n if (p.type === 'affine')\n return this.eq(p.toJ());\n\n if (this === p)\n return true;\n\n // x1 * z2^2 == x2 * z1^2\n var z2 = this.z.redSqr();\n var pz2 = p.z.redSqr();\n if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n return false;\n\n // y1 * z2^3 == y2 * z1^3\n var z3 = z2.redMul(this.z);\n var pz3 = pz2.redMul(p.z);\n return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n var zs = this.z.redSqr();\n var rx = x.toRed(this.curve.red).redMul(zs);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(zs);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\nJPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n Base.call(this, 'mont', conf);\n\n this.a = new BN(conf.a, 16).toRed(this.red);\n this.b = new BN(conf.b, 16).toRed(this.red);\n this.i4 = new BN(4).toRed(this.red).redInvm();\n this.two = new BN(2).toRed(this.red);\n this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n var x = point.normalize().x;\n var x2 = x.redSqr();\n var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n var y = rhs.redSqrt();\n\n return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && z === null) {\n this.x = this.curve.one;\n this.z = this.curve.zero;\n } else {\n this.x = new BN(x, 16);\n this.z = new BN(z, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n // 2M + 2S + 4A\n\n // A = X1 + Z1\n var a = this.x.redAdd(this.z);\n // AA = A^2\n var aa = a.redSqr();\n // B = X1 - Z1\n var b = this.x.redSub(this.z);\n // BB = B^2\n var bb = b.redSqr();\n // C = AA - BB\n var c = aa.redSub(bb);\n // X3 = AA * BB\n var nx = aa.redMul(bb);\n // Z3 = C * (BB + A24 * C)\n var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n // 4M + 2S + 6A\n\n // A = X2 + Z2\n var a = this.x.redAdd(this.z);\n // B = X2 - Z2\n var b = this.x.redSub(this.z);\n // C = X3 + Z3\n var c = p.x.redAdd(p.z);\n // D = X3 - Z3\n var d = p.x.redSub(p.z);\n // DA = D * A\n var da = d.redMul(a);\n // CB = C * B\n var cb = c.redMul(b);\n // X5 = Z1 * (DA + CB)^2\n var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n // Z5 = X1 * (DA - CB)^2\n var nz = diff.x.redMul(da.redISub(cb).redSqr());\n return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n var t = k.clone();\n var a = this; // (N / 2) * Q + Q\n var b = this.curve.point(null, null); // (N / 2) * Q\n var c = this; // Q\n\n for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n bits.push(t.andln(1));\n\n for (var i = bits.length - 1; i >= 0; i--) {\n if (bits[i] === 0) {\n // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n a = a.diffAdd(b, c);\n // N * Q = 2 * ((N / 2) * Q + Q))\n b = b.dbl();\n } else {\n // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n b = a.diffAdd(b, c);\n // N * Q + Q = 2 * ((N / 2) * Q + Q)\n a = a.dbl();\n }\n }\n return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n this.x = this.x.redMul(this.z.redInvm());\n this.z = this.curve.one;\n return this;\n};\n\nPoint.prototype.getX = function getX() {\n // Normalize coordinates\n this.normalize();\n\n return this.x.fromRed();\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n // NOTE: Important as we are creating point in Base.call()\n this.twisted = (conf.a | 0) !== 1;\n this.mOneA = this.twisted && (conf.a | 0) === -1;\n this.extended = this.mOneA;\n\n Base.call(this, 'edwards', conf);\n\n this.a = new BN(conf.a, 16).umod(this.red.m);\n this.a = this.a.toRed(this.red);\n this.c = new BN(conf.c, 16).toRed(this.red);\n this.c2 = this.c.redSqr();\n this.d = new BN(conf.d, 16).toRed(this.red);\n this.dd = this.d.redAdd(this.d);\n\n assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n if (this.mOneA)\n return num.redNeg();\n else\n return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n if (this.oneC)\n return num;\n else\n return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n x = new BN(x, 16);\n if (!x.red)\n x = x.toRed(this.red);\n\n var x2 = x.redSqr();\n var rhs = this.c2.redSub(this.a.redMul(x2));\n var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n var y2 = rhs.redMul(lhs.redInvm());\n var y = y2.redSqrt();\n if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n var isOdd = y.fromRed().isOdd();\n if (odd && !isOdd || !odd && isOdd)\n y = y.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n y = new BN(y, 16);\n if (!y.red)\n y = y.toRed(this.red);\n\n // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n var y2 = y.redSqr();\n var lhs = y2.redSub(this.c2);\n var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n var x2 = lhs.redMul(rhs.redInvm());\n\n if (x2.cmp(this.zero) === 0) {\n if (odd)\n throw new Error('invalid point');\n else\n return this.point(this.zero, y);\n }\n\n var x = x2.redSqrt();\n if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n throw new Error('invalid point');\n\n if (x.fromRed().isOdd() !== odd)\n x = x.redNeg();\n\n return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n if (point.isInfinity())\n return true;\n\n // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n point.normalize();\n\n var x2 = point.x.redSqr();\n var y2 = point.y.redSqr();\n var lhs = x2.redMul(this.a).redAdd(y2);\n var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n Base.BasePoint.call(this, curve, 'projective');\n if (x === null && y === null && z === null) {\n this.x = this.curve.zero;\n this.y = this.curve.one;\n this.z = this.curve.one;\n this.t = this.curve.zero;\n this.zOne = true;\n } else {\n this.x = new BN(x, 16);\n this.y = new BN(y, 16);\n this.z = z ? new BN(z, 16) : this.curve.one;\n this.t = t && new BN(t, 16);\n if (!this.x.red)\n this.x = this.x.toRed(this.curve.red);\n if (!this.y.red)\n this.y = this.y.toRed(this.curve.red);\n if (!this.z.red)\n this.z = this.z.toRed(this.curve.red);\n if (this.t && !this.t.red)\n this.t = this.t.toRed(this.curve.red);\n this.zOne = this.z === this.curve.one;\n\n // Use extended coordinates\n if (this.curve.extended && !this.t) {\n this.t = this.x.redMul(this.y);\n if (!this.zOne)\n this.t = this.t.redMul(this.z.redInvm());\n }\n }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n if (this.isInfinity())\n return '';\n return '';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n // XXX This code assumes that zero is always zero in red\n return this.x.cmpn(0) === 0 &&\n (this.y.cmp(this.z) === 0 ||\n (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #doubling-dbl-2008-hwcd\n // 4M + 4S\n\n // A = X1^2\n var a = this.x.redSqr();\n // B = Y1^2\n var b = this.y.redSqr();\n // C = 2 * Z1^2\n var c = this.z.redSqr();\n c = c.redIAdd(c);\n // D = a * A\n var d = this.curve._mulA(a);\n // E = (X1 + Y1)^2 - A - B\n var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n // G = D + B\n var g = d.redAdd(b);\n // F = G - C\n var f = g.redSub(c);\n // H = D - B\n var h = d.redSub(b);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #doubling-dbl-2008-bbjlp\n // #doubling-dbl-2007-bl\n // and others\n // Generally 3M + 4S or 2M + 4S\n\n // B = (X1 + Y1)^2\n var b = this.x.redAdd(this.y).redSqr();\n // C = X1^2\n var c = this.x.redSqr();\n // D = Y1^2\n var d = this.y.redSqr();\n\n var nx;\n var ny;\n var nz;\n var e;\n var h;\n var j;\n if (this.curve.twisted) {\n // E = a * C\n e = this.curve._mulA(c);\n // F = E + D\n var f = e.redAdd(d);\n if (this.zOne) {\n // X3 = (B - C - D) * (F - 2)\n nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F^2 - 2 * F\n nz = f.redSqr().redSub(f).redSub(f);\n } else {\n // H = Z1^2\n h = this.z.redSqr();\n // J = F - 2 * H\n j = f.redSub(h).redISub(h);\n // X3 = (B-C-D)*J\n nx = b.redSub(c).redISub(d).redMul(j);\n // Y3 = F * (E - D)\n ny = f.redMul(e.redSub(d));\n // Z3 = F * J\n nz = f.redMul(j);\n }\n } else {\n // E = C + D\n e = c.redAdd(d);\n // H = (c * Z1)^2\n h = this.curve._mulC(this.z).redSqr();\n // J = E - 2 * H\n j = e.redSub(h).redSub(h);\n // X3 = c * (B - E) * J\n nx = this.curve._mulC(b.redISub(e)).redMul(j);\n // Y3 = c * E * (C - D)\n ny = this.curve._mulC(e).redMul(c.redISub(d));\n // Z3 = E * J\n nz = e.redMul(j);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n if (this.isInfinity())\n return this;\n\n // Double in extended coordinates\n if (this.curve.extended)\n return this._extDbl();\n else\n return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n // #addition-add-2008-hwcd-3\n // 8M\n\n // A = (Y1 - X1) * (Y2 - X2)\n var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n // B = (Y1 + X1) * (Y2 + X2)\n var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n // C = T1 * k * T2\n var c = this.t.redMul(this.curve.dd).redMul(p.t);\n // D = Z1 * 2 * Z2\n var d = this.z.redMul(p.z.redAdd(p.z));\n // E = B - A\n var e = b.redSub(a);\n // F = D - C\n var f = d.redSub(c);\n // G = D + C\n var g = d.redAdd(c);\n // H = B + A\n var h = b.redAdd(a);\n // X3 = E * F\n var nx = e.redMul(f);\n // Y3 = G * H\n var ny = g.redMul(h);\n // T3 = E * H\n var nt = e.redMul(h);\n // Z3 = F * G\n var nz = f.redMul(g);\n return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n // #addition-add-2008-bbjlp\n // #addition-add-2007-bl\n // 10M + 1S\n\n // A = Z1 * Z2\n var a = this.z.redMul(p.z);\n // B = A^2\n var b = a.redSqr();\n // C = X1 * X2\n var c = this.x.redMul(p.x);\n // D = Y1 * Y2\n var d = this.y.redMul(p.y);\n // E = d * C * D\n var e = this.curve.d.redMul(c).redMul(d);\n // F = B - E\n var f = b.redSub(e);\n // G = B + E\n var g = b.redAdd(e);\n // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n var nx = a.redMul(f).redMul(tmp);\n var ny;\n var nz;\n if (this.curve.twisted) {\n // Y3 = A * G * (D - a * C)\n ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n // Z3 = F * G\n nz = f.redMul(g);\n } else {\n // Y3 = A * G * (D - C)\n ny = a.redMul(g).redMul(d.redSub(c));\n // Z3 = c * F * G\n nz = this.curve._mulC(f).redMul(g);\n }\n return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n if (this.isInfinity())\n return p;\n if (p.isInfinity())\n return this;\n\n if (this.curve.extended)\n return this._extAdd(p);\n else\n return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n if (this._hasDoubles(k))\n return this.curve._fixedNafMul(this, k);\n else\n return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n if (this.zOne)\n return this;\n\n // Normalize coordinates\n var zi = this.z.redInvm();\n this.x = this.x.redMul(zi);\n this.y = this.y.redMul(zi);\n if (this.t)\n this.t = this.t.redMul(zi);\n this.z = this.curve.one;\n this.zOne = true;\n return this;\n};\n\nPoint.prototype.neg = function neg() {\n return this.curve.point(this.x.redNeg(),\n this.y,\n this.z,\n this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n this.normalize();\n return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n this.normalize();\n return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n return this === other ||\n this.getX().cmp(other.getX()) === 0 &&\n this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n var rx = x.toRed(this.curve.red).redMul(this.z);\n if (this.x.cmp(rx) === 0)\n return true;\n\n var xc = x.clone();\n var t = this.curve.redN.redMul(this.z);\n for (;;) {\n xc.iadd(this.curve.n);\n if (xc.cmp(this.curve.p) >= 0)\n return false;\n\n rx.redIAdd(t);\n if (this.x.cmp(rx) === 0)\n return true;\n }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n","'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n 0x5A827999, 0x6ED9EBA1,\n 0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n if (!(this instanceof SHA1))\n return new SHA1();\n\n BlockHash.call(this);\n this.h = [\n 0x67452301, 0xefcdab89, 0x98badcfe,\n 0x10325476, 0xc3d2e1f0 ];\n this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n var W = this.W;\n\n for (var i = 0; i < 16; i++)\n W[i] = msg[start + i];\n\n for(; i < W.length; i++)\n W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n var a = this.h[0];\n var b = this.h[1];\n var c = this.h[2];\n var d = this.h[3];\n var e = this.h[4];\n\n for (i = 0; i < W.length; i++) {\n var s = ~~(i / 20);\n var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n e = d;\n d = c;\n c = rotl32(b, 30);\n b = a;\n a = t;\n }\n\n this.h[0] = sum32(this.h[0], a);\n this.h[1] = sum32(this.h[1], b);\n this.h[2] = sum32(this.h[2], c);\n this.h[3] = sum32(this.h[3], d);\n this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'big');\n else\n return utils.split32(this.h, 'big');\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n if (!(this instanceof SHA224))\n return new SHA224();\n\n SHA256.call(this);\n this.h = [\n 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n // Just truncate output\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 7), 'big');\n else\n return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n","'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n if (!(this instanceof SHA384))\n return new SHA384();\n\n SHA512.call(this);\n this.h = [\n 0xcbbb9d5d, 0xc1059ed8,\n 0x629a292a, 0x367cd507,\n 0x9159015a, 0x3070dd17,\n 0x152fecd8, 0xf70e5939,\n 0x67332667, 0xffc00b31,\n 0x8eb44a87, 0x68581511,\n 0xdb0c2e0d, 0x64f98fa7,\n 0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h.slice(0, 12), 'big');\n else\n return utils.split32(this.h.slice(0, 12), 'big');\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n if (!(this instanceof RIPEMD160))\n return new RIPEMD160();\n\n BlockHash.call(this);\n\n this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n var A = this.h[0];\n var B = this.h[1];\n var C = this.h[2];\n var D = this.h[3];\n var E = this.h[4];\n var Ah = A;\n var Bh = B;\n var Ch = C;\n var Dh = D;\n var Eh = E;\n for (var j = 0; j < 80; j++) {\n var T = sum32(\n rotl32(\n sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n s[j]),\n E);\n A = E;\n E = D;\n D = rotl32(C, 10);\n C = B;\n B = T;\n T = sum32(\n rotl32(\n sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n sh[j]),\n Eh);\n Ah = Eh;\n Eh = Dh;\n Dh = rotl32(Ch, 10);\n Ch = Bh;\n Bh = T;\n }\n T = sum32_3(this.h[1], C, Dh);\n this.h[1] = sum32_3(this.h[2], D, Eh);\n this.h[2] = sum32_3(this.h[3], E, Ah);\n this.h[3] = sum32_3(this.h[4], A, Bh);\n this.h[4] = sum32_3(this.h[0], B, Ch);\n this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n if (enc === 'hex')\n return utils.toHex32(this.h, 'little');\n else\n return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n if (j <= 15)\n return x ^ y ^ z;\n else if (j <= 31)\n return (x & y) | ((~x) & z);\n else if (j <= 47)\n return (x | (~y)) ^ z;\n else if (j <= 63)\n return (x & z) | (y & (~z));\n else\n return x ^ (y | (~z));\n}\n\nfunction K(j) {\n if (j <= 15)\n return 0x00000000;\n else if (j <= 31)\n return 0x5a827999;\n else if (j <= 47)\n return 0x6ed9eba1;\n else if (j <= 63)\n return 0x8f1bbcdc;\n else\n return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n if (j <= 15)\n return 0x50a28be6;\n else if (j <= 31)\n return 0x5c4dd124;\n else if (j <= 47)\n return 0x6d703ef3;\n else if (j <= 63)\n return 0x7a6d76e9;\n else\n return 0x00000000;\n}\n\nvar r = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n if (!(this instanceof Hmac))\n return new Hmac(hash, key, enc);\n this.Hash = hash;\n this.blockSize = hash.blockSize / 8;\n this.outSize = hash.outSize / 8;\n this.inner = null;\n this.outer = null;\n\n this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n // Shorten key, if needed\n if (key.length > this.blockSize)\n key = new this.Hash().update(key).digest();\n assert(key.length <= this.blockSize);\n\n // Add padding to key\n for (var i = key.length; i < this.blockSize; i++)\n key.push(0);\n\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x36;\n this.inner = new this.Hash().update(key);\n\n // 0x36 ^ 0x5c = 0x6a\n for (i = 0; i < key.length; i++)\n key[i] ^= 0x6a;\n this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n this.inner.update(msg, enc);\n return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n this.outer.update(this.inner.digest());\n return this.outer.digest(enc);\n};\n","module.exports = {\n doubles: {\n step: 4,\n points: [\n [\n 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n ],\n [\n '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n ],\n [\n '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n ],\n [\n '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n ],\n [\n '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n ],\n [\n '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n ],\n [\n 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n ],\n [\n '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n ],\n [\n 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n ],\n [\n 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n ],\n [\n 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n ],\n [\n '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n ],\n [\n '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n ],\n [\n '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n ],\n [\n '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n ],\n [\n '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n ],\n [\n '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n ],\n [\n '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n ],\n [\n '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n ],\n [\n 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n ],\n [\n 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n ],\n [\n '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n ],\n [\n '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n ],\n [\n 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n ],\n [\n '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n ],\n [\n 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n ],\n [\n 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n ],\n [\n 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n ],\n [\n 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n ],\n [\n 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n ],\n [\n '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n ],\n [\n '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n ],\n [\n 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n ],\n [\n '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n ],\n [\n 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n ],\n [\n 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n ],\n [\n 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n ],\n [\n '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n ],\n [\n '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n ],\n [\n '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n ],\n [\n '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n ],\n [\n 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n ],\n [\n '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n ],\n [\n '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n ],\n [\n '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n ],\n [\n 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n ],\n [\n '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n ],\n [\n 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n ],\n [\n 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n ],\n [\n '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n ],\n [\n '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n ],\n [\n 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n ],\n [\n 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n ],\n [\n 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n ],\n [\n '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n ],\n [\n '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n ],\n [\n 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n ],\n [\n '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n ],\n [\n '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n ],\n [\n '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n ],\n [\n 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n ],\n [\n '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n ],\n [\n '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n ],\n [\n 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n ],\n [\n 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n ],\n ],\n },\n naf: {\n wnd: 7,\n points: [\n [\n 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n ],\n [\n '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n ],\n [\n '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n ],\n [\n 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n ],\n [\n '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n ],\n [\n 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n ],\n [\n 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n ],\n [\n 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n ],\n [\n '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n ],\n [\n '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n ],\n [\n '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n ],\n [\n '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n ],\n [\n 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n ],\n [\n 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n ],\n [\n '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n ],\n [\n '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n ],\n [\n '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n ],\n [\n '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n ],\n [\n '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n ],\n [\n '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n ],\n [\n 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n ],\n [\n '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n ],\n [\n '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n ],\n [\n 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n ],\n [\n '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n ],\n [\n 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n ],\n [\n 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n ],\n [\n '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n ],\n [\n '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n ],\n [\n '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n ],\n [\n 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n ],\n [\n '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n ],\n [\n 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n ],\n [\n '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n ],\n [\n '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n ],\n [\n 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n ],\n [\n '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n ],\n [\n '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n ],\n [\n 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n ],\n [\n '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n ],\n [\n '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n ],\n [\n '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n ],\n [\n '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n ],\n [\n 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n ],\n [\n '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n ],\n [\n '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n ],\n [\n '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n ],\n [\n 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n ],\n [\n 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n ],\n [\n '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n ],\n [\n '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n ],\n [\n 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n ],\n [\n 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n ],\n [\n '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n ],\n [\n '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n ],\n [\n 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n ],\n [\n '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n ],\n [\n 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n ],\n [\n '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n ],\n [\n '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n ],\n [\n 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n ],\n [\n 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n ],\n [\n '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n ],\n [\n '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n ],\n [\n '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n ],\n [\n '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n ],\n [\n '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n ],\n [\n '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n ],\n [\n '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n ],\n [\n '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n ],\n [\n 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n ],\n [\n '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n ],\n [\n 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n ],\n [\n 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n ],\n [\n 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n ],\n [\n 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n ],\n [\n '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n ],\n [\n '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n ],\n [\n '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n ],\n [\n 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n ],\n [\n 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n ],\n [\n 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n ],\n [\n 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n ],\n [\n '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n ],\n [\n 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n ],\n [\n 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n ],\n [\n '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n ],\n [\n '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n ],\n [\n 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n ],\n [\n 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n ],\n [\n 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n ],\n [\n '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n ],\n [\n 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n ],\n [\n '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n ],\n [\n 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n ],\n [\n 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n ],\n [\n '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n ],\n [\n 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n ],\n [\n 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n ],\n [\n 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n ],\n [\n '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n ],\n [\n '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n ],\n [\n 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n ],\n [\n '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n ],\n [\n '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n ],\n [\n '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n ],\n [\n 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n ],\n [\n '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n ],\n [\n '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n ],\n [\n '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n ],\n [\n '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n ],\n [\n 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n ],\n [\n '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n ],\n [\n 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n ],\n [\n '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n ],\n [\n 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n ],\n [\n 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n ],\n [\n 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n ],\n [\n '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n ],\n [\n '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n ],\n [\n '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n ],\n [\n '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n ],\n [\n '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n ],\n [\n '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n ],\n [\n '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n ],\n [\n '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n ],\n [\n '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n ],\n ],\n },\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n if (!(this instanceof EC))\n return new EC(options);\n\n // Shortcut `elliptic.ec(curve-name)`\n if (typeof options === 'string') {\n assert(Object.prototype.hasOwnProperty.call(curves, options),\n 'Unknown curve ' + options);\n\n options = curves[options];\n }\n\n // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n if (options instanceof curves.PresetCurve)\n options = { curve: options };\n\n this.curve = options.curve.curve;\n this.n = this.curve.n;\n this.nh = this.n.ushrn(1);\n this.g = this.curve.g;\n\n // Point on curve\n this.g = options.curve.g;\n this.g.precompute(options.curve.n.bitLength() + 1);\n\n // Hash for function for DRBG\n this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n if (!options)\n options = {};\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n entropy: options.entropy || rand(this.hash.hmacStrength),\n entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n nonce: this.n.toArray(),\n });\n\n var bytes = this.n.byteLength();\n var ns2 = this.n.sub(new BN(2));\n for (;;) {\n var priv = new BN(drbg.generate(bytes));\n if (priv.cmp(ns2) > 0)\n continue;\n\n priv.iaddn(1);\n return this.keyFromPrivate(priv);\n }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly) {\n var delta = msg.byteLength() * 8 - this.n.bitLength();\n if (delta > 0)\n msg = msg.ushrn(delta);\n if (!truncOnly && msg.cmp(this.n) >= 0)\n return msg.sub(this.n);\n else\n return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n if (typeof enc === 'object') {\n options = enc;\n enc = null;\n }\n if (!options)\n options = {};\n\n key = this.keyFromPrivate(key, enc);\n msg = this._truncateToN(new BN(msg, 16));\n\n // Zero-extend key to provide enough entropy\n var bytes = this.n.byteLength();\n var bkey = key.getPrivate().toArray('be', bytes);\n\n // Zero-extend nonce to have the same byte size as N\n var nonce = msg.toArray('be', bytes);\n\n // Instantiate Hmac_DRBG\n var drbg = new HmacDRBG({\n hash: this.hash,\n entropy: bkey,\n nonce: nonce,\n pers: options.pers,\n persEnc: options.persEnc || 'utf8',\n });\n\n // Number of bytes to generate\n var ns1 = this.n.sub(new BN(1));\n\n for (var iter = 0; ; iter++) {\n var k = options.k ?\n options.k(iter) :\n new BN(drbg.generate(this.n.byteLength()));\n k = this._truncateToN(k, true);\n if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n continue;\n\n var kp = this.g.mul(k);\n if (kp.isInfinity())\n continue;\n\n var kpX = kp.getX();\n var r = kpX.umod(this.n);\n if (r.cmpn(0) === 0)\n continue;\n\n var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n s = s.umod(this.n);\n if (s.cmpn(0) === 0)\n continue;\n\n var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n (kpX.cmp(r) !== 0 ? 2 : 0);\n\n // Use complement of `s`, if it is > `n / 2`\n if (options.canonical && s.cmp(this.nh) > 0) {\n s = this.n.sub(s);\n recoveryParam ^= 1;\n }\n\n return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc) {\n msg = this._truncateToN(new BN(msg, 16));\n key = this.keyFromPublic(key, enc);\n signature = new Signature(signature, 'hex');\n\n // Perform primitive values validation\n var r = signature.r;\n var s = signature.s;\n if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n return false;\n if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n return false;\n\n // Validate signature\n var sinv = s.invm(this.n);\n var u1 = sinv.mul(msg).umod(this.n);\n var u2 = sinv.mul(r).umod(this.n);\n var p;\n\n if (!this.curve._maxwellTrick) {\n p = this.g.mulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n return p.getX().umod(this.n).cmp(r) === 0;\n }\n\n // NOTE: Greg Maxwell's trick, inspired by:\n // https://git.io/vad3K\n\n p = this.g.jmulAdd(u1, key.getPublic(), u2);\n if (p.isInfinity())\n return false;\n\n // Compare `p.x` of Jacobian point with `r`,\n // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n // inverse of `p.z^2`\n return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n assert((3 & j) === j, 'The recovery param is more than two bits');\n signature = new Signature(signature, enc);\n\n var n = this.n;\n var e = new BN(msg);\n var r = signature.r;\n var s = signature.s;\n\n // A set LSB signifies that the y-coordinate is odd\n var isYOdd = j & 1;\n var isSecondKey = j >> 1;\n if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n throw new Error('Unable to find sencond key candinate');\n\n // 1.1. Let x = r + jn.\n if (isSecondKey)\n r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n else\n r = this.curve.pointFromX(r, isYOdd);\n\n var rInv = signature.r.invm(n);\n var s1 = n.sub(e).mul(rInv).umod(n);\n var s2 = s.mul(rInv).umod(n);\n\n // 1.6.1 Compute Q = r^-1 (sR - eG)\n // Q = r^-1 (sR + -eG)\n return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n signature = new Signature(signature, enc);\n if (signature.recoveryParam !== null)\n return signature.recoveryParam;\n\n for (var i = 0; i < 4; i++) {\n var Qprime;\n try {\n Qprime = this.recoverPubKey(e, signature, i);\n } catch (e) {\n continue;\n }\n\n if (Qprime.eq(Q))\n return i;\n }\n throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n if (!(this instanceof HmacDRBG))\n return new HmacDRBG(options);\n this.hash = options.hash;\n this.predResist = !!options.predResist;\n\n this.outLen = this.hash.outSize;\n this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n this._reseed = null;\n this.reseedInterval = null;\n this.K = null;\n this.V = null;\n\n var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n var seed = entropy.concat(nonce).concat(pers);\n\n this.K = new Array(this.outLen / 8);\n this.V = new Array(this.outLen / 8);\n for (var i = 0; i < this.V.length; i++) {\n this.K[i] = 0x00;\n this.V[i] = 0x01;\n }\n\n this._update(seed);\n this._reseed = 1;\n this.reseedInterval = 0x1000000000000; // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n var kmac = this._hmac()\n .update(this.V)\n .update([ 0x00 ]);\n if (seed)\n kmac = kmac.update(seed);\n this.K = kmac.digest();\n this.V = this._hmac().update(this.V).digest();\n if (!seed)\n return;\n\n this.K = this._hmac()\n .update(this.V)\n .update([ 0x01 ])\n .update(seed)\n .digest();\n this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n // Optional entropy enc\n if (typeof entropyEnc !== 'string') {\n addEnc = add;\n add = entropyEnc;\n entropyEnc = null;\n }\n\n entropy = utils.toArray(entropy, entropyEnc);\n add = utils.toArray(add, addEnc);\n\n assert(entropy.length >= (this.minEntropy / 8),\n 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n this._update(entropy.concat(add || []));\n this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n if (this._reseed > this.reseedInterval)\n throw new Error('Reseed is required');\n\n // Optional encoding\n if (typeof enc !== 'string') {\n addEnc = add;\n add = enc;\n enc = null;\n }\n\n // Optional additional data\n if (add) {\n add = utils.toArray(add, addEnc || 'hex');\n this._update(add);\n }\n\n var temp = [];\n while (temp.length < len) {\n this.V = this._hmac().update(this.V).digest();\n temp = temp.concat(this.V);\n }\n\n var res = temp.slice(0, len);\n this._update(add);\n this._reseed++;\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n this.ec = ec;\n this.priv = null;\n this.pub = null;\n\n // KeyPair(ec, { priv: ..., pub: ... })\n if (options.priv)\n this._importPrivate(options.priv, options.privEnc);\n if (options.pub)\n this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n if (pub instanceof KeyPair)\n return pub;\n\n return new KeyPair(ec, {\n pub: pub,\n pubEnc: enc,\n });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n if (priv instanceof KeyPair)\n return priv;\n\n return new KeyPair(ec, {\n priv: priv,\n privEnc: enc,\n });\n};\n\nKeyPair.prototype.validate = function validate() {\n var pub = this.getPublic();\n\n if (pub.isInfinity())\n return { result: false, reason: 'Invalid public key' };\n if (!pub.validate())\n return { result: false, reason: 'Public key is not a point' };\n if (!pub.mul(this.ec.curve.n).isInfinity())\n return { result: false, reason: 'Public key * N != O' };\n\n return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n // compact is optional argument\n if (typeof compact === 'string') {\n enc = compact;\n compact = null;\n }\n\n if (!this.pub)\n this.pub = this.ec.g.mul(this.priv);\n\n if (!enc)\n return this.pub;\n\n return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n if (enc === 'hex')\n return this.priv.toString(16, 2);\n else\n return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n this.priv = new BN(key, enc || 16);\n\n // Ensure that the priv won't be bigger than n, otherwise we may fail\n // in fixed multiplication method\n this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n if (key.x || key.y) {\n // Montgomery points only have an `x` coordinate.\n // Weierstrass/Edwards points on the other hand have both `x` and\n // `y` coordinates.\n if (this.ec.curve.type === 'mont') {\n assert(key.x, 'Need x coordinate');\n } else if (this.ec.curve.type === 'short' ||\n this.ec.curve.type === 'edwards') {\n assert(key.x && key.y, 'Need both x and y coordinate');\n }\n this.pub = this.ec.curve.point(key.x, key.y);\n return;\n }\n this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n if(!pub.validate()) {\n assert(pub.validate(), 'public point not validated');\n }\n return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature) {\n return this.ec.verify(msg, signature, this);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n return '';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n if (options instanceof Signature)\n return options;\n\n if (this._importDER(options, enc))\n return;\n\n assert(options.r && options.s, 'Signature without r or s');\n this.r = new BN(options.r, 16);\n this.s = new BN(options.s, 16);\n if (options.recoveryParam === undefined)\n this.recoveryParam = null;\n else\n this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n this.place = 0;\n}\n\nfunction getLength(buf, p) {\n var initial = buf[p.place++];\n if (!(initial & 0x80)) {\n return initial;\n }\n var octetLen = initial & 0xf;\n\n // Indefinite length or overflow\n if (octetLen === 0 || octetLen > 4) {\n return false;\n }\n\n var val = 0;\n for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n val <<= 8;\n val |= buf[off];\n val >>>= 0;\n }\n\n // Leading zeroes\n if (val <= 0x7f) {\n return false;\n }\n\n p.place = off;\n return val;\n}\n\nfunction rmPadding(buf) {\n var i = 0;\n var len = buf.length - 1;\n while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n i++;\n }\n if (i === 0) {\n return buf;\n }\n return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n data = utils.toArray(data, enc);\n var p = new Position();\n if (data[p.place++] !== 0x30) {\n return false;\n }\n var len = getLength(data, p);\n if (len === false) {\n return false;\n }\n if ((len + p.place) !== data.length) {\n return false;\n }\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var rlen = getLength(data, p);\n if (rlen === false) {\n return false;\n }\n var r = data.slice(p.place, rlen + p.place);\n p.place += rlen;\n if (data[p.place++] !== 0x02) {\n return false;\n }\n var slen = getLength(data, p);\n if (slen === false) {\n return false;\n }\n if (data.length !== slen + p.place) {\n return false;\n }\n var s = data.slice(p.place, slen + p.place);\n if (r[0] === 0) {\n if (r[1] & 0x80) {\n r = r.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n if (s[0] === 0) {\n if (s[1] & 0x80) {\n s = s.slice(1);\n } else {\n // Leading zeroes\n return false;\n }\n }\n\n this.r = new BN(r);\n this.s = new BN(s);\n this.recoveryParam = null;\n\n return true;\n};\n\nfunction constructLength(arr, len) {\n if (len < 0x80) {\n arr.push(len);\n return;\n }\n var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n arr.push(octets | 0x80);\n while (--octets) {\n arr.push((len >>> (octets << 3)) & 0xff);\n }\n arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n var r = this.r.toArray();\n var s = this.s.toArray();\n\n // Pad values\n if (r[0] & 0x80)\n r = [ 0 ].concat(r);\n // Pad values\n if (s[0] & 0x80)\n s = [ 0 ].concat(s);\n\n r = rmPadding(r);\n s = rmPadding(s);\n\n while (!s[0] && !(s[1] & 0x80)) {\n s = s.slice(1);\n }\n var arr = [ 0x02 ];\n constructLength(arr, r.length);\n arr = arr.concat(r);\n arr.push(0x02);\n constructLength(arr, s.length);\n var backHalf = arr.concat(s);\n var res = [ 0x30 ];\n constructLength(res, backHalf.length);\n res = res.concat(backHalf);\n return utils.encode(res, enc);\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n if (!(this instanceof EDDSA))\n return new EDDSA(curve);\n\n curve = curves[curve].curve;\n this.curve = curve;\n this.g = curve.g;\n this.g.precompute(curve.n.bitLength() + 1);\n\n this.pointClass = curve.point().constructor;\n this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n message = parseBytes(message);\n var key = this.keyFromSecret(secret);\n var r = this.hashInt(key.messagePrefix(), message);\n var R = this.g.mul(r);\n var Rencoded = this.encodePoint(R);\n var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n .mul(key.priv());\n var S = r.add(s_).umod(this.curve.n);\n return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n message = parseBytes(message);\n sig = this.makeSignature(sig);\n var key = this.keyFromPublic(pub);\n var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n var SG = this.g.mul(sig.S());\n var RplusAh = sig.R().add(key.pub().mul(h));\n return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n var hash = this.hash();\n for (var i = 0; i < arguments.length; i++)\n hash.update(arguments[i]);\n return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n if (sig instanceof Signature)\n return sig;\n return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n var enc = point.getY().toArray('le', this.encodingLength);\n enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n bytes = utils.parseBytes(bytes);\n\n var lastIx = bytes.length - 1;\n var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n var y = utils.intFromLE(normed);\n return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n this.eddsa = eddsa;\n this._secret = parseBytes(params.secret);\n if (eddsa.isPoint(params.pub))\n this._pub = params.pub;\n else\n this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n if (pub instanceof KeyPair)\n return pub;\n return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n if (secret instanceof KeyPair)\n return secret;\n return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n if (this._pubBytes)\n return this.eddsa.decodePoint(this._pubBytes);\n return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n var eddsa = this.eddsa;\n var hash = this.hash();\n var lastIx = eddsa.encodingLength - 1;\n\n var a = hash.slice(0, eddsa.encodingLength);\n a[0] &= 248;\n a[lastIx] &= 127;\n a[lastIx] |= 64;\n\n return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n assert(this._secret, 'KeyPair can only verify');\n return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n assert(this._secret, 'KeyPair is public only');\n return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array|Object} sig -\n* @param {Array|Point} [sig.R] - R point as Point or bytes\n* @param {Array|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array} [sig.Rencoded] - R point encoded\n* @param {Array} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n this.eddsa = eddsa;\n\n if (typeof sig !== 'object')\n sig = parseBytes(sig);\n\n if (Array.isArray(sig)) {\n sig = {\n R: sig.slice(0, eddsa.encodingLength),\n S: sig.slice(eddsa.encodingLength),\n };\n }\n\n assert(sig.R && sig.S, 'Signature without R or S');\n\n if (eddsa.isPoint(sig.R))\n this._R = sig.R;\n if (sig.S instanceof BN)\n this._S = sig.S;\n\n this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","module.exports = (function() {\n /*\n * Generated by PEG.js 0.8.0.\n *\n * http://pegjs.majda.cz/\n */\n\n function peg$subclass(child, parent) {\n function ctor() { this.constructor = child; }\n ctor.prototype = parent.prototype;\n child.prototype = new ctor();\n }\n\n function SyntaxError(message, expected, found, offset, line, column) {\n this.message = message;\n this.expected = expected;\n this.found = found;\n this.offset = offset;\n this.line = line;\n this.column = column;\n\n this.name = \"SyntaxError\";\n }\n\n peg$subclass(SyntaxError, Error);\n\n function parse(input) {\n var options = arguments.length > 1 ? arguments[1] : {},\n\n peg$FAILED = {},\n\n peg$startRuleFunctions = { start: peg$parsestart },\n peg$startRuleFunction = peg$parsestart,\n\n peg$c0 = [],\n peg$c1 = function() { return nodes },\n peg$c2 = peg$FAILED,\n peg$c3 = \"#\",\n peg$c4 = { type: \"literal\", value: \"#\", description: \"\\\"#\\\"\" },\n peg$c5 = void 0,\n peg$c6 = { type: \"any\", description: \"any character\" },\n peg$c7 = \"[\",\n peg$c8 = { type: \"literal\", value: \"[\", description: \"\\\"[\\\"\" },\n peg$c9 = \"]\",\n peg$c10 = { type: \"literal\", value: \"]\", description: \"\\\"]\\\"\" },\n peg$c11 = function(name) { addNode(node('ObjectPath', name, line, column)) },\n peg$c12 = function(name) { addNode(node('ArrayPath', name, line, column)) },\n peg$c13 = function(parts, name) { return parts.concat(name) },\n peg$c14 = function(name) { return [name] },\n peg$c15 = function(name) { return name },\n peg$c16 = \".\",\n peg$c17 = { type: \"literal\", value: \".\", description: \"\\\".\\\"\" },\n peg$c18 = \"=\",\n peg$c19 = { type: \"literal\", value: \"=\", description: \"\\\"=\\\"\" },\n peg$c20 = function(key, value) { addNode(node('Assign', value, line, column, key)) },\n peg$c21 = function(chars) { return chars.join('') },\n peg$c22 = function(node) { return node.value },\n peg$c23 = \"\\\"\\\"\\\"\",\n peg$c24 = { type: \"literal\", value: \"\\\"\\\"\\\"\", description: \"\\\"\\\\\\\"\\\\\\\"\\\\\\\"\\\"\" },\n peg$c25 = null,\n peg$c26 = function(chars) { return node('String', chars.join(''), line, column) },\n peg$c27 = \"\\\"\",\n peg$c28 = { type: \"literal\", value: \"\\\"\", description: \"\\\"\\\\\\\"\\\"\" },\n peg$c29 = \"'''\",\n peg$c30 = { type: \"literal\", value: \"'''\", description: \"\\\"'''\\\"\" },\n peg$c31 = \"'\",\n peg$c32 = { type: \"literal\", value: \"'\", description: \"\\\"'\\\"\" },\n peg$c33 = function(char) { return char },\n peg$c34 = function(char) { return char},\n peg$c35 = \"\\\\\",\n peg$c36 = { type: \"literal\", value: \"\\\\\", description: \"\\\"\\\\\\\\\\\"\" },\n peg$c37 = function() { return '' },\n peg$c38 = \"e\",\n peg$c39 = { type: \"literal\", value: \"e\", description: \"\\\"e\\\"\" },\n peg$c40 = \"E\",\n peg$c41 = { type: \"literal\", value: \"E\", description: \"\\\"E\\\"\" },\n peg$c42 = function(left, right) { return node('Float', parseFloat(left + 'e' + right), line, column) },\n peg$c43 = function(text) { return node('Float', parseFloat(text), line, column) },\n peg$c44 = \"+\",\n peg$c45 = { type: \"literal\", value: \"+\", description: \"\\\"+\\\"\" },\n peg$c46 = function(digits) { return digits.join('') },\n peg$c47 = \"-\",\n peg$c48 = { type: \"literal\", value: \"-\", description: \"\\\"-\\\"\" },\n peg$c49 = function(digits) { return '-' + digits.join('') },\n peg$c50 = function(text) { return node('Integer', parseInt(text, 10), line, column) },\n peg$c51 = \"true\",\n peg$c52 = { type: \"literal\", value: \"true\", description: \"\\\"true\\\"\" },\n peg$c53 = function() { return node('Boolean', true, line, column) },\n peg$c54 = \"false\",\n peg$c55 = { type: \"literal\", value: \"false\", description: \"\\\"false\\\"\" },\n peg$c56 = function() { return node('Boolean', false, line, column) },\n peg$c57 = function() { return node('Array', [], line, column) },\n peg$c58 = function(value) { return node('Array', value ? [value] : [], line, column) },\n peg$c59 = function(values) { return node('Array', values, line, column) },\n peg$c60 = function(values, value) { return node('Array', values.concat(value), line, column) },\n peg$c61 = function(value) { return value },\n peg$c62 = \",\",\n peg$c63 = { type: \"literal\", value: \",\", description: \"\\\",\\\"\" },\n peg$c64 = \"{\",\n peg$c65 = { type: \"literal\", value: \"{\", description: \"\\\"{\\\"\" },\n peg$c66 = \"}\",\n peg$c67 = { type: \"literal\", value: \"}\", description: \"\\\"}\\\"\" },\n peg$c68 = function(values) { return node('InlineTable', values, line, column) },\n peg$c69 = function(key, value) { return node('InlineTableValue', value, line, column, key) },\n peg$c70 = function(digits) { return \".\" + digits },\n peg$c71 = function(date) { return date.join('') },\n peg$c72 = \":\",\n peg$c73 = { type: \"literal\", value: \":\", description: \"\\\":\\\"\" },\n peg$c74 = function(time) { return time.join('') },\n peg$c75 = \"T\",\n peg$c76 = { type: \"literal\", value: \"T\", description: \"\\\"T\\\"\" },\n peg$c77 = \"Z\",\n peg$c78 = { type: \"literal\", value: \"Z\", description: \"\\\"Z\\\"\" },\n peg$c79 = function(date, time) { return node('Date', new Date(date + \"T\" + time + \"Z\"), line, column) },\n peg$c80 = function(date, time) { return node('Date', new Date(date + \"T\" + time), line, column) },\n peg$c81 = /^[ \\t]/,\n peg$c82 = { type: \"class\", value: \"[ \\\\t]\", description: \"[ \\\\t]\" },\n peg$c83 = \"\\n\",\n peg$c84 = { type: \"literal\", value: \"\\n\", description: \"\\\"\\\\n\\\"\" },\n peg$c85 = \"\\r\",\n peg$c86 = { type: \"literal\", value: \"\\r\", description: \"\\\"\\\\r\\\"\" },\n peg$c87 = /^[0-9a-f]/i,\n peg$c88 = { type: \"class\", value: \"[0-9a-f]i\", description: \"[0-9a-f]i\" },\n peg$c89 = /^[0-9]/,\n peg$c90 = { type: \"class\", value: \"[0-9]\", description: \"[0-9]\" },\n peg$c91 = \"_\",\n peg$c92 = { type: \"literal\", value: \"_\", description: \"\\\"_\\\"\" },\n peg$c93 = function() { return \"\" },\n peg$c94 = /^[A-Za-z0-9_\\-]/,\n peg$c95 = { type: \"class\", value: \"[A-Za-z0-9_\\\\-]\", description: \"[A-Za-z0-9_\\\\-]\" },\n peg$c96 = function(d) { return d.join('') },\n peg$c97 = \"\\\\\\\"\",\n peg$c98 = { type: \"literal\", value: \"\\\\\\\"\", description: \"\\\"\\\\\\\\\\\\\\\"\\\"\" },\n peg$c99 = function() { return '\"' },\n peg$c100 = \"\\\\\\\\\",\n peg$c101 = { type: \"literal\", value: \"\\\\\\\\\", description: \"\\\"\\\\\\\\\\\\\\\\\\\"\" },\n peg$c102 = function() { return '\\\\' },\n peg$c103 = \"\\\\b\",\n peg$c104 = { type: \"literal\", value: \"\\\\b\", description: \"\\\"\\\\\\\\b\\\"\" },\n peg$c105 = function() { return '\\b' },\n peg$c106 = \"\\\\t\",\n peg$c107 = { type: \"literal\", value: \"\\\\t\", description: \"\\\"\\\\\\\\t\\\"\" },\n peg$c108 = function() { return '\\t' },\n peg$c109 = \"\\\\n\",\n peg$c110 = { type: \"literal\", value: \"\\\\n\", description: \"\\\"\\\\\\\\n\\\"\" },\n peg$c111 = function() { return '\\n' },\n peg$c112 = \"\\\\f\",\n peg$c113 = { type: \"literal\", value: \"\\\\f\", description: \"\\\"\\\\\\\\f\\\"\" },\n peg$c114 = function() { return '\\f' },\n peg$c115 = \"\\\\r\",\n peg$c116 = { type: \"literal\", value: \"\\\\r\", description: \"\\\"\\\\\\\\r\\\"\" },\n peg$c117 = function() { return '\\r' },\n peg$c118 = \"\\\\U\",\n peg$c119 = { type: \"literal\", value: \"\\\\U\", description: \"\\\"\\\\\\\\U\\\"\" },\n peg$c120 = function(digits) { return convertCodePoint(digits.join('')) },\n peg$c121 = \"\\\\u\",\n peg$c122 = { type: \"literal\", value: \"\\\\u\", description: \"\\\"\\\\\\\\u\\\"\" },\n\n peg$currPos = 0,\n peg$reportedPos = 0,\n peg$cachedPos = 0,\n peg$cachedPosDetails = { line: 1, column: 1, seenCR: false },\n peg$maxFailPos = 0,\n peg$maxFailExpected = [],\n peg$silentFails = 0,\n\n peg$cache = {},\n peg$result;\n\n if (\"startRule\" in options) {\n if (!(options.startRule in peg$startRuleFunctions)) {\n throw new Error(\"Can't start parsing from rule \\\"\" + options.startRule + \"\\\".\");\n }\n\n peg$startRuleFunction = peg$startRuleFunctions[options.startRule];\n }\n\n function text() {\n return input.substring(peg$reportedPos, peg$currPos);\n }\n\n function offset() {\n return peg$reportedPos;\n }\n\n function line() {\n return peg$computePosDetails(peg$reportedPos).line;\n }\n\n function column() {\n return peg$computePosDetails(peg$reportedPos).column;\n }\n\n function expected(description) {\n throw peg$buildException(\n null,\n [{ type: \"other\", description: description }],\n peg$reportedPos\n );\n }\n\n function error(message) {\n throw peg$buildException(message, null, peg$reportedPos);\n }\n\n function peg$computePosDetails(pos) {\n function advance(details, startPos, endPos) {\n var p, ch;\n\n for (p = startPos; p < endPos; p++) {\n ch = input.charAt(p);\n if (ch === \"\\n\") {\n if (!details.seenCR) { details.line++; }\n details.column = 1;\n details.seenCR = false;\n } else if (ch === \"\\r\" || ch === \"\\u2028\" || ch === \"\\u2029\") {\n details.line++;\n details.column = 1;\n details.seenCR = true;\n } else {\n details.column++;\n details.seenCR = false;\n }\n }\n }\n\n if (peg$cachedPos !== pos) {\n if (peg$cachedPos > pos) {\n peg$cachedPos = 0;\n peg$cachedPosDetails = { line: 1, column: 1, seenCR: false };\n }\n advance(peg$cachedPosDetails, peg$cachedPos, pos);\n peg$cachedPos = pos;\n }\n\n return peg$cachedPosDetails;\n }\n\n function peg$fail(expected) {\n if (peg$currPos < peg$maxFailPos) { return; }\n\n if (peg$currPos > peg$maxFailPos) {\n peg$maxFailPos = peg$currPos;\n peg$maxFailExpected = [];\n }\n\n peg$maxFailExpected.push(expected);\n }\n\n function peg$buildException(message, expected, pos) {\n function cleanupExpected(expected) {\n var i = 1;\n\n expected.sort(function(a, b) {\n if (a.description < b.description) {\n return -1;\n } else if (a.description > b.description) {\n return 1;\n } else {\n return 0;\n }\n });\n\n while (i < expected.length) {\n if (expected[i - 1] === expected[i]) {\n expected.splice(i, 1);\n } else {\n i++;\n }\n }\n }\n\n function buildMessage(expected, found) {\n function stringEscape(s) {\n function hex(ch) { return ch.charCodeAt(0).toString(16).toUpperCase(); }\n\n return s\n .replace(/\\\\/g, '\\\\\\\\')\n .replace(/\"/g, '\\\\\"')\n .replace(/\\x08/g, '\\\\b')\n .replace(/\\t/g, '\\\\t')\n .replace(/\\n/g, '\\\\n')\n .replace(/\\f/g, '\\\\f')\n .replace(/\\r/g, '\\\\r')\n .replace(/[\\x00-\\x07\\x0B\\x0E\\x0F]/g, function(ch) { return '\\\\x0' + hex(ch); })\n .replace(/[\\x10-\\x1F\\x80-\\xFF]/g, function(ch) { return '\\\\x' + hex(ch); })\n .replace(/[\\u0180-\\u0FFF]/g, function(ch) { return '\\\\u0' + hex(ch); })\n .replace(/[\\u1080-\\uFFFF]/g, function(ch) { return '\\\\u' + hex(ch); });\n }\n\n var expectedDescs = new Array(expected.length),\n expectedDesc, foundDesc, i;\n\n for (i = 0; i < expected.length; i++) {\n expectedDescs[i] = expected[i].description;\n }\n\n expectedDesc = expected.length > 1\n ? expectedDescs.slice(0, -1).join(\", \")\n + \" or \"\n + expectedDescs[expected.length - 1]\n : expectedDescs[0];\n\n foundDesc = found ? \"\\\"\" + stringEscape(found) + \"\\\"\" : \"end of input\";\n\n return \"Expected \" + expectedDesc + \" but \" + foundDesc + \" found.\";\n }\n\n var posDetails = peg$computePosDetails(pos),\n found = pos < input.length ? input.charAt(pos) : null;\n\n if (expected !== null) {\n cleanupExpected(expected);\n }\n\n return new SyntaxError(\n message !== null ? message : buildMessage(expected, found),\n expected,\n found,\n pos,\n posDetails.line,\n posDetails.column\n );\n }\n\n function peg$parsestart() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 0,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseline();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseline();\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c1();\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseline() {\n var s0, s1, s2, s3, s4, s5, s6;\n\n var key = peg$currPos * 49 + 1,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parseexpression();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsecomment();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsecomment();\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseNL();\n if (s6 !== peg$FAILED) {\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseNL();\n }\n } else {\n s5 = peg$c2;\n }\n if (s5 === peg$FAILED) {\n s5 = peg$parseEOF();\n }\n if (s5 !== peg$FAILED) {\n s1 = [s1, s2, s3, s4, s5];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n if (s2 !== peg$FAILED) {\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n } else {\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseNL();\n if (s3 !== peg$FAILED) {\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseNL();\n }\n } else {\n s2 = peg$c2;\n }\n if (s2 === peg$FAILED) {\n s2 = peg$parseEOF();\n }\n if (s2 !== peg$FAILED) {\n s1 = [s1, s2];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$parseNL();\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseexpression() {\n var s0;\n\n var key = peg$currPos * 49 + 2,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parsecomment();\n if (s0 === peg$FAILED) {\n s0 = peg$parsepath();\n if (s0 === peg$FAILED) {\n s0 = peg$parsetablearray();\n if (s0 === peg$FAILED) {\n s0 = peg$parseassignment();\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsecomment() {\n var s0, s1, s2, s3, s4, s5;\n\n var key = peg$currPos * 49 + 3,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 35) {\n s1 = peg$c3;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c4); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$currPos;\n s4 = peg$currPos;\n peg$silentFails++;\n s5 = peg$parseNL();\n if (s5 === peg$FAILED) {\n s5 = peg$parseEOF();\n }\n peg$silentFails--;\n if (s5 === peg$FAILED) {\n s4 = peg$c5;\n } else {\n peg$currPos = s4;\n s4 = peg$c2;\n }\n if (s4 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s5 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s5 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s5 !== peg$FAILED) {\n s4 = [s4, s5];\n s3 = s4;\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$currPos;\n s4 = peg$currPos;\n peg$silentFails++;\n s5 = peg$parseNL();\n if (s5 === peg$FAILED) {\n s5 = peg$parseEOF();\n }\n peg$silentFails--;\n if (s5 === peg$FAILED) {\n s4 = peg$c5;\n } else {\n peg$currPos = s4;\n s4 = peg$c2;\n }\n if (s4 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s5 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s5 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s5 !== peg$FAILED) {\n s4 = [s4, s5];\n s3 = s4;\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n }\n if (s2 !== peg$FAILED) {\n s1 = [s1, s2];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsepath() {\n var s0, s1, s2, s3, s4, s5;\n\n var key = peg$currPos * 49 + 4,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseS();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseS();\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsetable_key();\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parseS();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parseS();\n }\n if (s4 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s5 = peg$c9;\n peg$currPos++;\n } else {\n s5 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c11(s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsetablearray() {\n var s0, s1, s2, s3, s4, s5, s6, s7;\n\n var key = peg$currPos * 49 + 5,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 91) {\n s2 = peg$c7;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n s4 = peg$parsetable_key();\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseS();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseS();\n }\n if (s5 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s6 = peg$c9;\n peg$currPos++;\n } else {\n s6 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s6 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s7 = peg$c9;\n peg$currPos++;\n } else {\n s7 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s7 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c12(s4);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsetable_key() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 6,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parsedot_ended_table_key_part();\n if (s2 !== peg$FAILED) {\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parsedot_ended_table_key_part();\n }\n } else {\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsetable_key_part();\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c13(s1, s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsetable_key_part();\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c14(s1);\n }\n s0 = s1;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsetable_key_part() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 7,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsekey();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c15(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsequoted_key();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c15(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsedot_ended_table_key_part() {\n var s0, s1, s2, s3, s4, s5, s6;\n\n var key = peg$currPos * 49 + 8,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsekey();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseS();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseS();\n }\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c15(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsequoted_key();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseS();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseS();\n }\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c15(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseassignment() {\n var s0, s1, s2, s3, s4, s5;\n\n var key = peg$currPos * 49 + 9,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$parsekey();\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseS();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseS();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 61) {\n s3 = peg$c18;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c19); }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parseS();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parseS();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsevalue();\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c20(s1, s5);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsequoted_key();\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseS();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseS();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 61) {\n s3 = peg$c18;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c19); }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parseS();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parseS();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsevalue();\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c20(s1, s5);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsekey() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 10,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseASCII_BASIC();\n if (s2 !== peg$FAILED) {\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseASCII_BASIC();\n }\n } else {\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c21(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsequoted_key() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 11,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$parsedouble_quoted_single_line_string();\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c22(s1);\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsesingle_quoted_single_line_string();\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c22(s1);\n }\n s0 = s1;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsevalue() {\n var s0;\n\n var key = peg$currPos * 49 + 12,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parsestring();\n if (s0 === peg$FAILED) {\n s0 = peg$parsedatetime();\n if (s0 === peg$FAILED) {\n s0 = peg$parsefloat();\n if (s0 === peg$FAILED) {\n s0 = peg$parseinteger();\n if (s0 === peg$FAILED) {\n s0 = peg$parseboolean();\n if (s0 === peg$FAILED) {\n s0 = peg$parsearray();\n if (s0 === peg$FAILED) {\n s0 = peg$parseinline_table();\n }\n }\n }\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsestring() {\n var s0;\n\n var key = peg$currPos * 49 + 13,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parsedouble_quoted_multiline_string();\n if (s0 === peg$FAILED) {\n s0 = peg$parsedouble_quoted_single_line_string();\n if (s0 === peg$FAILED) {\n s0 = peg$parsesingle_quoted_multiline_string();\n if (s0 === peg$FAILED) {\n s0 = peg$parsesingle_quoted_single_line_string();\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsedouble_quoted_multiline_string() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 14,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 3) === peg$c23) {\n s1 = peg$c23;\n peg$currPos += 3;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c24); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parseNL();\n if (s2 === peg$FAILED) {\n s2 = peg$c25;\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsemultiline_string_char();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsemultiline_string_char();\n }\n if (s3 !== peg$FAILED) {\n if (input.substr(peg$currPos, 3) === peg$c23) {\n s4 = peg$c23;\n peg$currPos += 3;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c24); }\n }\n if (s4 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c26(s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsedouble_quoted_single_line_string() {\n var s0, s1, s2, s3;\n\n var key = peg$currPos * 49 + 15,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 34) {\n s1 = peg$c27;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c28); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsestring_char();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsestring_char();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 34) {\n s3 = peg$c27;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c28); }\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c26(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsesingle_quoted_multiline_string() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 16,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 3) === peg$c29) {\n s1 = peg$c29;\n peg$currPos += 3;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c30); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parseNL();\n if (s2 === peg$FAILED) {\n s2 = peg$c25;\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsemultiline_literal_char();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsemultiline_literal_char();\n }\n if (s3 !== peg$FAILED) {\n if (input.substr(peg$currPos, 3) === peg$c29) {\n s4 = peg$c29;\n peg$currPos += 3;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c30); }\n }\n if (s4 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c26(s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsesingle_quoted_single_line_string() {\n var s0, s1, s2, s3;\n\n var key = peg$currPos * 49 + 17,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 39) {\n s1 = peg$c31;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c32); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseliteral_char();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseliteral_char();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 39) {\n s3 = peg$c31;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c32); }\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c26(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsestring_char() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 18,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parseESCAPED();\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$currPos;\n peg$silentFails++;\n if (input.charCodeAt(peg$currPos) === 34) {\n s2 = peg$c27;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c28); }\n }\n peg$silentFails--;\n if (s2 === peg$FAILED) {\n s1 = peg$c5;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s2 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c33(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseliteral_char() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 19,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$currPos;\n peg$silentFails++;\n if (input.charCodeAt(peg$currPos) === 39) {\n s2 = peg$c31;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c32); }\n }\n peg$silentFails--;\n if (s2 === peg$FAILED) {\n s1 = peg$c5;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s2 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c33(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsemultiline_string_char() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 20,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parseESCAPED();\n if (s0 === peg$FAILED) {\n s0 = peg$parsemultiline_string_delim();\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$currPos;\n peg$silentFails++;\n if (input.substr(peg$currPos, 3) === peg$c23) {\n s2 = peg$c23;\n peg$currPos += 3;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c24); }\n }\n peg$silentFails--;\n if (s2 === peg$FAILED) {\n s1 = peg$c5;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s2 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c34(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsemultiline_string_delim() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 21,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 92) {\n s1 = peg$c35;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c36); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parseNL();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseNLS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseNLS();\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c37();\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsemultiline_literal_char() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 22,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$currPos;\n peg$silentFails++;\n if (input.substr(peg$currPos, 3) === peg$c29) {\n s2 = peg$c29;\n peg$currPos += 3;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c30); }\n }\n peg$silentFails--;\n if (s2 === peg$FAILED) {\n s1 = peg$c5;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n if (input.length > peg$currPos) {\n s2 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c33(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsefloat() {\n var s0, s1, s2, s3;\n\n var key = peg$currPos * 49 + 23,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$parsefloat_text();\n if (s1 === peg$FAILED) {\n s1 = peg$parseinteger_text();\n }\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 101) {\n s2 = peg$c38;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c39); }\n }\n if (s2 === peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 69) {\n s2 = peg$c40;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c41); }\n }\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parseinteger_text();\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c42(s1, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsefloat_text();\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c43(s1);\n }\n s0 = s1;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsefloat_text() {\n var s0, s1, s2, s3, s4, s5;\n\n var key = peg$currPos * 49 + 24,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 43) {\n s1 = peg$c44;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c45); }\n }\n if (s1 === peg$FAILED) {\n s1 = peg$c25;\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$currPos;\n s3 = peg$parseDIGITS();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parseDIGITS();\n if (s5 !== peg$FAILED) {\n s3 = [s3, s4, s5];\n s2 = s3;\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c46(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 45) {\n s1 = peg$c47;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c48); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$currPos;\n s3 = peg$parseDIGITS();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parseDIGITS();\n if (s5 !== peg$FAILED) {\n s3 = [s3, s4, s5];\n s2 = s3;\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c49(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseinteger() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 25,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$parseinteger_text();\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c50(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseinteger_text() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 26,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 43) {\n s1 = peg$c44;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c45); }\n }\n if (s1 === peg$FAILED) {\n s1 = peg$c25;\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseDIGIT_OR_UNDER();\n if (s3 !== peg$FAILED) {\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseDIGIT_OR_UNDER();\n }\n } else {\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$currPos;\n peg$silentFails++;\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n peg$silentFails--;\n if (s4 === peg$FAILED) {\n s3 = peg$c5;\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c46(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 45) {\n s1 = peg$c47;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c48); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseDIGIT_OR_UNDER();\n if (s3 !== peg$FAILED) {\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseDIGIT_OR_UNDER();\n }\n } else {\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$currPos;\n peg$silentFails++;\n if (input.charCodeAt(peg$currPos) === 46) {\n s4 = peg$c16;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n peg$silentFails--;\n if (s4 === peg$FAILED) {\n s3 = peg$c5;\n } else {\n peg$currPos = s3;\n s3 = peg$c2;\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c49(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseboolean() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 27,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 4) === peg$c51) {\n s1 = peg$c51;\n peg$currPos += 4;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c52); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c53();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 5) === peg$c54) {\n s1 = peg$c54;\n peg$currPos += 5;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c55); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c56();\n }\n s0 = s1;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsearray() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 28,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsearray_sep();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsearray_sep();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s3 = peg$c9;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c57();\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsearray_value();\n if (s2 === peg$FAILED) {\n s2 = peg$c25;\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s3 = peg$c9;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c58(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsearray_value_list();\n if (s3 !== peg$FAILED) {\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsearray_value_list();\n }\n } else {\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s3 = peg$c9;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c59(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 91) {\n s1 = peg$c7;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c8); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsearray_value_list();\n if (s3 !== peg$FAILED) {\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsearray_value_list();\n }\n } else {\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsearray_value();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 93) {\n s4 = peg$c9;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c10); }\n }\n if (s4 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c60(s2, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsearray_value() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 29,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parsearray_sep();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parsearray_sep();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsevalue();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsearray_sep();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsearray_sep();\n }\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c61(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsearray_value_list() {\n var s0, s1, s2, s3, s4, s5, s6;\n\n var key = peg$currPos * 49 + 30,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parsearray_sep();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parsearray_sep();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsevalue();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsearray_sep();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsearray_sep();\n }\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 44) {\n s4 = peg$c62;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c63); }\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parsearray_sep();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parsearray_sep();\n }\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c61(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsearray_sep() {\n var s0;\n\n var key = peg$currPos * 49 + 31,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parseS();\n if (s0 === peg$FAILED) {\n s0 = peg$parseNL();\n if (s0 === peg$FAILED) {\n s0 = peg$parsecomment();\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseinline_table() {\n var s0, s1, s2, s3, s4, s5;\n\n var key = peg$currPos * 49 + 32,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 123) {\n s1 = peg$c64;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c65); }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parseS();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parseS();\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseinline_table_assignment();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseinline_table_assignment();\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parseS();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parseS();\n }\n if (s4 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 125) {\n s5 = peg$c66;\n peg$currPos++;\n } else {\n s5 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c67); }\n }\n if (s5 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c68(s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseinline_table_assignment() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;\n\n var key = peg$currPos * 49 + 33,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsekey();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 61) {\n s4 = peg$c18;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c19); }\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseS();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseS();\n }\n if (s5 !== peg$FAILED) {\n s6 = peg$parsevalue();\n if (s6 !== peg$FAILED) {\n s7 = [];\n s8 = peg$parseS();\n while (s8 !== peg$FAILED) {\n s7.push(s8);\n s8 = peg$parseS();\n }\n if (s7 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 44) {\n s8 = peg$c62;\n peg$currPos++;\n } else {\n s8 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c63); }\n }\n if (s8 !== peg$FAILED) {\n s9 = [];\n s10 = peg$parseS();\n while (s10 !== peg$FAILED) {\n s9.push(s10);\n s10 = peg$parseS();\n }\n if (s9 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c69(s2, s6);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseS();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseS();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsekey();\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parseS();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parseS();\n }\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 61) {\n s4 = peg$c18;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c19); }\n }\n if (s4 !== peg$FAILED) {\n s5 = [];\n s6 = peg$parseS();\n while (s6 !== peg$FAILED) {\n s5.push(s6);\n s6 = peg$parseS();\n }\n if (s5 !== peg$FAILED) {\n s6 = peg$parsevalue();\n if (s6 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c69(s2, s6);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsesecfragment() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 34,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 46) {\n s1 = peg$c16;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c17); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parseDIGITS();\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c70(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsedate() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11;\n\n var key = peg$currPos * 49 + 35,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parseDIGIT_OR_UNDER();\n if (s2 !== peg$FAILED) {\n s3 = peg$parseDIGIT_OR_UNDER();\n if (s3 !== peg$FAILED) {\n s4 = peg$parseDIGIT_OR_UNDER();\n if (s4 !== peg$FAILED) {\n s5 = peg$parseDIGIT_OR_UNDER();\n if (s5 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 45) {\n s6 = peg$c47;\n peg$currPos++;\n } else {\n s6 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c48); }\n }\n if (s6 !== peg$FAILED) {\n s7 = peg$parseDIGIT_OR_UNDER();\n if (s7 !== peg$FAILED) {\n s8 = peg$parseDIGIT_OR_UNDER();\n if (s8 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 45) {\n s9 = peg$c47;\n peg$currPos++;\n } else {\n s9 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c48); }\n }\n if (s9 !== peg$FAILED) {\n s10 = peg$parseDIGIT_OR_UNDER();\n if (s10 !== peg$FAILED) {\n s11 = peg$parseDIGIT_OR_UNDER();\n if (s11 !== peg$FAILED) {\n s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10, s11];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c71(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsetime() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;\n\n var key = peg$currPos * 49 + 36,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parseDIGIT_OR_UNDER();\n if (s2 !== peg$FAILED) {\n s3 = peg$parseDIGIT_OR_UNDER();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 58) {\n s4 = peg$c72;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c73); }\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parseDIGIT_OR_UNDER();\n if (s5 !== peg$FAILED) {\n s6 = peg$parseDIGIT_OR_UNDER();\n if (s6 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 58) {\n s7 = peg$c72;\n peg$currPos++;\n } else {\n s7 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c73); }\n }\n if (s7 !== peg$FAILED) {\n s8 = peg$parseDIGIT_OR_UNDER();\n if (s8 !== peg$FAILED) {\n s9 = peg$parseDIGIT_OR_UNDER();\n if (s9 !== peg$FAILED) {\n s10 = peg$parsesecfragment();\n if (s10 === peg$FAILED) {\n s10 = peg$c25;\n }\n if (s10 !== peg$FAILED) {\n s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c74(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsetime_with_offset() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16;\n\n var key = peg$currPos * 49 + 37,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parseDIGIT_OR_UNDER();\n if (s2 !== peg$FAILED) {\n s3 = peg$parseDIGIT_OR_UNDER();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 58) {\n s4 = peg$c72;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c73); }\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parseDIGIT_OR_UNDER();\n if (s5 !== peg$FAILED) {\n s6 = peg$parseDIGIT_OR_UNDER();\n if (s6 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 58) {\n s7 = peg$c72;\n peg$currPos++;\n } else {\n s7 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c73); }\n }\n if (s7 !== peg$FAILED) {\n s8 = peg$parseDIGIT_OR_UNDER();\n if (s8 !== peg$FAILED) {\n s9 = peg$parseDIGIT_OR_UNDER();\n if (s9 !== peg$FAILED) {\n s10 = peg$parsesecfragment();\n if (s10 === peg$FAILED) {\n s10 = peg$c25;\n }\n if (s10 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 45) {\n s11 = peg$c47;\n peg$currPos++;\n } else {\n s11 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c48); }\n }\n if (s11 === peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 43) {\n s11 = peg$c44;\n peg$currPos++;\n } else {\n s11 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c45); }\n }\n }\n if (s11 !== peg$FAILED) {\n s12 = peg$parseDIGIT_OR_UNDER();\n if (s12 !== peg$FAILED) {\n s13 = peg$parseDIGIT_OR_UNDER();\n if (s13 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 58) {\n s14 = peg$c72;\n peg$currPos++;\n } else {\n s14 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c73); }\n }\n if (s14 !== peg$FAILED) {\n s15 = peg$parseDIGIT_OR_UNDER();\n if (s15 !== peg$FAILED) {\n s16 = peg$parseDIGIT_OR_UNDER();\n if (s16 !== peg$FAILED) {\n s2 = [s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c74(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parsedatetime() {\n var s0, s1, s2, s3, s4;\n\n var key = peg$currPos * 49 + 38,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = peg$parsedate();\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 84) {\n s2 = peg$c75;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c76); }\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsetime();\n if (s3 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 90) {\n s4 = peg$c77;\n peg$currPos++;\n } else {\n s4 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c78); }\n }\n if (s4 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c79(s1, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsedate();\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 84) {\n s2 = peg$c75;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c76); }\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsetime_with_offset();\n if (s3 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c80(s1, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseS() {\n var s0;\n\n var key = peg$currPos * 49 + 39,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n if (peg$c81.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c82); }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseNL() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 40,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n if (input.charCodeAt(peg$currPos) === 10) {\n s0 = peg$c83;\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c84); }\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 13) {\n s1 = peg$c85;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c86); }\n }\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 10) {\n s2 = peg$c83;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c84); }\n }\n if (s2 !== peg$FAILED) {\n s1 = [s1, s2];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseNLS() {\n var s0;\n\n var key = peg$currPos * 49 + 41,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$parseNL();\n if (s0 === peg$FAILED) {\n s0 = peg$parseS();\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseEOF() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 42,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n peg$silentFails++;\n if (input.length > peg$currPos) {\n s1 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c6); }\n }\n peg$silentFails--;\n if (s1 === peg$FAILED) {\n s0 = peg$c5;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseHEX() {\n var s0;\n\n var key = peg$currPos * 49 + 43,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n if (peg$c87.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c88); }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseDIGIT_OR_UNDER() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 44,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n if (peg$c89.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c90); }\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.charCodeAt(peg$currPos) === 95) {\n s1 = peg$c91;\n peg$currPos++;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c92); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c93();\n }\n s0 = s1;\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseASCII_BASIC() {\n var s0;\n\n var key = peg$currPos * 49 + 45,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n if (peg$c94.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c95); }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseDIGITS() {\n var s0, s1, s2;\n\n var key = peg$currPos * 49 + 46,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parseDIGIT_OR_UNDER();\n if (s2 !== peg$FAILED) {\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parseDIGIT_OR_UNDER();\n }\n } else {\n s1 = peg$c2;\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c96(s1);\n }\n s0 = s1;\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseESCAPED() {\n var s0, s1;\n\n var key = peg$currPos * 49 + 47,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c97) {\n s1 = peg$c97;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c98); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c99();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c100) {\n s1 = peg$c100;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c101); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c102();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c103) {\n s1 = peg$c103;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c104); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c105();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c106) {\n s1 = peg$c106;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c107); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c108();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c109) {\n s1 = peg$c109;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c110); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c111();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c112) {\n s1 = peg$c112;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c113); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c114();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c115) {\n s1 = peg$c115;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c116); }\n }\n if (s1 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c117();\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$parseESCAPED_UNICODE();\n }\n }\n }\n }\n }\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n function peg$parseESCAPED_UNICODE() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10;\n\n var key = peg$currPos * 49 + 48,\n cached = peg$cache[key];\n\n if (cached) {\n peg$currPos = cached.nextPos;\n return cached.result;\n }\n\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c118) {\n s1 = peg$c118;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c119); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$currPos;\n s3 = peg$parseHEX();\n if (s3 !== peg$FAILED) {\n s4 = peg$parseHEX();\n if (s4 !== peg$FAILED) {\n s5 = peg$parseHEX();\n if (s5 !== peg$FAILED) {\n s6 = peg$parseHEX();\n if (s6 !== peg$FAILED) {\n s7 = peg$parseHEX();\n if (s7 !== peg$FAILED) {\n s8 = peg$parseHEX();\n if (s8 !== peg$FAILED) {\n s9 = peg$parseHEX();\n if (s9 !== peg$FAILED) {\n s10 = peg$parseHEX();\n if (s10 !== peg$FAILED) {\n s3 = [s3, s4, s5, s6, s7, s8, s9, s10];\n s2 = s3;\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c120(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 2) === peg$c121) {\n s1 = peg$c121;\n peg$currPos += 2;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) { peg$fail(peg$c122); }\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$currPos;\n s3 = peg$parseHEX();\n if (s3 !== peg$FAILED) {\n s4 = peg$parseHEX();\n if (s4 !== peg$FAILED) {\n s5 = peg$parseHEX();\n if (s5 !== peg$FAILED) {\n s6 = peg$parseHEX();\n if (s6 !== peg$FAILED) {\n s3 = [s3, s4, s5, s6];\n s2 = s3;\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n } else {\n peg$currPos = s2;\n s2 = peg$c2;\n }\n if (s2 !== peg$FAILED) {\n peg$reportedPos = s0;\n s1 = peg$c120(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$c2;\n }\n }\n\n peg$cache[key] = { nextPos: peg$currPos, result: s0 };\n\n return s0;\n }\n\n\n var nodes = [];\n\n function genError(err, line, col) {\n var ex = new Error(err);\n ex.line = line;\n ex.column = col;\n throw ex;\n }\n\n function addNode(node) {\n nodes.push(node);\n }\n\n function node(type, value, line, column, key) {\n var obj = { type: type, value: value, line: line(), column: column() };\n if (key) obj.key = key;\n return obj;\n }\n\n function convertCodePoint(str, line, col) {\n var num = parseInt(\"0x\" + str);\n\n if (\n !isFinite(num) ||\n Math.floor(num) != num ||\n num < 0 ||\n num > 0x10FFFF ||\n (num > 0xD7FF && num < 0xE000)\n ) {\n genError(\"Invalid Unicode escape code: \" + str, line, col);\n } else {\n return fromCodePoint(num);\n }\n }\n\n function fromCodePoint() {\n var MAX_SIZE = 0x4000;\n var codeUnits = [];\n var highSurrogate;\n var lowSurrogate;\n var index = -1;\n var length = arguments.length;\n if (!length) {\n return '';\n }\n var result = '';\n while (++index < length) {\n var codePoint = Number(arguments[index]);\n if (codePoint <= 0xFFFF) { // BMP code point\n codeUnits.push(codePoint);\n } else { // Astral code point; split in surrogate halves\n // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n codePoint -= 0x10000;\n highSurrogate = (codePoint >> 10) + 0xD800;\n lowSurrogate = (codePoint % 0x400) + 0xDC00;\n codeUnits.push(highSurrogate, lowSurrogate);\n }\n if (index + 1 == length || codeUnits.length > MAX_SIZE) {\n result += String.fromCharCode.apply(null, codeUnits);\n codeUnits.length = 0;\n }\n }\n return result;\n }\n\n\n peg$result = peg$startRuleFunction();\n\n if (peg$result !== peg$FAILED && peg$currPos === input.length) {\n return peg$result;\n } else {\n if (peg$result !== peg$FAILED && peg$currPos < input.length) {\n peg$fail({ type: \"end\", description: \"end of input\" });\n }\n\n throw peg$buildException(null, peg$maxFailExpected, peg$maxFailPos);\n }\n }\n\n return {\n SyntaxError: SyntaxError,\n parse: parse\n };\n})();\n","\"use strict\";\nfunction compile(nodes) {\n var assignedPaths = [];\n var valueAssignments = [];\n var currentPath = \"\";\n var data = Object.create(null);\n var context = data;\n var arrayMode = false;\n\n return reduce(nodes);\n\n function reduce(nodes) {\n var node;\n for (var i = 0; i < nodes.length; i++) {\n node = nodes[i];\n switch (node.type) {\n case \"Assign\":\n assign(node);\n break;\n case \"ObjectPath\":\n setPath(node);\n break;\n case \"ArrayPath\":\n addTableArray(node);\n break;\n }\n }\n\n return data;\n }\n\n function genError(err, line, col) {\n var ex = new Error(err);\n ex.line = line;\n ex.column = col;\n throw ex;\n }\n\n function assign(node) {\n var key = node.key;\n var value = node.value;\n var line = node.line;\n var column = node.column;\n\n var fullPath;\n if (currentPath) {\n fullPath = currentPath + \".\" + key;\n } else {\n fullPath = key;\n }\n if (typeof context[key] !== \"undefined\") {\n genError(\"Cannot redefine existing key '\" + fullPath + \"'.\", line, column);\n }\n\n context[key] = reduceValueNode(value);\n\n if (!pathAssigned(fullPath)) {\n assignedPaths.push(fullPath);\n valueAssignments.push(fullPath);\n }\n }\n\n\n function pathAssigned(path) {\n return assignedPaths.indexOf(path) !== -1;\n }\n\n function reduceValueNode(node) {\n if (node.type === \"Array\") {\n return reduceArrayWithTypeChecking(node.value);\n } else if (node.type === \"InlineTable\") {\n return reduceInlineTableNode(node.value);\n } else {\n return node.value;\n }\n }\n\n function reduceInlineTableNode(values) {\n var obj = Object.create(null);\n for (var i = 0; i < values.length; i++) {\n var val = values[i];\n if (val.value.type === \"InlineTable\") {\n obj[val.key] = reduceInlineTableNode(val.value.value);\n } else if (val.type === \"InlineTableValue\") {\n obj[val.key] = reduceValueNode(val.value);\n }\n }\n\n return obj;\n }\n\n function setPath(node) {\n var path = node.value;\n var quotedPath = path.map(quoteDottedString).join(\".\");\n var line = node.line;\n var column = node.column;\n\n if (pathAssigned(quotedPath)) {\n genError(\"Cannot redefine existing key '\" + path + \"'.\", line, column);\n }\n assignedPaths.push(quotedPath);\n context = deepRef(data, path, Object.create(null), line, column);\n currentPath = path;\n }\n\n function addTableArray(node) {\n var path = node.value;\n var quotedPath = path.map(quoteDottedString).join(\".\");\n var line = node.line;\n var column = node.column;\n\n if (!pathAssigned(quotedPath)) {\n assignedPaths.push(quotedPath);\n }\n assignedPaths = assignedPaths.filter(function(p) {\n return p.indexOf(quotedPath) !== 0;\n });\n assignedPaths.push(quotedPath);\n context = deepRef(data, path, [], line, column);\n currentPath = quotedPath;\n\n if (context instanceof Array) {\n var newObj = Object.create(null);\n context.push(newObj);\n context = newObj;\n } else {\n genError(\"Cannot redefine existing key '\" + path + \"'.\", line, column);\n }\n }\n\n // Given a path 'a.b.c', create (as necessary) `start.a`,\n // `start.a.b`, and `start.a.b.c`, assigning `value` to `start.a.b.c`.\n // If `a` or `b` are arrays and have items in them, the last item in the\n // array is used as the context for the next sub-path.\n function deepRef(start, keys, value, line, column) {\n var traversed = [];\n var traversedPath = \"\";\n var path = keys.join(\".\");\n var ctx = start;\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n traversed.push(key);\n traversedPath = traversed.join(\".\");\n if (typeof ctx[key] === \"undefined\") {\n if (i === keys.length - 1) {\n ctx[key] = value;\n } else {\n ctx[key] = Object.create(null);\n }\n } else if (i !== keys.length - 1 && valueAssignments.indexOf(traversedPath) > -1) {\n // already a non-object value at key, can't be used as part of a new path\n genError(\"Cannot redefine existing key '\" + traversedPath + \"'.\", line, column);\n }\n\n ctx = ctx[key];\n if (ctx instanceof Array && ctx.length && i < keys.length - 1) {\n ctx = ctx[ctx.length - 1];\n }\n }\n\n return ctx;\n }\n\n function reduceArrayWithTypeChecking(array) {\n // Ensure that all items in the array are of the same type\n var firstType = null;\n for (var i = 0; i < array.length; i++) {\n var node = array[i];\n if (firstType === null) {\n firstType = node.type;\n } else {\n if (node.type !== firstType) {\n genError(\"Cannot add value of type \" + node.type + \" to array of type \" +\n firstType + \".\", node.line, node.column);\n }\n }\n }\n\n // Recursively reduce array of nodes into array of the nodes' values\n return array.map(reduceValueNode);\n }\n\n function quoteDottedString(str) {\n if (str.indexOf(\".\") > -1) {\n return \"\\\"\" + str + \"\\\"\";\n } else {\n return str;\n }\n }\n}\n\nmodule.exports = {\n compile: compile\n};\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n };\n} else {\n // old school shim for old browsers\n module.exports = 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","// .dirname, .basename, and .extname methods are extracted from Node.js v8.11.1,\n// backported and transplited with Babel, with backwards-compat fixes\n\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path = (i >= 0) ? arguments[i] : process.cwd();\n\n // Skip empty and invalid entries\n if (typeof path !== 'string') {\n throw new TypeError('Arguments to path.resolve must be strings');\n } else if (!path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n var isAbsolute = exports.isAbsolute(path),\n trailingSlash = substr(path, -1) === '/';\n\n // Normalize the path\n path = normalizeArray(filter(path.split('/'), function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n if (path && trailingSlash) {\n path += '/';\n }\n\n return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return exports.normalize(filter(paths, function(p, index) {\n if (typeof p !== 'string') {\n throw new TypeError('Arguments to path.join must be strings');\n }\n return p;\n }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n from = exports.resolve(from).substr(1);\n to = exports.resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (var i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function (path) {\n if (typeof path !== 'string') path = path + '';\n if (path.length === 0) return '.';\n var code = path.charCodeAt(0);\n var hasRoot = code === 47 /*/*/;\n var end = -1;\n var matchedSlash = true;\n for (var i = path.length - 1; i >= 1; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n } else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n\n if (end === -1) return hasRoot ? '/' : '.';\n if (hasRoot && end === 1) {\n // return '//';\n // Backwards-compat fix:\n return '/';\n }\n return path.slice(0, end);\n};\n\nfunction basename(path) {\n if (typeof path !== 'string') path = path + '';\n\n var start = 0;\n var end = -1;\n var matchedSlash = true;\n var i;\n\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n\n if (end === -1) return '';\n return path.slice(start, end);\n}\n\n// Uses a mixed approach for backwards-compatibility, as ext behavior changed\n// in new Node.js versions, so only basename() above is backported here\nexports.basename = function (path, ext) {\n var f = basename(path);\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n return f;\n};\n\nexports.extname = function (path) {\n if (typeof path !== 'string') path = path + '';\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n for (var i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1)\n startDot = i;\n else if (preDotState !== 1)\n preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n return '';\n }\n return path.slice(startDot, end);\n};\n\nfunction filter (xs, f) {\n if (xs.filter) return xs.filter(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n if (f(xs[i], i, xs)) res.push(xs[i]);\n }\n return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n ? function (str, start, len) { return str.substr(start, len) }\n : function (str, start, len) {\n if (start < 0) start = str.length + start;\n return str.substr(start, len);\n }\n;\n","/** @license React v17.0.2\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';require(\"object-assign\");var f=require(\"react\"),g=60103;exports.Fragment=60107;if(\"function\"===typeof Symbol&&Symbol.for){var h=Symbol.for;g=h(\"react.element\");exports.Fragment=h(\"react.fragment\")}var m=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,n=Object.prototype.hasOwnProperty,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,k){var b,d={},e=null,l=null;void 0!==k&&(e=\"\"+k);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(l=a.ref);for(b in a)n.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:g,type:c,key:e,ref:l,props:d,_owner:m.current}}exports.jsx=q;exports.jsxs=q;\n"],"sourceRoot":""}