{"version":3,"sources":["../node_modules/des.js/lib/des/cipher.js","../node_modules/des.js/lib/des/utils.js","../node_modules/des.js/lib/des/des.js","../node_modules/diffie-hellman/lib/generatePrime.js","../node_modules/diffie-hellman/node_modules/bn.js/lib/bn.js","../node_modules/dom-helpers/esm/removeClass.js","../node_modules/dom-helpers/esm/addClass.js","../node_modules/dom-helpers/esm/hasClass.js","../node_modules/des.js/lib/des.js","../node_modules/des.js/lib/des/cbc.js","../node_modules/des.js/lib/des/ede.js","../node_modules/diffie-hellman/browser.js","../node_modules/diffie-hellman/lib/dh.js","../node_modules/ecdsa-sig-formatter/src/ecdsa-sig-formatter.js","../node_modules/ecdsa-sig-formatter/src/param-bytes-for-alg.js"],"names":["assert","require","Cipher","options","this","type","blockSize","_init","buffer","Array","bufferOff","module","exports","prototype","update","data","length","_updateDecrypt","_updateEncrypt","_buffer","off","min","Math","i","_flushBuffer","out","_update","inputOff","outputOff","count","max","ceil","final","first","last","_finalEncrypt","_finalDecrypt","concat","_pad","_unpad","equal","readUInt32BE","bytes","writeUInt32BE","value","ip","inL","inR","outL","outR","j","rip","pc1","r28shl","num","shift","pc2table","pc2","len","expand","r","sTable","substitute","permuteTable","permute","padSplit","size","group","str","toString","push","slice","join","inherits","utils","DESState","tmp","keys","DES","call","state","_desState","deriveKeys","key","create","shiftTable","kL","kR","inp","inOff","outOff","l","_encrypt","_decrypt","pad","lStart","rStart","keyL","keyR","s","t","randomBytes","findPrime","simpleSieve","fermatTest","BN","TWENTYFOUR","millerRabin","ONE","TWO","FIVE","TEN","THREE","ELEVEN","FOUR","primes","_getPrimes","res","k","sqrt","p","modn","cmpn","red","mont","toRed","redPow","subn","fromRed","bits","gen","n2","bitLength","ishrn","isEven","iadd","testn","cmp","mod","shrn","test","val","msg","Error","ctor","superCtor","super_","TempCtor","constructor","number","base","endian","isBN","negative","words","Buffer","wordSize","window","e","parseHex4Bits","string","index","c","charCodeAt","parseHexByte","lowerBound","parseBase","start","end","mul","isArray","left","right","_initNumber","_initArray","replace","_parseHex","_parseBase","toArray","w","strip","limbLen","limbPow","total","word","imuln","_iaddn","pow","copy","dest","clone","_expand","_normSign","inspect","zeros","groupSizes","groupBases","smallMulTo","self","a","b","lo","carry","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","q","andln","iushrn","clz32","_countBits","_zeroBits","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","isub","add","sub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","w0","imul","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","jumboMulTo","FFTM","mulp","x","y","mulTo","hncarry","bigMulTo","makeRBT","N","revBin","rb","rbt","rws","iws","rtws","itws","transform","rtwdf","cos","PI","itwdf","sin","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","n","m","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","toBitArray","iushln","carryMask","newCarry","ishln","hint","extended","h","mask","maskedWords","shln","ushln","ushrn","imaskn","maskn","isubn","addn","iabs","_ishlnsubmul","_wordDiv","mode","bhi","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","acc","egcd","A","B","C","D","g","yp","xp","im","isOdd","jm","gcd","_invmp","x1","x2","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","ctx","convertTo","_forceRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","redSqr","_verify1","redISqr","redSqrt","redInvm","redNeg","k256","p224","p192","p25519","MPrime","name","_tmp","K256","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","_strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","wnd","current","currentLen","u","replaceClassName","origClass","classToRemove","RegExp","removeClass","element","className","classList","remove","setAttribute","baseVal","addClass","contains","indexOf","hasClass","CBC","EDE","proto","CBCState","iv","instantiate","Base","_cbcInit","Object","_cbcState","superProto","EDEState","k1","k2","k3","ciphers","_edeState","generatePrime","DH","ENCODINGS","DiffieHellmanGroup","createDiffieHellmanGroup","getDiffieHellman","createDiffieHellman","DiffieHellman","enc","generator","genc","isBuffer","SEVEN","setPublicKey","pub","_pub","setPrivateKey","priv","_priv","primeCache","malleable","setGenerator","__prime","_primeLen","_primeCode","formatReturnValue","bn","buf","defineProperty","enumerable","get","hex","rem","error","checkPrime","__gen","generateKeys","_gen","getPublicKey","computeSecret","other","secret","getPrime","front","fill","getPrivateKey","getGenerator","getParamBytesForAlg","MAX_OCTET","signatureAsBuffer","signature","from","TypeError","countPadding","stop","derToJose","alg","paramBytes","maxEncodedParamLength","inputLength","offset","TAG_SEQ","seqLength","TAG_INT","rLength","rOffset","sLength","sOffset","rPadding","sPadding","dst","allocUnsafe","joseToDer","signatureBytes","rsBytes","shortLength","getParamSize","keySize","paramBytesForAlg","ES256","ES384","ES512"],"mappings":"qHAEA,IAAIA,EAASC,EAAQ,IAErB,SAASC,EAAOC,GACdC,KAAKD,QAAUA,EAEfC,KAAKC,KAAOD,KAAKD,QAAQE,KACzBD,KAAKE,UAAY,EACjBF,KAAKG,QAELH,KAAKI,OAAS,IAAIC,MAAML,KAAKE,WAC7BF,KAAKM,UAAY,CACnB,CACAC,EAAOC,QAAUV,EAEjBA,EAAOW,UAAUN,MAAQ,WACvB,EAGFL,EAAOW,UAAUC,OAAS,SAAgBC,GACxC,OAAoB,IAAhBA,EAAKC,OACA,GAES,YAAdZ,KAAKC,KACAD,KAAKa,eAAeF,GAEpBX,KAAKc,eAAeH,EAC/B,EAEAb,EAAOW,UAAUM,QAAU,SAAiBJ,EAAMK,GAGhD,IADA,IAAIC,EAAMC,KAAKD,IAAIjB,KAAKI,OAAOQ,OAASZ,KAAKM,UAAWK,EAAKC,OAASI,GAC7DG,EAAI,EAAGA,EAAIF,EAAKE,IACvBnB,KAAKI,OAAOJ,KAAKM,UAAYa,GAAKR,EAAKK,EAAMG,GAI/C,OAHAnB,KAAKM,WAAaW,EAGXA,CACT,EAEAnB,EAAOW,UAAUW,aAAe,SAAsBC,EAAKL,GAGzD,OAFAhB,KAAKsB,QAAQtB,KAAKI,OAAQ,EAAGiB,EAAKL,GAClChB,KAAKM,UAAY,EACVN,KAAKE,SACd,EAEAJ,EAAOW,UAAUK,eAAiB,SAAwBH,GACxD,IAAIY,EAAW,EACXC,EAAY,EAEZC,GAAUzB,KAAKM,UAAYK,EAAKC,QAAUZ,KAAKE,UAAa,EAC5DmB,EAAM,IAAIhB,MAAMoB,EAAQzB,KAAKE,WAEV,IAAnBF,KAAKM,YACPiB,GAAYvB,KAAKe,QAAQJ,EAAMY,GAE3BvB,KAAKM,YAAcN,KAAKI,OAAOQ,SACjCY,GAAaxB,KAAKoB,aAAaC,EAAKG,KAKxC,IADA,IAAIE,EAAMf,EAAKC,QAAWD,EAAKC,OAASW,GAAYvB,KAAKE,UAClDqB,EAAWG,EAAKH,GAAYvB,KAAKE,UACtCF,KAAKsB,QAAQX,EAAMY,EAAUF,EAAKG,GAClCA,GAAaxB,KAAKE,UAIpB,KAAOqB,EAAWZ,EAAKC,OAAQW,IAAYvB,KAAKM,YAC9CN,KAAKI,OAAOJ,KAAKM,WAAaK,EAAKY,GAErC,OAAOF,CACT,EAEAvB,EAAOW,UAAUI,eAAiB,SAAwBF,GAQxD,IAPA,IAAIY,EAAW,EACXC,EAAY,EAEZC,EAAQP,KAAKS,MAAM3B,KAAKM,UAAYK,EAAKC,QAAUZ,KAAKE,WAAa,EACrEmB,EAAM,IAAIhB,MAAMoB,EAAQzB,KAAKE,WAG1BuB,EAAQ,EAAGA,IAChBF,GAAYvB,KAAKe,QAAQJ,EAAMY,GAC/BC,GAAaxB,KAAKoB,aAAaC,EAAKG,GAMtC,OAFAD,GAAYvB,KAAKe,QAAQJ,EAAMY,GAExBF,CACT,EAEAvB,EAAOW,UAAUmB,MAAQ,SAAexB,GACtC,IAAIyB,EAIAC,EAMJ,OATI1B,IACFyB,EAAQ7B,KAAKU,OAAON,IAIpB0B,EADgB,YAAd9B,KAAKC,KACAD,KAAK+B,gBAEL/B,KAAKgC,gBAEVH,EACKA,EAAMI,OAAOH,GAEbA,CACX,EAEAhC,EAAOW,UAAUyB,KAAO,SAAc9B,EAAQY,GAC5C,GAAY,IAARA,EACF,OAAO,EAET,KAAOA,EAAMZ,EAAOQ,QAClBR,EAAOY,KAAS,EAElB,OAAO,CACT,EAEAlB,EAAOW,UAAUsB,cAAgB,WAC/B,IAAK/B,KAAKkC,KAAKlC,KAAKI,OAAQJ,KAAKM,WAC/B,MAAO,GAET,IAAIe,EAAM,IAAIhB,MAAML,KAAKE,WAEzB,OADAF,KAAKsB,QAAQtB,KAAKI,OAAQ,EAAGiB,EAAK,GAC3BA,CACT,EAEAvB,EAAOW,UAAU0B,OAAS,SAAgB/B,GACxC,OAAOA,CACT,EAEAN,EAAOW,UAAUuB,cAAgB,WAC/BpC,EAAOwC,MAAMpC,KAAKM,UAAWN,KAAKE,UAAW,8BAC7C,IAAImB,EAAM,IAAIhB,MAAML,KAAKE,WAGzB,OAFAF,KAAKoB,aAAaC,EAAK,GAEhBrB,KAAKmC,OAAOd,EACrB,C,mCC1IAb,EAAQ6B,aAAe,SAAsBC,EAAOtB,GAKlD,OAJYsB,EAAM,EAAItB,IAAQ,GAClBsB,EAAM,EAAItB,IAAQ,GAClBsB,EAAM,EAAItB,IAAQ,EACnBsB,EAAM,EAAItB,MACN,CACjB,EAEAR,EAAQ+B,cAAgB,SAAuBD,EAAOE,EAAOxB,GAC3DsB,EAAM,EAAItB,GAAOwB,IAAU,GAC3BF,EAAM,EAAItB,GAAQwB,IAAU,GAAM,IAClCF,EAAM,EAAItB,GAAQwB,IAAU,EAAK,IACjCF,EAAM,EAAItB,GAAe,IAARwB,CACnB,EAEAhC,EAAQiC,GAAK,SAAYC,EAAKC,EAAKtB,EAAKL,GAItC,IAHA,IAAI4B,EAAO,EACPC,EAAO,EAEF1B,EAAI,EAAGA,GAAK,EAAGA,GAAK,EAAG,CAC9B,IAAK,IAAI2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BF,IAAS,EACTA,GAASD,IAASG,EAAI3B,EAAM,EAE9B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BF,IAAS,EACTA,GAASF,IAASI,EAAI3B,EAAM,CAEhC,CAEA,IAASA,EAAI,EAAGA,GAAK,EAAGA,GAAK,EAAG,CAC9B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BD,IAAS,EACTA,GAASF,IAASG,EAAI3B,EAAM,EAE9B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BD,IAAS,EACTA,GAASH,IAASI,EAAI3B,EAAM,CAEhC,CAEAE,EAAIL,EAAM,GAAK4B,IAAS,EACxBvB,EAAIL,EAAM,GAAK6B,IAAS,CAC1B,EAEArC,EAAQuC,IAAM,SAAaL,EAAKC,EAAKtB,EAAKL,GAIxC,IAHA,IAAI4B,EAAO,EACPC,EAAO,EAEF1B,EAAI,EAAGA,EAAI,EAAGA,IACrB,IAAK,IAAI2B,EAAI,GAAIA,GAAK,EAAGA,GAAK,EAC5BF,IAAS,EACTA,GAASD,IAASG,EAAI3B,EAAM,EAC5ByB,IAAS,EACTA,GAASF,IAASI,EAAI3B,EAAM,EAGhC,IAASA,EAAI,EAAGA,EAAI,EAAGA,IACrB,IAAS2B,EAAI,GAAIA,GAAK,EAAGA,GAAK,EAC5BD,IAAS,EACTA,GAASF,IAASG,EAAI3B,EAAM,EAC5B0B,IAAS,EACTA,GAASH,IAASI,EAAI3B,EAAM,EAIhCE,EAAIL,EAAM,GAAK4B,IAAS,EACxBvB,EAAIL,EAAM,GAAK6B,IAAS,CAC1B,EAEArC,EAAQwC,IAAM,SAAaN,EAAKC,EAAKtB,EAAKL,GAQxC,IAPA,IAAI4B,EAAO,EACPC,EAAO,EAMF1B,EAAI,EAAGA,GAAK,EAAGA,IAAK,CAC3B,IAAK,IAAI2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BF,IAAS,EACTA,GAASD,GAAQG,EAAI3B,EAAM,EAE7B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BF,IAAS,EACTA,GAASF,GAAQI,EAAI3B,EAAM,CAE/B,CACA,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BF,IAAS,EACTA,GAASD,GAAQG,EAAI3B,EAAM,EAO7B,IAASA,EAAI,EAAGA,GAAK,EAAGA,IAAK,CAC3B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BD,IAAS,EACTA,GAASF,GAAQG,EAAI3B,EAAM,EAE7B,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BD,IAAS,EACTA,GAASH,GAAQI,EAAI3B,EAAM,CAE/B,CACA,IAAS2B,EAAI,EAAGA,GAAK,GAAIA,GAAK,EAC5BD,IAAS,EACTA,GAASH,GAAQI,EAAI3B,EAAM,EAG7BE,EAAIL,EAAM,GAAK4B,IAAS,EACxBvB,EAAIL,EAAM,GAAK6B,IAAS,CAC1B,EAEArC,EAAQyC,OAAS,SAAgBC,EAAKC,GACpC,OAASD,GAAOC,EAAS,UAAcD,IAAS,GAAKC,CACvD,EAEA,IAAIC,EAAW,CAEb,GAAI,GAAI,GAAI,EAAG,GAAI,GAAI,GAAI,EAC3B,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,GACzB,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,GAAI,GAGzB,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,GACzB,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,GAAI,EACzB,GAAI,EAAG,GAAI,GAAI,EAAG,GAAI,GAAI,IAG5B5C,EAAQ6C,IAAM,SAAaX,EAAKC,EAAKtB,EAAKL,GAKxC,IAJA,IAAI4B,EAAO,EACPC,EAAO,EAEPS,EAAMF,EAASxC,SAAW,EACrBO,EAAI,EAAGA,EAAImC,EAAKnC,IACvByB,IAAS,EACTA,GAASF,IAAQU,EAASjC,GAAM,EAElC,IAASA,EAAImC,EAAKnC,EAAIiC,EAASxC,OAAQO,IACrC0B,IAAS,EACTA,GAASF,IAAQS,EAASjC,GAAM,EAGlCE,EAAIL,EAAM,GAAK4B,IAAS,EACxBvB,EAAIL,EAAM,GAAK6B,IAAS,CAC1B,EAEArC,EAAQ+C,OAAS,SAAgBC,EAAGnC,EAAKL,GACvC,IAAI4B,EAAO,EACPC,EAAO,EAEXD,GAAa,EAAJY,IAAU,EAAMA,IAAM,GAC/B,IAAK,IAAIrC,EAAI,GAAIA,GAAK,GAAIA,GAAK,EAC7ByB,IAAS,EACTA,GAASY,IAAMrC,EAAK,GAEtB,IAASA,EAAI,GAAIA,GAAK,EAAGA,GAAK,EAC5B0B,GAASW,IAAMrC,EAAK,GACpB0B,IAAS,EAEXA,IAAc,GAAJW,IAAa,EAAMA,IAAM,GAEnCnC,EAAIL,EAAM,GAAK4B,IAAS,EACxBvB,EAAIL,EAAM,GAAK6B,IAAS,CAC1B,EAEA,IAAIY,EAAS,CACX,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,GAAI,EAAG,EACpD,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAClD,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,EAClD,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAEnD,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAClD,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EACnD,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EACpD,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAElD,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,GACjD,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,GAAI,EAAG,EACpD,GAAI,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EACjD,GAAI,EAAG,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,GAEpD,EAAG,GAAI,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EACnD,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,GAAI,EAAG,GAAI,GAAI,EACnD,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,EACpD,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAEjD,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EACpD,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAClD,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GACnD,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAElD,GAAI,GAAI,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EACnD,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EACnD,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAClD,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,GAElD,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAAI,GACnD,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,EAClD,EAAG,EAAG,EAAG,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EACpD,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,GAEjD,GAAI,EAAG,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,EACnD,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EAAG,GAAI,GAAI,EAAG,EAAG,EACnD,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,GAClD,EAAG,GAAI,EAAG,GAAI,GAAI,EAAG,GAAI,EAAG,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,IAGpDjD,EAAQkD,WAAa,SAAoBhB,EAAKC,GAE5C,IADA,IAAItB,EAAM,EACDF,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAI1BE,IAAQ,EACRA,GAHSoC,EAAW,GAAJtC,GADPuB,IAAS,GAAS,EAAJvB,EAAU,IAKnC,CACA,IAASA,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAI1BE,IAAQ,EACRA,GAHSoC,EAAO,IAAe,GAAJtC,GADlBwB,IAAS,GAAS,EAAJxB,EAAU,IAKnC,CACA,OAAOE,IAAQ,CACjB,EAEA,IAAIsC,EAAe,CACjB,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,EAAG,GAAI,GAAI,GAAI,EAAG,EAAG,GAAI,GAAI,EAAG,GACvD,GAAI,GAAI,EAAG,GAAI,EAAG,EAAG,GAAI,GAAI,GAAI,GAAI,EAAG,GAAI,GAAI,GAAI,GAAI,GAG1DnD,EAAQoD,QAAU,SAAiBV,GAEjC,IADA,IAAI7B,EAAM,EACDF,EAAI,EAAGA,EAAIwC,EAAa/C,OAAQO,IACvCE,IAAQ,EACRA,GAAQ6B,IAAQS,EAAaxC,GAAM,EAErC,OAAOE,IAAQ,CACjB,EAEAb,EAAQqD,SAAW,SAAkBX,EAAKY,EAAMC,GAE9C,IADA,IAAIC,EAAMd,EAAIe,SAAS,GAChBD,EAAIpD,OAASkD,GAClBE,EAAM,IAAMA,EAGd,IADA,IAAI3C,EAAM,GACDF,EAAI,EAAGA,EAAI2C,EAAM3C,GAAK4C,EAC7B1C,EAAI6C,KAAKF,EAAIG,MAAMhD,EAAGA,EAAI4C,IAC5B,OAAO1C,EAAI+C,KAAK,IAClB,C,mCC7PA,IAAIxE,EAASC,EAAQ,IACjBwE,EAAWxE,EAAQ,IAEnByE,EAAQzE,EAAQ,KAChBC,EAASD,EAAQ,KAErB,SAAS0E,IACPvE,KAAKwE,IAAM,IAAInE,MAAM,GACrBL,KAAKyE,KAAO,IACd,CAEA,SAASC,EAAI3E,GACXD,EAAO6E,KAAK3E,KAAMD,GAElB,IAAI6E,EAAQ,IAAIL,EAChBvE,KAAK6E,UAAYD,EAEjB5E,KAAK8E,WAAWF,EAAO7E,EAAQgF,IACjC,CACAV,EAASK,EAAK5E,GACdS,EAAOC,QAAUkE,EAEjBA,EAAIM,OAAS,SAAgBjF,GAC3B,OAAO,IAAI2E,EAAI3E,EACjB,EAEA,IAAIkF,EAAa,CACf,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EACrB,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAGvBP,EAAIjE,UAAUqE,WAAa,SAAoBF,EAAOG,GACpDH,EAAMH,KAAO,IAAIpE,MAAM,IAEvBT,EAAOwC,MAAM2C,EAAInE,OAAQZ,KAAKE,UAAW,sBAEzC,IAAIgF,EAAKZ,EAAMjC,aAAa0C,EAAK,GAC7BI,EAAKb,EAAMjC,aAAa0C,EAAK,GAEjCT,EAAMtB,IAAIkC,EAAIC,EAAIP,EAAMJ,IAAK,GAC7BU,EAAKN,EAAMJ,IAAI,GACfW,EAAKP,EAAMJ,IAAI,GACf,IAAK,IAAIrD,EAAI,EAAGA,EAAIyD,EAAMH,KAAK7D,OAAQO,GAAK,EAAG,CAC7C,IAAIgC,EAAQ8B,EAAW9D,IAAM,GAC7B+D,EAAKZ,EAAMrB,OAAOiC,EAAI/B,GACtBgC,EAAKb,EAAMrB,OAAOkC,EAAIhC,GACtBmB,EAAMjB,IAAI6B,EAAIC,EAAIP,EAAMH,KAAMtD,EAChC,CACF,EAEAuD,EAAIjE,UAAUa,QAAU,SAAiB8D,EAAKC,EAAOhE,EAAKiE,GACxD,IAAIV,EAAQ5E,KAAK6E,UAEbU,EAAIjB,EAAMjC,aAAa+C,EAAKC,GAC5B7B,EAAIc,EAAMjC,aAAa+C,EAAKC,EAAQ,GAGxCf,EAAM7B,GAAG8C,EAAG/B,EAAGoB,EAAMJ,IAAK,GAC1Be,EAAIX,EAAMJ,IAAI,GACdhB,EAAIoB,EAAMJ,IAAI,GAEI,YAAdxE,KAAKC,KACPD,KAAKwF,SAASZ,EAAOW,EAAG/B,EAAGoB,EAAMJ,IAAK,GAEtCxE,KAAKyF,SAASb,EAAOW,EAAG/B,EAAGoB,EAAMJ,IAAK,GAExCe,EAAIX,EAAMJ,IAAI,GACdhB,EAAIoB,EAAMJ,IAAI,GAEdF,EAAM/B,cAAclB,EAAKkE,EAAGD,GAC5BhB,EAAM/B,cAAclB,EAAKmC,EAAG8B,EAAS,EACvC,EAEAZ,EAAIjE,UAAUyB,KAAO,SAAc9B,EAAQY,GAEzC,IADA,IAAIwB,EAAQpC,EAAOQ,OAASI,EACnBG,EAAIH,EAAKG,EAAIf,EAAOQ,OAAQO,IACnCf,EAAOe,GAAKqB,EAEd,OAAO,CACT,EAEAkC,EAAIjE,UAAU0B,OAAS,SAAgB/B,GAErC,IADA,IAAIsF,EAAMtF,EAAOA,EAAOQ,OAAS,GACxBO,EAAIf,EAAOQ,OAAS8E,EAAKvE,EAAIf,EAAOQ,OAAQO,IACnDvB,EAAOwC,MAAMhC,EAAOe,GAAIuE,GAE1B,OAAOtF,EAAO+D,MAAM,EAAG/D,EAAOQ,OAAS8E,EACzC,EAEAhB,EAAIjE,UAAU+E,SAAW,SAAkBZ,EAAOe,EAAQC,EAAQvE,EAAKL,GAKrE,IAJA,IAAIuE,EAAII,EACJnC,EAAIoC,EAGCzE,EAAI,EAAGA,EAAIyD,EAAMH,KAAK7D,OAAQO,GAAK,EAAG,CAC7C,IAAI0E,EAAOjB,EAAMH,KAAKtD,GAClB2E,EAAOlB,EAAMH,KAAKtD,EAAI,GAG1BmD,EAAMf,OAAOC,EAAGoB,EAAMJ,IAAK,GAE3BqB,GAAQjB,EAAMJ,IAAI,GAClBsB,GAAQlB,EAAMJ,IAAI,GAClB,IAAIuB,EAAIzB,EAAMZ,WAAWmC,EAAMC,GAG3BE,EAAIxC,EACRA,GAAK+B,EAHGjB,EAAMV,QAAQmC,MAGN,EAChBR,EAAIS,CACN,CAGA1B,EAAMvB,IAAIS,EAAG+B,EAAGlE,EAAKL,EACvB,EAEA0D,EAAIjE,UAAUgF,SAAW,SAAkBb,EAAOe,EAAQC,EAAQvE,EAAKL,GAKrE,IAJA,IAAIuE,EAAIK,EACJpC,EAAImC,EAGCxE,EAAIyD,EAAMH,KAAK7D,OAAS,EAAGO,GAAK,EAAGA,GAAK,EAAG,CAClD,IAAI0E,EAAOjB,EAAMH,KAAKtD,GAClB2E,EAAOlB,EAAMH,KAAKtD,EAAI,GAG1BmD,EAAMf,OAAOgC,EAAGX,EAAMJ,IAAK,GAE3BqB,GAAQjB,EAAMJ,IAAI,GAClBsB,GAAQlB,EAAMJ,IAAI,GAClB,IAAIuB,EAAIzB,EAAMZ,WAAWmC,EAAMC,GAG3BE,EAAIT,EACRA,GAAK/B,EAHGc,EAAMV,QAAQmC,MAGN,EAChBvC,EAAIwC,CACN,CAGA1B,EAAMvB,IAAIwC,EAAG/B,EAAGnC,EAAKL,EACvB,C,sBC7IA,IAAIiF,EAAcpG,EAAQ,KAC1BU,EAAOC,QAAU0F,EACjBA,EAAUC,YAAcA,EACxBD,EAAUE,WAAaA,EACvB,IAAIC,EAAKxG,EAAQ,KACbyG,EAAa,IAAID,EAAG,IAEpBE,EAAc,IADA1G,EAAQ,MAEtB2G,EAAM,IAAIH,EAAG,GACbI,EAAM,IAAIJ,EAAG,GACbK,EAAO,IAAIL,EAAG,GAGdM,GAFU,IAAIN,EAAG,IACT,IAAIA,EAAG,GACT,IAAIA,EAAG,KACbO,EAAQ,IAAIP,EAAG,GAEfQ,GADQ,IAAIR,EAAG,GACN,IAAIA,EAAG,KAChBS,EAAO,IAAIT,EAAG,GAEdU,GADS,IAAIV,EAAG,IACP,MAEb,SAASW,IACP,GAAe,OAAXD,EACF,OAAOA,EAET,IACIE,EAAM,GACVA,EAAI,GAAK,EACT,IAAK,IAAI9F,EAAI,EAAG+F,EAAI,EAAGA,EAHX,QAGsBA,GAAK,EAAG,CAExC,IADA,IAAIC,EAAOjG,KAAKS,KAAKT,KAAKiG,KAAKD,IACtBpE,EAAI,EAAGA,EAAI3B,GAAK8F,EAAInE,IAAMqE,GAC7BD,EAAID,EAAInE,KAAO,EADoBA,KAIrC3B,IAAM2B,GAAKmE,EAAInE,IAAMqE,IAGzBF,EAAI9F,KAAO+F,EACb,CAEA,OADAH,EAASE,EACFA,CACT,CAEA,SAASd,EAAYiB,GAGnB,IAFA,IAAIL,EAASC,IAEJ7F,EAAI,EAAGA,EAAI4F,EAAOnG,OAAQO,IACjC,GAA0B,IAAtBiG,EAAEC,KAAKN,EAAO5F,IAChB,OAA0B,IAAtBiG,EAAEE,KAAKP,EAAO5F,IAOtB,OAAO,CACT,CAEA,SAASiF,EAAWgB,GAClB,IAAIG,EAAMlB,EAAGmB,KAAKJ,GAClB,OAA8D,IAAvDX,EAAIgB,MAAMF,GAAKG,OAAON,EAAEO,KAAK,IAAIC,UAAUN,KAAK,EACzD,CAEA,SAASpB,EAAU2B,EAAMC,GACvB,GAAID,EAAO,GAET,OACS,IAAIxB,EADD,IAARyB,GAAqB,IAARA,EACD,CAAC,IAAM,KAEP,CAAC,IAAM,KAKzB,IAAI5E,EAAK6E,EAET,IAJAD,EAAM,IAAIzB,EAAGyB,KAIA,CAEX,IADA5E,EAAM,IAAImD,EAAGJ,EAAY/E,KAAKS,KAAKkG,EAAO,KACnC3E,EAAI8E,YAAcH,GACvB3E,EAAI+E,MAAM,GAQZ,GANI/E,EAAIgF,UACNhF,EAAIiF,KAAK3B,GAENtD,EAAIkF,MAAM,IACblF,EAAIiF,KAAK1B,GAENqB,EAAIO,IAAI5B,IAIN,IAAKqB,EAAIO,IAAI3B,GAClB,KAAOxD,EAAIoF,IAAI3B,GAAK0B,IAAIzB,IACtB1D,EAAIiF,KAAKrB,QALX,KAAO5D,EAAIoF,IAAIhC,GAAY+B,IAAIxB,IAC7B3D,EAAIiF,KAAKrB,GAQb,GAAIX,EADJ4B,EAAK7E,EAAIqF,KAAK,KACSpC,EAAYjD,IACjCkD,EAAW2B,IAAO3B,EAAWlD,IAC7BqD,EAAYiC,KAAKT,IAAOxB,EAAYiC,KAAKtF,GACzC,OAAOA,CAEX,CAEF,C,uBCxGA,sBAAW3C,EAAQC,GACjB,aAGA,SAASZ,EAAQ6I,EAAKC,GACpB,IAAKD,EAAK,MAAM,IAAIE,MAAMD,GAAO,mBACnC,CAIA,SAASrE,EAAUuE,EAAMC,GACvBD,EAAKE,OAASD,EACd,IAAIE,EAAW,WAAa,EAC5BA,EAAStI,UAAYoI,EAAUpI,UAC/BmI,EAAKnI,UAAY,IAAIsI,EACrBH,EAAKnI,UAAUuI,YAAcJ,CAC/B,CAIA,SAASvC,EAAI4C,EAAQC,EAAMC,GACzB,GAAI9C,EAAG+C,KAAKH,GACV,OAAOA,EAGTjJ,KAAKqJ,SAAW,EAChBrJ,KAAKsJ,MAAQ,KACbtJ,KAAKY,OAAS,EAGdZ,KAAKuH,IAAM,KAEI,OAAX0B,IACW,OAATC,GAA0B,OAATA,IACnBC,EAASD,EACTA,EAAO,IAGTlJ,KAAKG,MAAM8I,GAAU,EAAGC,GAAQ,GAAIC,GAAU,MAElD,CAUA,IAAII,EATkB,kBAAXhJ,EACTA,EAAOC,QAAU6F,EAEjB7F,EAAQ6F,GAAKA,EAGfA,EAAGA,GAAKA,EACRA,EAAGmD,SAAW,GAGd,IAEID,EADoB,qBAAXE,QAAmD,qBAAlBA,OAAOF,OACxCE,OAAOF,OAEP1J,EAAQ,KAAU0J,MAG/B,CADE,MAAOG,GACT,CA+HA,SAASC,EAAeC,EAAQC,GAC9B,IAAIC,EAAIF,EAAOG,WAAWF,GAE1B,OAAIC,GAAK,IAAMA,GAAK,GACXA,EAAI,GAEFA,GAAK,IAAMA,GAAK,IAClBA,EAAI,GAGHA,EAAI,GAAM,EAEtB,CAEA,SAASE,EAAcJ,EAAQK,EAAYJ,GACzC,IAAIrG,EAAImG,EAAcC,EAAQC,GAI9B,OAHIA,EAAQ,GAAKI,IACfzG,GAAKmG,EAAcC,EAAQC,EAAQ,IAAM,GAEpCrG,CACT,CA6CA,SAAS0G,EAAWlG,EAAKmG,EAAOC,EAAKC,GAGnC,IAFA,IAAI7G,EAAI,EACJF,EAAMpC,KAAKD,IAAI+C,EAAIpD,OAAQwJ,GACtBjJ,EAAIgJ,EAAOhJ,EAAImC,EAAKnC,IAAK,CAChC,IAAI2I,EAAI9F,EAAI+F,WAAW5I,GAAK,GAE5BqC,GAAK6G,EAIH7G,GADEsG,GAAK,GACFA,EAAI,GAAK,GAGLA,GAAK,GACTA,EAAI,GAAK,GAITA,CAET,CACA,OAAOtG,CACT,CApNA6C,EAAG+C,KAAO,SAAelG,GACvB,OAAIA,aAAemD,GAIJ,OAARnD,GAA+B,kBAARA,GAC5BA,EAAI8F,YAAYQ,WAAanD,EAAGmD,UAAYnJ,MAAMiK,QAAQpH,EAAIoG,MAClE,EAEAjD,EAAG3E,IAAM,SAAc6I,EAAMC,GAC3B,OAAID,EAAKlC,IAAImC,GAAS,EAAUD,EACzBC,CACT,EAEAnE,EAAGpF,IAAM,SAAcsJ,EAAMC,GAC3B,OAAID,EAAKlC,IAAImC,GAAS,EAAUD,EACzBC,CACT,EAEAnE,EAAG5F,UAAUN,MAAQ,SAAe8I,EAAQC,EAAMC,GAChD,GAAsB,kBAAXF,EACT,OAAOjJ,KAAKyK,YAAYxB,EAAQC,EAAMC,GAGxC,GAAsB,kBAAXF,EACT,OAAOjJ,KAAK0K,WAAWzB,EAAQC,EAAMC,GAG1B,QAATD,IACFA,EAAO,IAETtJ,EAAOsJ,KAAiB,EAAPA,IAAaA,GAAQ,GAAKA,GAAQ,IAGnD,IAAIiB,EAAQ,EACM,OAFlBlB,EAASA,EAAOhF,WAAW0G,QAAQ,OAAQ,KAEhC,KACTR,IACAnK,KAAKqJ,SAAW,GAGdc,EAAQlB,EAAOrI,SACJ,KAATsI,EACFlJ,KAAK4K,UAAU3B,EAAQkB,EAAOhB,IAE9BnJ,KAAK6K,WAAW5B,EAAQC,EAAMiB,GACf,OAAXhB,GACFnJ,KAAK0K,WAAW1K,KAAK8K,UAAW5B,EAAMC,IAI9C,EAEA9C,EAAG5F,UAAUgK,YAAc,SAAsBxB,EAAQC,EAAMC,GACzDF,EAAS,IACXjJ,KAAKqJ,SAAW,EAChBJ,GAAUA,GAERA,EAAS,UACXjJ,KAAKsJ,MAAQ,CAAW,SAATL,GACfjJ,KAAKY,OAAS,GACLqI,EAAS,kBAClBjJ,KAAKsJ,MAAQ,CACF,SAATL,EACCA,EAAS,SAAa,UAEzBjJ,KAAKY,OAAS,IAEdhB,EAAOqJ,EAAS,kBAChBjJ,KAAKsJ,MAAQ,CACF,SAATL,EACCA,EAAS,SAAa,SACvB,GAEFjJ,KAAKY,OAAS,GAGD,OAAXuI,GAGJnJ,KAAK0K,WAAW1K,KAAK8K,UAAW5B,EAAMC,EACxC,EAEA9C,EAAG5F,UAAUiK,WAAa,SAAqBzB,EAAQC,EAAMC,GAG3D,GADAvJ,EAAgC,kBAAlBqJ,EAAOrI,QACjBqI,EAAOrI,QAAU,EAGnB,OAFAZ,KAAKsJ,MAAQ,CAAE,GACftJ,KAAKY,OAAS,EACPZ,KAGTA,KAAKY,OAASM,KAAKS,KAAKsH,EAAOrI,OAAS,GACxCZ,KAAKsJ,MAAQ,IAAIjJ,MAAML,KAAKY,QAC5B,IAAK,IAAIO,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAC/BnB,KAAKsJ,MAAMnI,GAAK,EAGlB,IAAI2B,EAAGiI,EACH/J,EAAM,EACV,GAAe,OAAXmI,EACF,IAAKhI,EAAI8H,EAAOrI,OAAS,EAAGkC,EAAI,EAAG3B,GAAK,EAAGA,GAAK,EAC9C4J,EAAI9B,EAAO9H,GAAM8H,EAAO9H,EAAI,IAAM,EAAM8H,EAAO9H,EAAI,IAAM,GACzDnB,KAAKsJ,MAAMxG,IAAOiI,GAAK/J,EAAO,SAC9BhB,KAAKsJ,MAAMxG,EAAI,GAAMiI,IAAO,GAAK/J,EAAQ,UACzCA,GAAO,KACI,KACTA,GAAO,GACP8B,UAGC,GAAe,OAAXqG,EACT,IAAKhI,EAAI,EAAG2B,EAAI,EAAG3B,EAAI8H,EAAOrI,OAAQO,GAAK,EACzC4J,EAAI9B,EAAO9H,GAAM8H,EAAO9H,EAAI,IAAM,EAAM8H,EAAO9H,EAAI,IAAM,GACzDnB,KAAKsJ,MAAMxG,IAAOiI,GAAK/J,EAAO,SAC9BhB,KAAKsJ,MAAMxG,EAAI,GAAMiI,IAAO,GAAK/J,EAAQ,UACzCA,GAAO,KACI,KACTA,GAAO,GACP8B,KAIN,OAAO9C,KAAKgL,OACd,EAwBA3E,EAAG5F,UAAUmK,UAAY,SAAoB3B,EAAQkB,EAAOhB,GAE1DnJ,KAAKY,OAASM,KAAKS,MAAMsH,EAAOrI,OAASuJ,GAAS,GAClDnK,KAAKsJ,MAAQ,IAAIjJ,MAAML,KAAKY,QAC5B,IAAK,IAAIO,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAC/BnB,KAAKsJ,MAAMnI,GAAK,EAIlB,IAGI4J,EAHA/J,EAAM,EACN8B,EAAI,EAGR,GAAe,OAAXqG,EACF,IAAKhI,EAAI8H,EAAOrI,OAAS,EAAGO,GAAKgJ,EAAOhJ,GAAK,EAC3C4J,EAAIf,EAAaf,EAAQkB,EAAOhJ,IAAMH,EACtChB,KAAKsJ,MAAMxG,IAAU,SAAJiI,EACb/J,GAAO,IACTA,GAAO,GACP8B,GAAK,EACL9C,KAAKsJ,MAAMxG,IAAMiI,IAAM,IAEvB/J,GAAO,OAKX,IAAKG,GADa8H,EAAOrI,OAASuJ,GACX,IAAM,EAAIA,EAAQ,EAAIA,EAAOhJ,EAAI8H,EAAOrI,OAAQO,GAAK,EAC1E4J,EAAIf,EAAaf,EAAQkB,EAAOhJ,IAAMH,EACtChB,KAAKsJ,MAAMxG,IAAU,SAAJiI,EACb/J,GAAO,IACTA,GAAO,GACP8B,GAAK,EACL9C,KAAKsJ,MAAMxG,IAAMiI,IAAM,IAEvB/J,GAAO,EAKbhB,KAAKgL,OACP,EA0BA3E,EAAG5F,UAAUoK,WAAa,SAAqB5B,EAAQC,EAAMiB,GAE3DnK,KAAKsJ,MAAQ,CAAE,GACftJ,KAAKY,OAAS,EAGd,IAAK,IAAIqK,EAAU,EAAGC,EAAU,EAAGA,GAAW,SAAWA,GAAWhC,EAClE+B,IAEFA,IACAC,EAAWA,EAAUhC,EAAQ,EAO7B,IALA,IAAIiC,EAAQlC,EAAOrI,OAASuJ,EACxB7B,EAAM6C,EAAQF,EACdb,EAAMlJ,KAAKD,IAAIkK,EAAOA,EAAQ7C,GAAO6B,EAErCiB,EAAO,EACFjK,EAAIgJ,EAAOhJ,EAAIiJ,EAAKjJ,GAAK8J,EAChCG,EAAOlB,EAAUjB,EAAQ9H,EAAGA,EAAI8J,EAAS/B,GAEzClJ,KAAKqL,MAAMH,GACPlL,KAAKsJ,MAAM,GAAK8B,EAAO,SACzBpL,KAAKsJ,MAAM,IAAM8B,EAEjBpL,KAAKsL,OAAOF,GAIhB,GAAY,IAAR9C,EAAW,CACb,IAAIiD,EAAM,EAGV,IAFAH,EAAOlB,EAAUjB,EAAQ9H,EAAG8H,EAAOrI,OAAQsI,GAEtC/H,EAAI,EAAGA,EAAImH,EAAKnH,IACnBoK,GAAOrC,EAGTlJ,KAAKqL,MAAME,GACPvL,KAAKsJ,MAAM,GAAK8B,EAAO,SACzBpL,KAAKsJ,MAAM,IAAM8B,EAEjBpL,KAAKsL,OAAOF,EAEhB,CAEApL,KAAKgL,OACP,EAEA3E,EAAG5F,UAAU+K,KAAO,SAAeC,GACjCA,EAAKnC,MAAQ,IAAIjJ,MAAML,KAAKY,QAC5B,IAAK,IAAIO,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAC/BsK,EAAKnC,MAAMnI,GAAKnB,KAAKsJ,MAAMnI,GAE7BsK,EAAK7K,OAASZ,KAAKY,OACnB6K,EAAKpC,SAAWrJ,KAAKqJ,SACrBoC,EAAKlE,IAAMvH,KAAKuH,GAClB,EAEAlB,EAAG5F,UAAUiL,MAAQ,WACnB,IAAIlI,EAAI,IAAI6C,EAAG,MAEf,OADArG,KAAKwL,KAAKhI,GACHA,CACT,EAEA6C,EAAG5F,UAAUkL,QAAU,SAAkB7H,GACvC,KAAO9D,KAAKY,OAASkD,GACnB9D,KAAKsJ,MAAMtJ,KAAKY,UAAY,EAE9B,OAAOZ,IACT,EAGAqG,EAAG5F,UAAUuK,MAAQ,WACnB,KAAOhL,KAAKY,OAAS,GAAqC,IAAhCZ,KAAKsJ,MAAMtJ,KAAKY,OAAS,IACjDZ,KAAKY,SAEP,OAAOZ,KAAK4L,WACd,EAEAvF,EAAG5F,UAAUmL,UAAY,WAKvB,OAHoB,IAAhB5L,KAAKY,QAAkC,IAAlBZ,KAAKsJ,MAAM,KAClCtJ,KAAKqJ,SAAW,GAEXrJ,IACT,EAEAqG,EAAG5F,UAAUoL,QAAU,WACrB,OAAQ7L,KAAKuH,IAAM,UAAY,SAAWvH,KAAKiE,SAAS,IAAM,GAChE,EAgCA,IAAI6H,EAAQ,CACV,GACA,IACA,KACA,MACA,OACA,QACA,SACA,UACA,WACA,YACA,aACA,cACA,eACA,gBACA,iBACA,kBACA,mBACA,oBACA,qBACA,sBACA,uBACA,wBACA,yBACA,0BACA,2BACA,6BAGEC,EAAa,CACf,EAAG,EACH,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EACvB,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAClB,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAClB,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAClB,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GAGhBC,EAAa,CACf,EAAG,EACH,SAAU,SAAU,SAAU,SAAU,SAAU,SAAU,SAC5D,SAAU,IAAU,SAAU,SAAU,SAAU,QAAS,SAC3D,SAAU,SAAU,SAAU,SAAU,KAAU,QAAS,QAC3D,QAAS,QAAS,QAAS,SAAU,SAAU,SAAU,SACzD,MAAU,SAAU,SAAU,SAAU,SAAU,SAAU,UAsjB9D,SAASC,EAAYC,EAAMhJ,EAAK7B,GAC9BA,EAAIgI,SAAWnG,EAAImG,SAAW6C,EAAK7C,SACnC,IAAI/F,EAAO4I,EAAKtL,OAASsC,EAAItC,OAAU,EACvCS,EAAIT,OAAS0C,EACbA,EAAOA,EAAM,EAAK,EAGlB,IAAI6I,EAAoB,EAAhBD,EAAK5C,MAAM,GACf8C,EAAmB,EAAflJ,EAAIoG,MAAM,GACd9F,EAAI2I,EAAIC,EAERC,EAAS,SAAJ7I,EACL8I,EAAS9I,EAAI,SAAa,EAC9BnC,EAAIiI,MAAM,GAAK+C,EAEf,IAAK,IAAInF,EAAI,EAAGA,EAAI5D,EAAK4D,IAAK,CAM5B,IAHA,IAAIqF,EAASD,IAAU,GACnBE,EAAgB,SAARF,EACRG,EAAOvL,KAAKD,IAAIiG,EAAGhE,EAAItC,OAAS,GAC3BkC,EAAI5B,KAAKQ,IAAI,EAAGwF,EAAIgF,EAAKtL,OAAS,GAAIkC,GAAK2J,EAAM3J,IAAK,CAC7D,IAAI3B,EAAK+F,EAAIpE,EAAK,EAIlByJ,IADA/I,GAFA2I,EAAoB,EAAhBD,EAAK5C,MAAMnI,KACfiL,EAAmB,EAAflJ,EAAIoG,MAAMxG,IACF0J,GACG,SAAa,EAC5BA,EAAY,SAAJhJ,CACV,CACAnC,EAAIiI,MAAMpC,GAAa,EAARsF,EACfF,EAAiB,EAATC,CACV,CAOA,OANc,IAAVD,EACFjL,EAAIiI,MAAMpC,GAAa,EAARoF,EAEfjL,EAAIT,SAGCS,EAAI2J,OACb,CA1lBA3E,EAAG5F,UAAUwD,SAAW,SAAmBiF,EAAMwD,GAI/C,IAAIrL,EACJ,GAHAqL,EAAoB,EAAVA,GAAe,EAGZ,MAJbxD,EAAOA,GAAQ,KAIa,QAATA,EAAgB,CACjC7H,EAAM,GAGN,IAFA,IAAIL,EAAM,EACNsL,EAAQ,EACHnL,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAAK,CACpC,IAAI4J,EAAI/K,KAAKsJ,MAAMnI,GACfiK,GAA+B,UAArBL,GAAK/J,EAAOsL,IAAmBrI,SAAS,IAGpD5C,EADY,KADdiL,EAASvB,IAAO,GAAK/J,EAAQ,WACVG,IAAMnB,KAAKY,OAAS,EAC/BkL,EAAM,EAAIV,EAAKxK,QAAUwK,EAAO/J,EAEhC+J,EAAO/J,GAEfL,GAAO,IACI,KACTA,GAAO,GACPG,IAEJ,CAIA,IAHc,IAAVmL,IACFjL,EAAMiL,EAAMrI,SAAS,IAAM5C,GAEtBA,EAAIT,OAAS8L,IAAY,GAC9BrL,EAAM,IAAMA,EAKd,OAHsB,IAAlBrB,KAAKqJ,WACPhI,EAAM,IAAMA,GAEPA,CACT,CAEA,GAAI6H,KAAiB,EAAPA,IAAaA,GAAQ,GAAKA,GAAQ,GAAI,CAElD,IAAIyD,EAAYZ,EAAW7C,GAEvB0D,EAAYZ,EAAW9C,GAC3B7H,EAAM,GACN,IAAIyI,EAAI9J,KAAK0L,QAEb,IADA5B,EAAET,SAAW,GACLS,EAAE+C,UAAU,CAClB,IAAIrJ,EAAIsG,EAAEzC,KAAKuF,GAAW3I,SAASiF,GAMjC7H,GALFyI,EAAIA,EAAEgD,MAAMF,IAELC,SAGCrJ,EAAInC,EAFJyK,EAAMa,EAAYnJ,EAAE5C,QAAU4C,EAAInC,CAI5C,CAIA,IAHIrB,KAAK6M,WACPxL,EAAM,IAAMA,GAEPA,EAAIT,OAAS8L,IAAY,GAC9BrL,EAAM,IAAMA,EAKd,OAHsB,IAAlBrB,KAAKqJ,WACPhI,EAAM,IAAMA,GAEPA,CACT,CAEAzB,GAAO,EAAO,kCAChB,EAEAyG,EAAG5F,UAAUsM,SAAW,WACtB,IAAIC,EAAMhN,KAAKsJ,MAAM,GASrB,OARoB,IAAhBtJ,KAAKY,OACPoM,GAAuB,SAAhBhN,KAAKsJ,MAAM,GACO,IAAhBtJ,KAAKY,QAAkC,IAAlBZ,KAAKsJ,MAAM,GAEzC0D,GAAO,iBAAoC,SAAhBhN,KAAKsJ,MAAM,GAC7BtJ,KAAKY,OAAS,GACvBhB,GAAO,EAAO,8CAEU,IAAlBI,KAAKqJ,UAAmB2D,EAAMA,CACxC,EAEA3G,EAAG5F,UAAUwM,OAAS,WACpB,OAAOjN,KAAKiE,SAAS,GACvB,EAEAoC,EAAG5F,UAAUyM,SAAW,SAAmB/D,EAAQvI,GAEjD,OADAhB,EAAyB,qBAAX2J,GACPvJ,KAAKmN,YAAY5D,EAAQJ,EAAQvI,EAC1C,EAEAyF,EAAG5F,UAAUqK,QAAU,SAAkB3B,EAAQvI,GAC/C,OAAOZ,KAAKmN,YAAY9M,MAAO8I,EAAQvI,EACzC,EAEAyF,EAAG5F,UAAU0M,YAAc,SAAsBC,EAAWjE,EAAQvI,GAClE,IAAIyM,EAAarN,KAAKqN,aAClBC,EAAY1M,GAAUM,KAAKQ,IAAI,EAAG2L,GACtCzN,EAAOyN,GAAcC,EAAW,yCAChC1N,EAAO0N,EAAY,EAAG,+BAEtBtN,KAAKgL,QACL,IAGIoB,EAAGjL,EAHHoM,EAA0B,OAAXpE,EACflC,EAAM,IAAImG,EAAUE,GAGpBE,EAAIxN,KAAK0L,QACb,GAAK6B,EAYE,CACL,IAAKpM,EAAI,GAAIqM,EAAEX,SAAU1L,IACvBiL,EAAIoB,EAAEC,MAAM,KACZD,EAAEE,OAAO,GAETzG,EAAI9F,GAAKiL,EAGX,KAAOjL,EAAImM,EAAWnM,IACpB8F,EAAI9F,GAAK,CAEb,KAvBmB,CAEjB,IAAKA,EAAI,EAAGA,EAAImM,EAAYD,EAAYlM,IACtC8F,EAAI9F,GAAK,EAGX,IAAKA,EAAI,GAAIqM,EAAEX,SAAU1L,IACvBiL,EAAIoB,EAAEC,MAAM,KACZD,EAAEE,OAAO,GAETzG,EAAIqG,EAAYnM,EAAI,GAAKiL,CAE7B,CAaA,OAAOnF,CACT,EAEI/F,KAAKyM,MACPtH,EAAG5F,UAAUmN,WAAa,SAAqB7C,GAC7C,OAAO,GAAK7J,KAAKyM,MAAM5C,EACzB,EAEA1E,EAAG5F,UAAUmN,WAAa,SAAqB7C,GAC7C,IAAI/E,EAAI+E,EACJvH,EAAI,EAiBR,OAhBIwC,GAAK,OACPxC,GAAK,GACLwC,KAAO,IAELA,GAAK,KACPxC,GAAK,EACLwC,KAAO,GAELA,GAAK,IACPxC,GAAK,EACLwC,KAAO,GAELA,GAAK,IACPxC,GAAK,EACLwC,KAAO,GAEFxC,EAAIwC,CACb,EAGFK,EAAG5F,UAAUoN,UAAY,SAAoB9C,GAE3C,GAAU,IAANA,EAAS,OAAO,GAEpB,IAAI/E,EAAI+E,EACJvH,EAAI,EAoBR,OAnBqB,KAAZ,KAAJwC,KACHxC,GAAK,GACLwC,KAAO,IAEU,KAAV,IAAJA,KACHxC,GAAK,EACLwC,KAAO,GAES,KAAT,GAAJA,KACHxC,GAAK,EACLwC,KAAO,GAES,KAAT,EAAJA,KACHxC,GAAK,EACLwC,KAAO,GAES,KAAT,EAAJA,IACHxC,IAEKA,CACT,EAGA6C,EAAG5F,UAAUuH,UAAY,WACvB,IAAI+C,EAAI/K,KAAKsJ,MAAMtJ,KAAKY,OAAS,GAC7BkN,EAAK9N,KAAK4N,WAAW7C,GACzB,OAA2B,IAAnB/K,KAAKY,OAAS,GAAUkN,CAClC,EAgBAzH,EAAG5F,UAAUsN,SAAW,WACtB,GAAI/N,KAAK6M,SAAU,OAAO,EAG1B,IADA,IAAIrJ,EAAI,EACCrC,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAAK,CACpC,IAAIiL,EAAIpM,KAAK6N,UAAU7N,KAAKsJ,MAAMnI,IAElC,GADAqC,GAAK4I,EACK,KAANA,EAAU,KAChB,CACA,OAAO5I,CACT,EAEA6C,EAAG5F,UAAU4M,WAAa,WACxB,OAAOnM,KAAKS,KAAK3B,KAAKgI,YAAc,EACtC,EAEA3B,EAAG5F,UAAUuN,OAAS,SAAiBC,GACrC,OAAsB,IAAlBjO,KAAKqJ,SACArJ,KAAKkO,MAAMC,MAAMF,GAAOG,MAAM,GAEhCpO,KAAK0L,OACd,EAEArF,EAAG5F,UAAU4N,SAAW,SAAmBJ,GACzC,OAAIjO,KAAKoI,MAAM6F,EAAQ,GACdjO,KAAKsO,KAAKL,GAAOG,MAAM,GAAGG,OAE5BvO,KAAK0L,OACd,EAEArF,EAAG5F,UAAU+N,MAAQ,WACnB,OAAyB,IAAlBxO,KAAKqJ,QACd,EAGAhD,EAAG5F,UAAUgO,IAAM,WACjB,OAAOzO,KAAK0L,QAAQ6C,MACtB,EAEAlI,EAAG5F,UAAU8N,KAAO,WAKlB,OAJKvO,KAAK6M,WACR7M,KAAKqJ,UAAY,GAGZrJ,IACT,EAGAqG,EAAG5F,UAAUiO,KAAO,SAAexL,GACjC,KAAOlD,KAAKY,OAASsC,EAAItC,QACvBZ,KAAKsJ,MAAMtJ,KAAKY,UAAY,EAG9B,IAAK,IAAIO,EAAI,EAAGA,EAAI+B,EAAItC,OAAQO,IAC9BnB,KAAKsJ,MAAMnI,GAAKnB,KAAKsJ,MAAMnI,GAAK+B,EAAIoG,MAAMnI,GAG5C,OAAOnB,KAAKgL,OACd,EAEA3E,EAAG5F,UAAUkO,IAAM,SAAczL,GAE/B,OADAtD,EAA0C,KAAlCI,KAAKqJ,SAAWnG,EAAImG,WACrBrJ,KAAK0O,KAAKxL,EACnB,EAGAmD,EAAG5F,UAAUmO,GAAK,SAAa1L,GAC7B,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQiD,IAAIzL,GAC/CA,EAAIwI,QAAQiD,IAAI3O,KACzB,EAEAqG,EAAG5F,UAAUoO,IAAM,SAAc3L,GAC/B,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQgD,KAAKxL,GAChDA,EAAIwI,QAAQgD,KAAK1O,KAC1B,EAGAqG,EAAG5F,UAAUqO,MAAQ,SAAgB5L,GAEnC,IAAIkJ,EAEFA,EADEpM,KAAKY,OAASsC,EAAItC,OAChBsC,EAEAlD,KAGN,IAAK,IAAImB,EAAI,EAAGA,EAAIiL,EAAExL,OAAQO,IAC5BnB,KAAKsJ,MAAMnI,GAAKnB,KAAKsJ,MAAMnI,GAAK+B,EAAIoG,MAAMnI,GAK5C,OAFAnB,KAAKY,OAASwL,EAAExL,OAETZ,KAAKgL,OACd,EAEA3E,EAAG5F,UAAUsO,KAAO,SAAe7L,GAEjC,OADAtD,EAA0C,KAAlCI,KAAKqJ,SAAWnG,EAAImG,WACrBrJ,KAAK8O,MAAM5L,EACpB,EAGAmD,EAAG5F,UAAUuO,IAAM,SAAc9L,GAC/B,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQqD,KAAK7L,GAChDA,EAAIwI,QAAQqD,KAAK/O,KAC1B,EAEAqG,EAAG5F,UAAUwO,KAAO,SAAe/L,GACjC,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQoD,MAAM5L,GACjDA,EAAIwI,QAAQoD,MAAM9O,KAC3B,EAGAqG,EAAG5F,UAAUyO,MAAQ,SAAgBhM,GAEnC,IAAIiJ,EACAC,EACApM,KAAKY,OAASsC,EAAItC,QACpBuL,EAAInM,KACJoM,EAAIlJ,IAEJiJ,EAAIjJ,EACJkJ,EAAIpM,MAGN,IAAK,IAAImB,EAAI,EAAGA,EAAIiL,EAAExL,OAAQO,IAC5BnB,KAAKsJ,MAAMnI,GAAKgL,EAAE7C,MAAMnI,GAAKiL,EAAE9C,MAAMnI,GAGvC,GAAInB,OAASmM,EACX,KAAOhL,EAAIgL,EAAEvL,OAAQO,IACnBnB,KAAKsJ,MAAMnI,GAAKgL,EAAE7C,MAAMnI,GAM5B,OAFAnB,KAAKY,OAASuL,EAAEvL,OAETZ,KAAKgL,OACd,EAEA3E,EAAG5F,UAAU0O,KAAO,SAAejM,GAEjC,OADAtD,EAA0C,KAAlCI,KAAKqJ,SAAWnG,EAAImG,WACrBrJ,KAAKkP,MAAMhM,EACpB,EAGAmD,EAAG5F,UAAU2O,IAAM,SAAclM,GAC/B,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQyD,KAAKjM,GAChDA,EAAIwI,QAAQyD,KAAKnP,KAC1B,EAEAqG,EAAG5F,UAAU4O,KAAO,SAAenM,GACjC,OAAIlD,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQwD,MAAMhM,GACjDA,EAAIwI,QAAQwD,MAAMlP,KAC3B,EAGAqG,EAAG5F,UAAU0N,MAAQ,SAAgBF,GACnCrO,EAAwB,kBAAVqO,GAAsBA,GAAS,GAE7C,IAAIqB,EAAsC,EAAxBpO,KAAKS,KAAKsM,EAAQ,IAChCsB,EAAWtB,EAAQ,GAGvBjO,KAAK2L,QAAQ2D,GAETC,EAAW,GACbD,IAIF,IAAK,IAAInO,EAAI,EAAGA,EAAImO,EAAanO,IAC/BnB,KAAKsJ,MAAMnI,GAAsB,UAAhBnB,KAAKsJ,MAAMnI,GAS9B,OALIoO,EAAW,IACbvP,KAAKsJ,MAAMnI,IAAMnB,KAAKsJ,MAAMnI,GAAM,UAAc,GAAKoO,GAIhDvP,KAAKgL,OACd,EAEA3E,EAAG5F,UAAU6N,KAAO,SAAeL,GACjC,OAAOjO,KAAK0L,QAAQyC,MAAMF,EAC5B,EAGA5H,EAAG5F,UAAU+O,KAAO,SAAeC,EAAKhH,GACtC7I,EAAsB,kBAAR6P,GAAoBA,GAAO,GAEzC,IAAIzO,EAAOyO,EAAM,GAAM,EACnBC,EAAOD,EAAM,GAUjB,OARAzP,KAAK2L,QAAQ3K,EAAM,GAGjBhB,KAAKsJ,MAAMtI,GADTyH,EACgBzI,KAAKsJ,MAAMtI,GAAQ,GAAK0O,EAExB1P,KAAKsJ,MAAMtI,KAAS,GAAK0O,GAGtC1P,KAAKgL,OACd,EAGA3E,EAAG5F,UAAU0H,KAAO,SAAejF,GACjC,IAAIM,EAkBA2I,EAAGC,EAfP,GAAsB,IAAlBpM,KAAKqJ,UAAmC,IAAjBnG,EAAImG,SAI7B,OAHArJ,KAAKqJ,SAAW,EAChB7F,EAAIxD,KAAK2P,KAAKzM,GACdlD,KAAKqJ,UAAY,EACVrJ,KAAK4L,YAGP,GAAsB,IAAlB5L,KAAKqJ,UAAmC,IAAjBnG,EAAImG,SAIpC,OAHAnG,EAAImG,SAAW,EACf7F,EAAIxD,KAAK2P,KAAKzM,GACdA,EAAImG,SAAW,EACR7F,EAAEoI,YAKP5L,KAAKY,OAASsC,EAAItC,QACpBuL,EAAInM,KACJoM,EAAIlJ,IAEJiJ,EAAIjJ,EACJkJ,EAAIpM,MAIN,IADA,IAAIsM,EAAQ,EACHnL,EAAI,EAAGA,EAAIiL,EAAExL,OAAQO,IAC5BqC,GAAkB,EAAb2I,EAAE7C,MAAMnI,KAAwB,EAAbiL,EAAE9C,MAAMnI,IAAUmL,EAC1CtM,KAAKsJ,MAAMnI,GAAS,SAAJqC,EAChB8I,EAAQ9I,IAAM,GAEhB,KAAiB,IAAV8I,GAAenL,EAAIgL,EAAEvL,OAAQO,IAClCqC,GAAkB,EAAb2I,EAAE7C,MAAMnI,IAAUmL,EACvBtM,KAAKsJ,MAAMnI,GAAS,SAAJqC,EAChB8I,EAAQ9I,IAAM,GAIhB,GADAxD,KAAKY,OAASuL,EAAEvL,OACF,IAAV0L,EACFtM,KAAKsJ,MAAMtJ,KAAKY,QAAU0L,EAC1BtM,KAAKY,cAEA,GAAIuL,IAAMnM,KACf,KAAOmB,EAAIgL,EAAEvL,OAAQO,IACnBnB,KAAKsJ,MAAMnI,GAAKgL,EAAE7C,MAAMnI,GAI5B,OAAOnB,IACT,EAGAqG,EAAG5F,UAAUmP,IAAM,SAAc1M,GAC/B,IAAI+D,EACJ,OAAqB,IAAjB/D,EAAImG,UAAoC,IAAlBrJ,KAAKqJ,UAC7BnG,EAAImG,SAAW,EACfpC,EAAMjH,KAAK6P,IAAI3M,GACfA,EAAImG,UAAY,EACTpC,GACmB,IAAjB/D,EAAImG,UAAoC,IAAlBrJ,KAAKqJ,UACpCrJ,KAAKqJ,SAAW,EAChBpC,EAAM/D,EAAI2M,IAAI7P,MACdA,KAAKqJ,SAAW,EACTpC,GAGLjH,KAAKY,OAASsC,EAAItC,OAAeZ,KAAK0L,QAAQvD,KAAKjF,GAEhDA,EAAIwI,QAAQvD,KAAKnI,KAC1B,EAGAqG,EAAG5F,UAAUkP,KAAO,SAAezM,GAEjC,GAAqB,IAAjBA,EAAImG,SAAgB,CACtBnG,EAAImG,SAAW,EACf,IAAI7F,EAAIxD,KAAKmI,KAAKjF,GAElB,OADAA,EAAImG,SAAW,EACR7F,EAAEoI,WAGX,CAAO,GAAsB,IAAlB5L,KAAKqJ,SAId,OAHArJ,KAAKqJ,SAAW,EAChBrJ,KAAKmI,KAAKjF,GACVlD,KAAKqJ,SAAW,EACTrJ,KAAK4L,YAId,IAWIO,EAAGC,EAXH/D,EAAMrI,KAAKqI,IAAInF,GAGnB,GAAY,IAARmF,EAIF,OAHArI,KAAKqJ,SAAW,EAChBrJ,KAAKY,OAAS,EACdZ,KAAKsJ,MAAM,GAAK,EACTtJ,KAKLqI,EAAM,GACR8D,EAAInM,KACJoM,EAAIlJ,IAEJiJ,EAAIjJ,EACJkJ,EAAIpM,MAIN,IADA,IAAIsM,EAAQ,EACHnL,EAAI,EAAGA,EAAIiL,EAAExL,OAAQO,IAE5BmL,GADA9I,GAAkB,EAAb2I,EAAE7C,MAAMnI,KAAwB,EAAbiL,EAAE9C,MAAMnI,IAAUmL,IAC7B,GACbtM,KAAKsJ,MAAMnI,GAAS,SAAJqC,EAElB,KAAiB,IAAV8I,GAAenL,EAAIgL,EAAEvL,OAAQO,IAElCmL,GADA9I,GAAkB,EAAb2I,EAAE7C,MAAMnI,IAAUmL,IACV,GACbtM,KAAKsJ,MAAMnI,GAAS,SAAJqC,EAIlB,GAAc,IAAV8I,GAAenL,EAAIgL,EAAEvL,QAAUuL,IAAMnM,KACvC,KAAOmB,EAAIgL,EAAEvL,OAAQO,IACnBnB,KAAKsJ,MAAMnI,GAAKgL,EAAE7C,MAAMnI,GAU5B,OANAnB,KAAKY,OAASM,KAAKQ,IAAI1B,KAAKY,OAAQO,GAEhCgL,IAAMnM,OACRA,KAAKqJ,SAAW,GAGXrJ,KAAKgL,OACd,EAGA3E,EAAG5F,UAAUoP,IAAM,SAAc3M,GAC/B,OAAOlD,KAAK0L,QAAQiE,KAAKzM,EAC3B,EA8CA,IAAI4M,EAAc,SAAsB5D,EAAMhJ,EAAK7B,GACjD,IAIIgL,EACA0D,EACAjC,EANA3B,EAAID,EAAK5C,MACT8C,EAAIlJ,EAAIoG,MACR0G,EAAI3O,EAAIiI,MACRQ,EAAI,EAIJmG,EAAY,EAAP9D,EAAE,GACP+D,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPjE,EAAE,GACPkE,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPpE,EAAE,GACPqE,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPvE,EAAE,GACPwE,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAP1E,EAAE,GACP2E,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAP7E,EAAE,GACP8E,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPhF,EAAE,GACPiF,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPnF,EAAE,GACPoF,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPtF,EAAE,GACPuF,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPzF,EAAE,GACP0F,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAP3F,EAAE,GACP4F,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAP9F,EAAE,GACP+F,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPjG,EAAE,GACPkG,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPpG,EAAE,GACPqG,EAAW,KAALD,EACNE,EAAMF,IAAO,GACbG,EAAY,EAAPvG,EAAE,GACPwG,EAAW,KAALD,EACNE,GAAMF,IAAO,GACbG,GAAY,EAAP1G,EAAE,GACP2G,GAAW,KAALD,GACNE,GAAMF,KAAO,GACbG,GAAY,EAAP7G,EAAE,GACP8G,GAAW,KAALD,GACNE,GAAMF,KAAO,GACbG,GAAY,EAAPhH,EAAE,GACPiH,GAAW,KAALD,GACNE,GAAMF,KAAO,GACbG,GAAY,EAAPnH,EAAE,GACPoH,GAAW,KAALD,GACNE,GAAMF,KAAO,GACbG,GAAY,EAAPtH,EAAE,GACPuH,GAAW,KAALD,GACNE,GAAMF,KAAO,GAEjBrS,EAAIgI,SAAW6C,EAAK7C,SAAWnG,EAAImG,SACnChI,EAAIT,OAAS,GAMb,IAAIiT,IAAQ/J,GAJZuC,EAAKnL,KAAK4S,KAAK5D,EAAK8B,IAIE,KAAa,MAFnCjC,GADAA,EAAM7O,KAAK4S,KAAK5D,EAAK+B,IACR/Q,KAAK4S,KAAK3D,EAAK6B,GAAQ,KAEU,IAAO,EACrDlI,IAFAgE,EAAK5M,KAAK4S,KAAK3D,EAAK8B,KAEPlC,IAAQ,IAAO,IAAM8D,KAAO,IAAO,EAChDA,IAAM,SAENxH,EAAKnL,KAAK4S,KAAKzD,EAAK2B,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKzD,EAAK4B,IACR/Q,KAAK4S,KAAKxD,EAAK0B,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKxD,EAAK2B,GAKpB,IAAI8B,IAAQjK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKiC,GAAQ,GAIZ,KAAa,MAFnCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKkC,GAAQ,GACvBlR,KAAK4S,KAAK3D,EAAKgC,GAAQ,KAEU,IAAO,EACrDrI,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKiC,GAAQ,IAErBrC,IAAQ,IAAO,IAAMgE,KAAO,IAAO,EAChDA,IAAM,SAEN1H,EAAKnL,KAAK4S,KAAKtD,EAAKwB,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKtD,EAAKyB,IACR/Q,KAAK4S,KAAKrD,EAAKuB,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKrD,EAAKwB,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAK8B,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAK+B,GAAQ,GACvBlR,KAAK4S,KAAKxD,EAAK6B,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAK8B,GAAQ,EAKlC,IAAI4B,IAAQlK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKoC,GAAQ,GAIZ,KAAa,MAFnCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKqC,GAAQ,GACvBrR,KAAK4S,KAAK3D,EAAKmC,GAAQ,KAEU,IAAO,EACrDxI,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKoC,GAAQ,IAErBxC,IAAQ,IAAO,IAAMiE,KAAO,IAAO,EAChDA,IAAM,SAEN3H,EAAKnL,KAAK4S,KAAKnD,EAAKqB,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKnD,EAAKsB,IACR/Q,KAAK4S,KAAKlD,EAAKoB,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKlD,EAAKqB,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAK2B,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAK4B,GAAQ,GACvBlR,KAAK4S,KAAKrD,EAAK0B,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAK2B,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKiC,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKkC,GAAQ,GACvBrR,KAAK4S,KAAKxD,EAAKgC,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKiC,GAAQ,EAKlC,IAAI0B,IAAQnK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKuC,GAAQ,GAIZ,KAAa,MAFnC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKwC,GAAQ,GACvBxR,KAAK4S,KAAK3D,EAAKsC,GAAQ,KAEU,IAAO,EACrD3I,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKuC,GAAQ,IAErB3C,IAAQ,IAAO,IAAMkE,KAAO,IAAO,EAChDA,IAAM,SAEN5H,EAAKnL,KAAK4S,KAAKhD,EAAKkB,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKhD,EAAKmB,IACR/Q,KAAK4S,KAAK/C,EAAKiB,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAK/C,EAAKkB,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAKwB,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAKyB,GAAQ,GACvBlR,KAAK4S,KAAKlD,EAAKuB,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAKwB,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAK8B,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAK+B,GAAQ,GACvBrR,KAAK4S,KAAKrD,EAAK6B,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAK8B,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKoC,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKqC,GAAQ,GACvBxR,KAAK4S,KAAKxD,EAAKmC,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKoC,GAAQ,EAKlC,IAAIwB,IAAQpK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAK0C,GAAQ,GAIZ,KAAa,MAFnC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAK2C,IAAQ,GACvB3R,KAAK4S,KAAK3D,EAAKyC,GAAQ,KAEU,IAAO,EACrD9I,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAK0C,IAAQ,IAErB9C,IAAQ,IAAO,IAAMmE,KAAO,IAAO,EAChDA,IAAM,SAEN7H,EAAKnL,KAAK4S,KAAK7C,EAAKe,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAK7C,EAAKgB,IACR/Q,KAAK4S,KAAK5C,EAAKc,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAK5C,EAAKe,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAKqB,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAKsB,GAAQ,GACvBlR,KAAK4S,KAAK/C,EAAKoB,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAKqB,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAK2B,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAK4B,GAAQ,GACvBrR,KAAK4S,KAAKlD,EAAK0B,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAK2B,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAKiC,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAKkC,GAAQ,GACvBxR,KAAK4S,KAAKrD,EAAKgC,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAKiC,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKuC,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKwC,IAAQ,GACvB3R,KAAK4S,KAAKxD,EAAKsC,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKuC,IAAQ,EAKlC,IAAIsB,IAAQrK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAK6C,IAAQ,GAIZ,KAAa,MAFnChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAK8C,IAAQ,GACvB9R,KAAK4S,KAAK3D,EAAK4C,IAAQ,KAEU,IAAO,EACrDjJ,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAK6C,IAAQ,IAErBjD,IAAQ,IAAO,IAAMoE,KAAO,IAAO,EAChDA,IAAM,SAEN9H,EAAKnL,KAAK4S,KAAK1C,EAAKY,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAK1C,EAAKa,IACR/Q,KAAK4S,KAAKzC,EAAKW,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKzC,EAAKY,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKkB,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKmB,GAAQ,GACvBlR,KAAK4S,KAAK5C,EAAKiB,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKkB,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAKwB,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAKyB,GAAQ,GACvBrR,KAAK4S,KAAK/C,EAAKuB,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAKwB,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAK8B,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAK+B,GAAQ,GACvBxR,KAAK4S,KAAKlD,EAAK6B,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAK8B,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAKoC,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAKqC,IAAQ,GACvB3R,KAAK4S,KAAKrD,EAAKmC,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAKoC,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAK0C,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAK2C,IAAQ,GACvB9R,KAAK4S,KAAKxD,EAAKyC,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAK0C,IAAQ,EAKlC,IAAIoB,IAAQtK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKgD,IAAQ,GAIZ,KAAa,MAFnCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKiD,IAAQ,GACvBjS,KAAK4S,KAAK3D,EAAK+C,IAAQ,KAEU,IAAO,EACrDpJ,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKgD,IAAQ,IAErBpD,IAAQ,IAAO,IAAMqE,KAAO,IAAO,EAChDA,IAAM,SAEN/H,EAAKnL,KAAK4S,KAAKvC,EAAKS,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKvC,EAAKU,IACR/Q,KAAK4S,KAAKtC,EAAKQ,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKtC,EAAKS,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKe,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKgB,GAAQ,GACvBlR,KAAK4S,KAAKzC,EAAKc,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKe,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKqB,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKsB,GAAQ,GACvBrR,KAAK4S,KAAK5C,EAAKoB,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKqB,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAK2B,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAK4B,GAAQ,GACvBxR,KAAK4S,KAAK/C,EAAK0B,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAK2B,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAKiC,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAKkC,IAAQ,GACvB3R,KAAK4S,KAAKlD,EAAKgC,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAKiC,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAKuC,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAKwC,IAAQ,GACvB9R,KAAK4S,KAAKrD,EAAKsC,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAKuC,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAK6C,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAK8C,IAAQ,GACvBjS,KAAK4S,KAAKxD,EAAK4C,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAK6C,IAAQ,EAKlC,IAAIkB,IAAQvK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKmD,IAAQ,GAIZ,KAAa,MAFnCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKoD,IAAQ,GACvBpS,KAAK4S,KAAK3D,EAAKkD,IAAQ,KAEU,IAAO,EACrDvJ,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKmD,IAAQ,IAErBvD,IAAQ,IAAO,IAAMsE,KAAO,IAAO,EAChDA,IAAM,SAENhI,EAAKnL,KAAK4S,KAAKpC,EAAKM,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKpC,EAAKO,IACR/Q,KAAK4S,KAAKnC,EAAKK,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKnC,EAAKM,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKY,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKa,GAAQ,GACvBlR,KAAK4S,KAAKtC,EAAKW,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKY,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKkB,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKmB,GAAQ,GACvBrR,KAAK4S,KAAKzC,EAAKiB,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKkB,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKwB,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKyB,GAAQ,GACvBxR,KAAK4S,KAAK5C,EAAKuB,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKwB,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAK8B,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAK+B,IAAQ,GACvB3R,KAAK4S,KAAK/C,EAAK6B,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAK8B,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAKoC,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAKqC,IAAQ,GACvB9R,KAAK4S,KAAKlD,EAAKmC,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAKoC,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAK0C,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAK2C,IAAQ,GACvBjS,KAAK4S,KAAKrD,EAAKyC,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAK0C,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKgD,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKiD,IAAQ,GACvBpS,KAAK4S,KAAKxD,EAAK+C,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKgD,IAAQ,EAKlC,IAAIgB,IAAQxK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKsD,IAAQ,GAIZ,KAAa,MAFnCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAKuD,IAAQ,GACvBvS,KAAK4S,KAAK3D,EAAKqD,IAAQ,KAEU,IAAO,EACrD1J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKsD,IAAQ,IAErB1D,IAAQ,IAAO,IAAMuE,KAAO,IAAO,EAChDA,IAAM,SAENjI,EAAKnL,KAAK4S,KAAKjC,EAAKG,GAEpBjC,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKI,IACR/Q,KAAK4S,KAAKhC,EAAKE,GAAQ,EACpClE,EAAK5M,KAAK4S,KAAKhC,EAAKG,GACpB5F,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKS,GAAQ,EAElCpC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKU,GAAQ,GACvBlR,KAAK4S,KAAKnC,EAAKQ,GAAQ,EACpCrE,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKS,GAAQ,EAClC/F,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKe,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKgB,GAAQ,GACvBrR,KAAK4S,KAAKtC,EAAKc,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKe,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKqB,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKsB,GAAQ,GACvBxR,KAAK4S,KAAKzC,EAAKoB,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKqB,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAK2B,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAK4B,IAAQ,GACvB3R,KAAK4S,KAAK5C,EAAK0B,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAK2B,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAKiC,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAKkC,IAAQ,GACvB9R,KAAK4S,KAAK/C,EAAKgC,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAKiC,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAKuC,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAKwC,IAAQ,GACvBjS,KAAK4S,KAAKlD,EAAKsC,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAKuC,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAK6C,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAK8C,IAAQ,GACvBpS,KAAK4S,KAAKrD,EAAK4C,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAK6C,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKmD,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKoD,IAAQ,GACvBvS,KAAK4S,KAAKxD,EAAKkD,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKmD,IAAQ,EAKlC,IAAIc,IAAQzK,GAJZuC,EAAMA,EAAKnL,KAAK4S,KAAK5D,EAAKyD,IAAQ,GAIZ,KAAa,MAFnC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK5D,EAAK0D,IAAQ,GACvB1S,KAAK4S,KAAK3D,EAAKwD,IAAQ,KAEU,IAAO,EACrD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK3D,EAAKyD,IAAQ,IAErB7D,IAAQ,IAAO,IAAMwE,KAAO,IAAO,EAChDA,IAAM,SAENlI,EAAKnL,KAAK4S,KAAKjC,EAAKM,GAEpBpC,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKO,IACRlR,KAAK4S,KAAKhC,EAAKK,GAAQ,EACpCrE,EAAK5M,KAAK4S,KAAKhC,EAAKM,GACpB/F,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKY,GAAQ,EAElCvC,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKa,GAAQ,GACvBrR,KAAK4S,KAAKnC,EAAKW,GAAQ,EACpCxE,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKY,GAAQ,EAClClG,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKkB,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKmB,GAAQ,GACvBxR,KAAK4S,KAAKtC,EAAKiB,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKkB,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKwB,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKyB,IAAQ,GACvB3R,KAAK4S,KAAKzC,EAAKuB,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKwB,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAK8B,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAK+B,IAAQ,GACvB9R,KAAK4S,KAAK5C,EAAK6B,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAK8B,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAKoC,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAKqC,IAAQ,GACvBjS,KAAK4S,KAAK/C,EAAKmC,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAKoC,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAK0C,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAK2C,IAAQ,GACvBpS,KAAK4S,KAAKlD,EAAKyC,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAK0C,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAKgD,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAKiD,IAAQ,GACvBvS,KAAK4S,KAAKrD,EAAK+C,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAKgD,IAAQ,EAKlC,IAAIe,IAAS1K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKzD,EAAKsD,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKzD,EAAKuD,IAAQ,GACvB1S,KAAK4S,KAAKxD,EAAKqD,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKxD,EAAKsD,IAAQ,IAErB7D,IAAQ,IAAO,IAAMyE,KAAQ,IAAO,EACjDA,IAAO,SAEPnI,EAAKnL,KAAK4S,KAAKjC,EAAKS,GAEpBvC,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKU,IACRrR,KAAK4S,KAAKhC,EAAKQ,GAAQ,EACpCxE,EAAK5M,KAAK4S,KAAKhC,EAAKS,GACpBlG,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKe,GAAQ,EAElC1C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKgB,GAAQ,GACvBxR,KAAK4S,KAAKnC,EAAKc,GAAQ,EACpC3E,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKe,GAAQ,EAClCrG,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKqB,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKsB,IAAQ,GACvB3R,KAAK4S,KAAKtC,EAAKoB,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKqB,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAK2B,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAK4B,IAAQ,GACvB9R,KAAK4S,KAAKzC,EAAK0B,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAK2B,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKiC,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKkC,IAAQ,GACvBjS,KAAK4S,KAAK5C,EAAKgC,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKiC,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAKuC,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAKwC,IAAQ,GACvBpS,KAAK4S,KAAK/C,EAAKsC,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAKuC,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAK6C,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAK8C,IAAQ,GACvBvS,KAAK4S,KAAKlD,EAAK4C,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAK6C,IAAQ,EAKlC,IAAIgB,IAAS3K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKtD,EAAKmD,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKtD,EAAKoD,IAAQ,GACvB1S,KAAK4S,KAAKrD,EAAKkD,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKrD,EAAKmD,IAAQ,IAErB7D,IAAQ,IAAO,IAAM0E,KAAQ,IAAO,EACjDA,IAAO,SAEPpI,EAAKnL,KAAK4S,KAAKjC,EAAKY,GAEpB1C,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKa,IACRxR,KAAK4S,KAAKhC,EAAKW,GAAQ,EACpC3E,EAAK5M,KAAK4S,KAAKhC,EAAKY,GACpBrG,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKkB,GAAQ,EAElC7C,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKmB,IAAQ,GACvB3R,KAAK4S,KAAKnC,EAAKiB,GAAQ,EACpC9E,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKkB,IAAQ,EAClCxG,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKwB,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKyB,IAAQ,GACvB9R,KAAK4S,KAAKtC,EAAKuB,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKwB,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAK8B,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAK+B,IAAQ,GACvBjS,KAAK4S,KAAKzC,EAAK6B,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAK8B,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKoC,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKqC,IAAQ,GACvBpS,KAAK4S,KAAK5C,EAAKmC,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKoC,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAK0C,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAK2C,IAAQ,GACvBvS,KAAK4S,KAAK/C,EAAKyC,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAK0C,IAAQ,EAKlC,IAAIiB,IAAS5K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKnD,EAAKgD,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKnD,EAAKiD,IAAQ,GACvB1S,KAAK4S,KAAKlD,EAAK+C,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKlD,EAAKgD,IAAQ,IAErB7D,IAAQ,IAAO,IAAM2E,KAAQ,IAAO,EACjDA,IAAO,SAEPrI,EAAKnL,KAAK4S,KAAKjC,EAAKe,GAEpB7C,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKgB,KACR3R,KAAK4S,KAAKhC,EAAKc,GAAQ,EACpC9E,EAAK5M,KAAK4S,KAAKhC,EAAKe,IACpBxG,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKqB,IAAQ,EAElChD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKsB,IAAQ,GACvB9R,KAAK4S,KAAKnC,EAAKoB,IAAQ,EACpCjF,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKqB,IAAQ,EAClC3G,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAK2B,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAK4B,IAAQ,GACvBjS,KAAK4S,KAAKtC,EAAK0B,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAK2B,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKiC,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKkC,IAAQ,GACvBpS,KAAK4S,KAAKzC,EAAKgC,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKiC,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAKuC,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAKwC,IAAQ,GACvBvS,KAAK4S,KAAK5C,EAAKsC,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAKuC,IAAQ,EAKlC,IAAIkB,IAAS7K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKhD,EAAK6C,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKhD,EAAK8C,IAAQ,GACvB1S,KAAK4S,KAAK/C,EAAK4C,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK/C,EAAK6C,IAAQ,IAErB7D,IAAQ,IAAO,IAAM4E,KAAQ,IAAO,EACjDA,IAAO,SAEPtI,EAAKnL,KAAK4S,KAAKjC,EAAKkB,IAEpBhD,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKmB,KACR9R,KAAK4S,KAAKhC,EAAKiB,IAAQ,EACpCjF,EAAK5M,KAAK4S,KAAKhC,EAAKkB,IACpB3G,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKwB,IAAQ,EAElCnD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKyB,IAAQ,GACvBjS,KAAK4S,KAAKnC,EAAKuB,IAAQ,EACpCpF,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKwB,IAAQ,EAClC9G,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAK8B,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAK+B,IAAQ,GACvBpS,KAAK4S,KAAKtC,EAAK6B,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAK8B,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKoC,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKqC,IAAQ,GACvBvS,KAAK4S,KAAKzC,EAAKmC,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKoC,IAAQ,EAKlC,IAAImB,IAAS9K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAK7C,EAAK0C,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK7C,EAAK2C,IAAQ,GACvB1S,KAAK4S,KAAK5C,EAAKyC,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAK5C,EAAK0C,IAAQ,IAErB7D,IAAQ,IAAO,IAAM6E,KAAQ,IAAO,EACjDA,IAAO,SAEPvI,EAAKnL,KAAK4S,KAAKjC,EAAKqB,IAEpBnD,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKsB,KACRjS,KAAK4S,KAAKhC,EAAKoB,IAAQ,EACpCpF,EAAK5M,KAAK4S,KAAKhC,EAAKqB,IACpB9G,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAK2B,IAAQ,EAElCtD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAK4B,IAAQ,GACvBpS,KAAK4S,KAAKnC,EAAK0B,IAAQ,EACpCvF,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAK2B,IAAQ,EAClCjH,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKiC,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKkC,IAAQ,GACvBvS,KAAK4S,KAAKtC,EAAKgC,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKiC,IAAQ,EAKlC,IAAIoB,IAAS/K,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAK1C,EAAKuC,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAK1C,EAAKwC,IAAQ,GACvB1S,KAAK4S,KAAKzC,EAAKsC,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKzC,EAAKuC,IAAQ,IAErB7D,IAAQ,IAAO,IAAM8E,KAAQ,IAAO,EACjDA,IAAO,SAEPxI,EAAKnL,KAAK4S,KAAKjC,EAAKwB,IAEpBtD,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAKyB,KACRpS,KAAK4S,KAAKhC,EAAKuB,IAAQ,EACpCvF,EAAK5M,KAAK4S,KAAKhC,EAAKwB,IACpBjH,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAK8B,IAAQ,EAElCzD,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAK+B,IAAQ,GACvBvS,KAAK4S,KAAKnC,EAAK6B,IAAQ,EACpC1F,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAK8B,IAAQ,EAKlC,IAAIqB,IAAShL,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKvC,EAAKoC,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKvC,EAAKqC,IAAQ,GACvB1S,KAAK4S,KAAKtC,EAAKmC,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKtC,EAAKoC,IAAQ,IAErB7D,IAAQ,IAAO,IAAM+E,KAAQ,IAAO,EACjDA,IAAO,SAEPzI,EAAKnL,KAAK4S,KAAKjC,EAAK2B,IAEpBzD,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAK4B,KACRvS,KAAK4S,KAAKhC,EAAK0B,IAAQ,EACpC1F,EAAK5M,KAAK4S,KAAKhC,EAAK2B,IAKpB,IAAIsB,IAASjL,GAJbuC,EAAMA,EAAKnL,KAAK4S,KAAKpC,EAAKiC,IAAQ,GAIX,KAAa,MAFpC5D,GADAA,EAAOA,EAAM7O,KAAK4S,KAAKpC,EAAKkC,IAAQ,GACvB1S,KAAK4S,KAAKnC,EAAKgC,IAAQ,KAEW,IAAO,EACtD7J,IAFAgE,EAAMA,EAAK5M,KAAK4S,KAAKnC,EAAKiC,IAAQ,IAErB7D,IAAQ,IAAO,IAAMgF,KAAQ,IAAO,EACjDA,IAAO,SAMP,IAAIC,IAASlL,GAJbuC,EAAKnL,KAAK4S,KAAKjC,EAAK8B,KAIG,KAAa,MAFpC5D,GADAA,EAAM7O,KAAK4S,KAAKjC,EAAK+B,KACR1S,KAAK4S,KAAKhC,EAAK6B,IAAQ,KAEW,IAAO,EA0BtD,OAzBA7J,IAFAgE,EAAK5M,KAAK4S,KAAKhC,EAAK8B,MAEP7D,IAAQ,IAAO,IAAMiF,KAAQ,IAAO,EACjDA,IAAO,SACPhF,EAAE,GAAK6D,GACP7D,EAAE,GAAK+D,GACP/D,EAAE,GAAKgE,GACPhE,EAAE,GAAKiE,GACPjE,EAAE,GAAKkE,GACPlE,EAAE,GAAKmE,GACPnE,EAAE,GAAKoE,GACPpE,EAAE,GAAKqE,GACPrE,EAAE,GAAKsE,GACPtE,EAAE,GAAKuE,GACPvE,EAAE,IAAMwE,GACRxE,EAAE,IAAMyE,GACRzE,EAAE,IAAM0E,GACR1E,EAAE,IAAM2E,GACR3E,EAAE,IAAM4E,GACR5E,EAAE,IAAM6E,GACR7E,EAAE,IAAM8E,GACR9E,EAAE,IAAM+E,GACR/E,EAAE,IAAMgF,GACE,IAANlL,IACFkG,EAAE,IAAMlG,EACRzI,EAAIT,UAECS,CACT,EAgDA,SAAS4T,EAAY/I,EAAMhJ,EAAK7B,GAE9B,OADW,IAAI6T,GACHC,KAAKjJ,EAAMhJ,EAAK7B,EAC9B,CAqBA,SAAS6T,EAAME,EAAGC,GAChBrV,KAAKoV,EAAIA,EACTpV,KAAKqV,EAAIA,CACX,CAxEKnU,KAAK4S,OACRhE,EAAc7D,GAiDhB5F,EAAG5F,UAAU6U,MAAQ,SAAgBpS,EAAK7B,GACxC,IAAI4F,EACA3D,EAAMtD,KAAKY,OAASsC,EAAItC,OAW5B,OATEqG,EADkB,KAAhBjH,KAAKY,QAAgC,KAAfsC,EAAItC,OACtBkP,EAAY9P,KAAMkD,EAAK7B,GACpBiC,EAAM,GACT2I,EAAWjM,KAAMkD,EAAK7B,GACnBiC,EAAM,KArDnB,SAAmB4I,EAAMhJ,EAAK7B,GAC5BA,EAAIgI,SAAWnG,EAAImG,SAAW6C,EAAK7C,SACnChI,EAAIT,OAASsL,EAAKtL,OAASsC,EAAItC,OAI/B,IAFA,IAAI0L,EAAQ,EACRiJ,EAAU,EACLrO,EAAI,EAAGA,EAAI7F,EAAIT,OAAS,EAAGsG,IAAK,CAGvC,IAAIqF,EAASgJ,EACbA,EAAU,EAGV,IAFA,IAAI/I,EAAgB,SAARF,EACRG,EAAOvL,KAAKD,IAAIiG,EAAGhE,EAAItC,OAAS,GAC3BkC,EAAI5B,KAAKQ,IAAI,EAAGwF,EAAIgF,EAAKtL,OAAS,GAAIkC,GAAK2J,EAAM3J,IAAK,CAC7D,IAAI3B,EAAI+F,EAAIpE,EAGRU,GAFoB,EAAhB0I,EAAK5C,MAAMnI,KACI,EAAf+B,EAAIoG,MAAMxG,IAGduJ,EAAS,SAAJ7I,EAGTgJ,EAAa,UADbH,EAAMA,EAAKG,EAAS,GAIpB+I,IAFAhJ,GAHAA,EAAUA,GAAW/I,EAAI,SAAa,GAAM,IAGxB6I,IAAO,IAAO,KAEZ,GACtBE,GAAU,QACZ,CACAlL,EAAIiI,MAAMpC,GAAKsF,EACfF,EAAQC,EACRA,EAASgJ,CACX,CAOA,OANc,IAAVjJ,EACFjL,EAAIiI,MAAMpC,GAAKoF,EAEfjL,EAAIT,SAGCS,EAAI2J,OACb,CAeUwK,CAASxV,KAAMkD,EAAK7B,GAEpB4T,EAAWjV,KAAMkD,EAAK7B,GAGvB4F,CACT,EAUAiO,EAAKzU,UAAUgV,QAAU,SAAkBC,GAGzC,IAFA,IAAI1P,EAAI,IAAI3F,MAAMqV,GACdnQ,EAAIc,EAAG5F,UAAUmN,WAAW8H,GAAK,EAC5BvU,EAAI,EAAGA,EAAIuU,EAAGvU,IACrB6E,EAAE7E,GAAKnB,KAAK2V,OAAOxU,EAAGoE,EAAGmQ,GAG3B,OAAO1P,CACT,EAGAkP,EAAKzU,UAAUkV,OAAS,SAAiBP,EAAG7P,EAAGmQ,GAC7C,GAAU,IAANN,GAAWA,IAAMM,EAAI,EAAG,OAAON,EAGnC,IADA,IAAIQ,EAAK,EACAzU,EAAI,EAAGA,EAAIoE,EAAGpE,IACrByU,IAAW,EAAJR,IAAW7P,EAAIpE,EAAI,EAC1BiU,IAAM,EAGR,OAAOQ,CACT,EAIAV,EAAKzU,UAAUmD,QAAU,SAAkBiS,EAAKC,EAAKC,EAAKC,EAAMC,EAAMP,GACpE,IAAK,IAAIvU,EAAI,EAAGA,EAAIuU,EAAGvU,IACrB6U,EAAK7U,GAAK2U,EAAID,EAAI1U,IAClB8U,EAAK9U,GAAK4U,EAAIF,EAAI1U,GAEtB,EAEA+T,EAAKzU,UAAUyV,UAAY,SAAoBJ,EAAKC,EAAKC,EAAMC,EAAMP,EAAGG,GACtE7V,KAAK4D,QAAQiS,EAAKC,EAAKC,EAAKC,EAAMC,EAAMP,GAExC,IAAK,IAAI3P,EAAI,EAAGA,EAAI2P,EAAG3P,IAAM,EAM3B,IALA,IAAIR,EAAIQ,GAAK,EAEToQ,EAAQjV,KAAKkV,IAAI,EAAIlV,KAAKmV,GAAK9Q,GAC/B+Q,EAAQpV,KAAKqV,IAAI,EAAIrV,KAAKmV,GAAK9Q,GAE1B6B,EAAI,EAAGA,EAAIsO,EAAGtO,GAAK7B,EAI1B,IAHA,IAAIiR,EAASL,EACTM,EAASH,EAEJxT,EAAI,EAAGA,EAAIiD,EAAGjD,IAAK,CAC1B,IAAI4T,EAAKV,EAAK5O,EAAItE,GACd6T,EAAKV,EAAK7O,EAAItE,GAEd8T,EAAKZ,EAAK5O,EAAItE,EAAIiD,GAClB8Q,EAAKZ,EAAK7O,EAAItE,EAAIiD,GAElB+Q,EAAKN,EAASI,EAAKH,EAASI,EAEhCA,EAAKL,EAASK,EAAKJ,EAASG,EAC5BA,EAAKE,EAELd,EAAK5O,EAAItE,GAAK4T,EAAKE,EACnBX,EAAK7O,EAAItE,GAAK6T,EAAKE,EAEnBb,EAAK5O,EAAItE,EAAIiD,GAAK2Q,EAAKE,EACvBX,EAAK7O,EAAItE,EAAIiD,GAAK4Q,EAAKE,EAGnB/T,IAAMyC,IACRuR,EAAKX,EAAQK,EAASF,EAAQG,EAE9BA,EAASN,EAAQM,EAASH,EAAQE,EAClCA,EAASM,EAEb,CAGN,EAEA5B,EAAKzU,UAAUsW,YAAc,SAAsBC,EAAGC,GACpD,IAAIvB,EAAqB,EAAjBxU,KAAKQ,IAAIuV,EAAGD,GAChBE,EAAU,EAAJxB,EACNvU,EAAI,EACR,IAAKuU,EAAIA,EAAI,EAAI,EAAGA,EAAGA,KAAU,EAC/BvU,IAGF,OAAO,GAAKA,EAAI,EAAI+V,CACtB,EAEAhC,EAAKzU,UAAU0W,UAAY,SAAoBrB,EAAKC,EAAKL,GACvD,KAAIA,GAAK,GAET,IAAK,IAAIvU,EAAI,EAAGA,EAAIuU,EAAI,EAAGvU,IAAK,CAC9B,IAAI6E,EAAI8P,EAAI3U,GAEZ2U,EAAI3U,GAAK2U,EAAIJ,EAAIvU,EAAI,GACrB2U,EAAIJ,EAAIvU,EAAI,GAAK6E,EAEjBA,EAAI+P,EAAI5U,GAER4U,EAAI5U,IAAM4U,EAAIL,EAAIvU,EAAI,GACtB4U,EAAIL,EAAIvU,EAAI,IAAM6E,CACpB,CACF,EAEAkP,EAAKzU,UAAU2W,aAAe,SAAuBC,EAAI3B,GAEvD,IADA,IAAIpJ,EAAQ,EACHnL,EAAI,EAAGA,EAAIuU,EAAI,EAAGvU,IAAK,CAC9B,IAAI4J,EAAoC,KAAhC7J,KAAKoW,MAAMD,EAAG,EAAIlW,EAAI,GAAKuU,GACjCxU,KAAKoW,MAAMD,EAAG,EAAIlW,GAAKuU,GACvBpJ,EAEF+K,EAAGlW,GAAS,SAAJ4J,EAGNuB,EADEvB,EAAI,SACE,EAEAA,EAAI,SAAY,CAE5B,CAEA,OAAOsM,CACT,EAEAnC,EAAKzU,UAAU8W,WAAa,SAAqBF,EAAI/T,EAAKwS,EAAKJ,GAE7D,IADA,IAAIpJ,EAAQ,EACHnL,EAAI,EAAGA,EAAImC,EAAKnC,IACvBmL,GAAyB,EAAR+K,EAAGlW,GAEpB2U,EAAI,EAAI3U,GAAa,KAARmL,EAAgBA,KAAkB,GAC/CwJ,EAAI,EAAI3U,EAAI,GAAa,KAARmL,EAAgBA,KAAkB,GAIrD,IAAKnL,EAAI,EAAImC,EAAKnC,EAAIuU,IAAKvU,EACzB2U,EAAI3U,GAAK,EAGXvB,EAAiB,IAAV0M,GACP1M,EAA6B,MAAb,KAAR0M,GACV,EAEA4I,EAAKzU,UAAU+W,KAAO,SAAe9B,GAEnC,IADA,IAAI+B,EAAK,IAAIpX,MAAMqV,GACVvU,EAAI,EAAGA,EAAIuU,EAAGvU,IACrBsW,EAAGtW,GAAK,EAGV,OAAOsW,CACT,EAEAvC,EAAKzU,UAAU0U,KAAO,SAAeC,EAAGC,EAAGhU,GACzC,IAAIqU,EAAI,EAAI1V,KAAK+W,YAAY3B,EAAExU,OAAQyU,EAAEzU,QAErCiV,EAAM7V,KAAKyV,QAAQC,GAEnBgC,EAAI1X,KAAKwX,KAAK9B,GAEdI,EAAM,IAAIzV,MAAMqV,GAChBiC,EAAO,IAAItX,MAAMqV,GACjBkC,EAAO,IAAIvX,MAAMqV,GAEjBmC,EAAO,IAAIxX,MAAMqV,GACjBoC,EAAQ,IAAIzX,MAAMqV,GAClBqC,EAAQ,IAAI1X,MAAMqV,GAElBsC,EAAO3W,EAAIiI,MACf0O,EAAKpX,OAAS8U,EAEd1V,KAAKuX,WAAWnC,EAAE9L,MAAO8L,EAAExU,OAAQkV,EAAKJ,GACxC1V,KAAKuX,WAAWlC,EAAE/L,MAAO+L,EAAEzU,OAAQiX,EAAMnC,GAEzC1V,KAAKkW,UAAUJ,EAAK4B,EAAGC,EAAMC,EAAMlC,EAAGG,GACtC7V,KAAKkW,UAAU2B,EAAMH,EAAGI,EAAOC,EAAOrC,EAAGG,GAEzC,IAAK,IAAI1U,EAAI,EAAGA,EAAIuU,EAAGvU,IAAK,CAC1B,IAAI2V,EAAKa,EAAKxW,GAAK2W,EAAM3W,GAAKyW,EAAKzW,GAAK4W,EAAM5W,GAC9CyW,EAAKzW,GAAKwW,EAAKxW,GAAK4W,EAAM5W,GAAKyW,EAAKzW,GAAK2W,EAAM3W,GAC/CwW,EAAKxW,GAAK2V,CACZ,CASA,OAPA9W,KAAKmX,UAAUQ,EAAMC,EAAMlC,GAC3B1V,KAAKkW,UAAUyB,EAAMC,EAAMI,EAAMN,EAAGhC,EAAGG,GACvC7V,KAAKmX,UAAUa,EAAMN,EAAGhC,GACxB1V,KAAKoX,aAAaY,EAAMtC,GAExBrU,EAAIgI,SAAW+L,EAAE/L,SAAWgM,EAAEhM,SAC9BhI,EAAIT,OAASwU,EAAExU,OAASyU,EAAEzU,OACnBS,EAAI2J,OACb,EAGA3E,EAAG5F,UAAU4J,IAAM,SAAcnH,GAC/B,IAAI7B,EAAM,IAAIgF,EAAG,MAEjB,OADAhF,EAAIiI,MAAQ,IAAIjJ,MAAML,KAAKY,OAASsC,EAAItC,QACjCZ,KAAKsV,MAAMpS,EAAK7B,EACzB,EAGAgF,EAAG5F,UAAUwX,KAAO,SAAe/U,GACjC,IAAI7B,EAAM,IAAIgF,EAAG,MAEjB,OADAhF,EAAIiI,MAAQ,IAAIjJ,MAAML,KAAKY,OAASsC,EAAItC,QACjCqU,EAAWjV,KAAMkD,EAAK7B,EAC/B,EAGAgF,EAAG5F,UAAUqT,KAAO,SAAe5Q,GACjC,OAAOlD,KAAK0L,QAAQ4J,MAAMpS,EAAKlD,KACjC,EAEAqG,EAAG5F,UAAU4K,MAAQ,SAAgBnI,GACnCtD,EAAsB,kBAARsD,GACdtD,EAAOsD,EAAM,UAIb,IADA,IAAIoJ,EAAQ,EACHnL,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAAK,CACpC,IAAI4J,GAAqB,EAAhB/K,KAAKsJ,MAAMnI,IAAU+B,EAC1BmJ,GAAU,SAAJtB,IAA0B,SAARuB,GAC5BA,IAAU,GACVA,GAAUvB,EAAI,SAAa,EAE3BuB,GAASD,IAAO,GAChBrM,KAAKsJ,MAAMnI,GAAU,SAALkL,CAClB,CAOA,OALc,IAAVC,IACFtM,KAAKsJ,MAAMnI,GAAKmL,EAChBtM,KAAKY,UAGAZ,IACT,EAEAqG,EAAG5F,UAAUyX,KAAO,SAAehV,GACjC,OAAOlD,KAAK0L,QAAQL,MAAMnI,EAC5B,EAGAmD,EAAG5F,UAAU0X,IAAM,WACjB,OAAOnY,KAAKqK,IAAIrK,KAClB,EAGAqG,EAAG5F,UAAU2X,KAAO,WAClB,OAAOpY,KAAK8T,KAAK9T,KAAK0L,QACxB,EAGArF,EAAG5F,UAAU8K,IAAM,SAAcrI,GAC/B,IAAI6H,EAxxCN,SAAqB7H,GAGnB,IAFA,IAAI6H,EAAI,IAAI1K,MAAM6C,EAAI8E,aAEbyH,EAAM,EAAGA,EAAM1E,EAAEnK,OAAQ6O,IAAO,CACvC,IAAIzO,EAAOyO,EAAM,GAAM,EACnBC,EAAOD,EAAM,GAEjB1E,EAAE0E,IAAQvM,EAAIoG,MAAMtI,GAAQ,GAAK0O,KAAWA,CAC9C,CAEA,OAAO3E,CACT,CA6wCUsN,CAAWnV,GACnB,GAAiB,IAAb6H,EAAEnK,OAAc,OAAO,IAAIyF,EAAG,GAIlC,IADA,IAAIY,EAAMjH,KACDmB,EAAI,EAAGA,EAAI4J,EAAEnK,QACP,IAATmK,EAAE5J,GADsBA,IAAK8F,EAAMA,EAAIkR,OAI7C,KAAMhX,EAAI4J,EAAEnK,OACV,IAAK,IAAI4M,EAAIvG,EAAIkR,MAAOhX,EAAI4J,EAAEnK,OAAQO,IAAKqM,EAAIA,EAAE2K,MAClC,IAATpN,EAAE5J,KAEN8F,EAAMA,EAAIoD,IAAImD,IAIlB,OAAOvG,CACT,EAGAZ,EAAG5F,UAAU6X,OAAS,SAAiBzQ,GACrCjI,EAAuB,kBAATiI,GAAqBA,GAAQ,GAC3C,IAGI1G,EAHAqC,EAAIqE,EAAO,GACX9B,GAAK8B,EAAOrE,GAAK,GACjB+U,EAAa,WAAe,GAAK/U,GAAQ,GAAKA,EAGlD,GAAU,IAANA,EAAS,CACX,IAAI8I,EAAQ,EAEZ,IAAKnL,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAAK,CAChC,IAAIqX,EAAWxY,KAAKsJ,MAAMnI,GAAKoX,EAC3BzO,GAAsB,EAAhB9J,KAAKsJ,MAAMnI,IAAUqX,GAAahV,EAC5CxD,KAAKsJ,MAAMnI,GAAK2I,EAAIwC,EACpBA,EAAQkM,IAAc,GAAKhV,CAC7B,CAEI8I,IACFtM,KAAKsJ,MAAMnI,GAAKmL,EAChBtM,KAAKY,SAET,CAEA,GAAU,IAANmF,EAAS,CACX,IAAK5E,EAAInB,KAAKY,OAAS,EAAGO,GAAK,EAAGA,IAChCnB,KAAKsJ,MAAMnI,EAAI4E,GAAK/F,KAAKsJ,MAAMnI,GAGjC,IAAKA,EAAI,EAAGA,EAAI4E,EAAG5E,IACjBnB,KAAKsJ,MAAMnI,GAAK,EAGlBnB,KAAKY,QAAUmF,CACjB,CAEA,OAAO/F,KAAKgL,OACd,EAEA3E,EAAG5F,UAAUgY,MAAQ,SAAgB5Q,GAGnC,OADAjI,EAAyB,IAAlBI,KAAKqJ,UACLrJ,KAAKsY,OAAOzQ,EACrB,EAKAxB,EAAG5F,UAAUiN,OAAS,SAAiB7F,EAAM6Q,EAAMC,GAEjD,IAAIC,EADJhZ,EAAuB,kBAATiI,GAAqBA,GAAQ,GAGzC+Q,EADEF,GACGA,EAAQA,EAAO,IAAO,GAEvB,EAGN,IAAIlV,EAAIqE,EAAO,GACX9B,EAAI7E,KAAKD,KAAK4G,EAAOrE,GAAK,GAAIxD,KAAKY,QACnCiY,EAAO,SAAc,WAAcrV,GAAMA,EACzCsV,EAAcH,EAMlB,GAJAC,GAAK7S,EACL6S,EAAI1X,KAAKQ,IAAI,EAAGkX,GAGZE,EAAa,CACf,IAAK,IAAI3X,EAAI,EAAGA,EAAI4E,EAAG5E,IACrB2X,EAAYxP,MAAMnI,GAAKnB,KAAKsJ,MAAMnI,GAEpC2X,EAAYlY,OAASmF,CACvB,CAEA,GAAU,IAANA,QAEG,GAAI/F,KAAKY,OAASmF,EAEvB,IADA/F,KAAKY,QAAUmF,EACV5E,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAC3BnB,KAAKsJ,MAAMnI,GAAKnB,KAAKsJ,MAAMnI,EAAI4E,QAGjC/F,KAAKsJ,MAAM,GAAK,EAChBtJ,KAAKY,OAAS,EAGhB,IAAI0L,EAAQ,EACZ,IAAKnL,EAAInB,KAAKY,OAAS,EAAGO,GAAK,IAAgB,IAAVmL,GAAenL,GAAKyX,GAAIzX,IAAK,CAChE,IAAIiK,EAAuB,EAAhBpL,KAAKsJ,MAAMnI,GACtBnB,KAAKsJ,MAAMnI,GAAMmL,GAAU,GAAK9I,EAAO4H,IAAS5H,EAChD8I,EAAQlB,EAAOyN,CACjB,CAYA,OATIC,GAAyB,IAAVxM,IACjBwM,EAAYxP,MAAMwP,EAAYlY,UAAY0L,GAGxB,IAAhBtM,KAAKY,SACPZ,KAAKsJ,MAAM,GAAK,EAChBtJ,KAAKY,OAAS,GAGTZ,KAAKgL,OACd,EAEA3E,EAAG5F,UAAUwH,MAAQ,SAAgBJ,EAAM6Q,EAAMC,GAG/C,OADA/Y,EAAyB,IAAlBI,KAAKqJ,UACLrJ,KAAK0N,OAAO7F,EAAM6Q,EAAMC,EACjC,EAGAtS,EAAG5F,UAAUsY,KAAO,SAAelR,GACjC,OAAO7H,KAAK0L,QAAQ+M,MAAM5Q,EAC5B,EAEAxB,EAAG5F,UAAUuY,MAAQ,SAAgBnR,GACnC,OAAO7H,KAAK0L,QAAQ4M,OAAOzQ,EAC7B,EAGAxB,EAAG5F,UAAU8H,KAAO,SAAeV,GACjC,OAAO7H,KAAK0L,QAAQzD,MAAMJ,EAC5B,EAEAxB,EAAG5F,UAAUwY,MAAQ,SAAgBpR,GACnC,OAAO7H,KAAK0L,QAAQgC,OAAO7F,EAC7B,EAGAxB,EAAG5F,UAAU2H,MAAQ,SAAgBqH,GACnC7P,EAAsB,kBAAR6P,GAAoBA,GAAO,GACzC,IAAIjM,EAAIiM,EAAM,GACV1J,GAAK0J,EAAMjM,GAAK,GAChBgK,EAAI,GAAKhK,EAGb,QAAIxD,KAAKY,QAAUmF,OAGX/F,KAAKsJ,MAAMvD,GAELyH,EAChB,EAGAnH,EAAG5F,UAAUyY,OAAS,SAAiBrR,GACrCjI,EAAuB,kBAATiI,GAAqBA,GAAQ,GAC3C,IAAIrE,EAAIqE,EAAO,GACX9B,GAAK8B,EAAOrE,GAAK,GAIrB,GAFA5D,EAAyB,IAAlBI,KAAKqJ,SAAgB,2CAExBrJ,KAAKY,QAAUmF,EACjB,OAAO/F,KAQT,GALU,IAANwD,GACFuC,IAEF/F,KAAKY,OAASM,KAAKD,IAAI8E,EAAG/F,KAAKY,QAErB,IAAN4C,EAAS,CACX,IAAIqV,EAAO,SAAc,WAAcrV,GAAMA,EAC7CxD,KAAKsJ,MAAMtJ,KAAKY,OAAS,IAAMiY,CACjC,CAEA,OAAO7Y,KAAKgL,OACd,EAGA3E,EAAG5F,UAAU0Y,MAAQ,SAAgBtR,GACnC,OAAO7H,KAAK0L,QAAQwN,OAAOrR,EAC7B,EAGAxB,EAAG5F,UAAU2N,MAAQ,SAAgBlL,GAGnC,OAFAtD,EAAsB,kBAARsD,GACdtD,EAAOsD,EAAM,UACTA,EAAM,EAAUlD,KAAKoZ,OAAOlW,GAGV,IAAlBlD,KAAKqJ,SACa,IAAhBrJ,KAAKY,SAAiC,EAAhBZ,KAAKsJ,MAAM,IAAUpG,GAC7ClD,KAAKsJ,MAAM,GAAKpG,GAAuB,EAAhBlD,KAAKsJ,MAAM,IAClCtJ,KAAKqJ,SAAW,EACTrJ,OAGTA,KAAKqJ,SAAW,EAChBrJ,KAAKoZ,MAAMlW,GACXlD,KAAKqJ,SAAW,EACTrJ,MAIFA,KAAKsL,OAAOpI,EACrB,EAEAmD,EAAG5F,UAAU6K,OAAS,SAAiBpI,GACrClD,KAAKsJ,MAAM,IAAMpG,EAGjB,IAAK,IAAI/B,EAAI,EAAGA,EAAInB,KAAKY,QAAUZ,KAAKsJ,MAAMnI,IAAM,SAAWA,IAC7DnB,KAAKsJ,MAAMnI,IAAM,SACbA,IAAMnB,KAAKY,OAAS,EACtBZ,KAAKsJ,MAAMnI,EAAI,GAAK,EAEpBnB,KAAKsJ,MAAMnI,EAAI,KAKnB,OAFAnB,KAAKY,OAASM,KAAKQ,IAAI1B,KAAKY,OAAQO,EAAI,GAEjCnB,IACT,EAGAqG,EAAG5F,UAAU2Y,MAAQ,SAAgBlW,GAGnC,GAFAtD,EAAsB,kBAARsD,GACdtD,EAAOsD,EAAM,UACTA,EAAM,EAAG,OAAOlD,KAAKoO,OAAOlL,GAEhC,GAAsB,IAAlBlD,KAAKqJ,SAIP,OAHArJ,KAAKqJ,SAAW,EAChBrJ,KAAKoO,MAAMlL,GACXlD,KAAKqJ,SAAW,EACTrJ,KAKT,GAFAA,KAAKsJ,MAAM,IAAMpG,EAEG,IAAhBlD,KAAKY,QAAgBZ,KAAKsJ,MAAM,GAAK,EACvCtJ,KAAKsJ,MAAM,IAAMtJ,KAAKsJ,MAAM,GAC5BtJ,KAAKqJ,SAAW,OAGhB,IAAK,IAAIlI,EAAI,EAAGA,EAAInB,KAAKY,QAAUZ,KAAKsJ,MAAMnI,GAAK,EAAGA,IACpDnB,KAAKsJ,MAAMnI,IAAM,SACjBnB,KAAKsJ,MAAMnI,EAAI,IAAM,EAIzB,OAAOnB,KAAKgL,OACd,EAEA3E,EAAG5F,UAAU4Y,KAAO,SAAenW,GACjC,OAAOlD,KAAK0L,QAAQ0C,MAAMlL,EAC5B,EAEAmD,EAAG5F,UAAUkH,KAAO,SAAezE,GACjC,OAAOlD,KAAK0L,QAAQ0N,MAAMlW,EAC5B,EAEAmD,EAAG5F,UAAU6Y,KAAO,WAGlB,OAFAtZ,KAAKqJ,SAAW,EAETrJ,IACT,EAEAqG,EAAG5F,UAAUyN,IAAM,WACjB,OAAOlO,KAAK0L,QAAQ4N,MACtB,EAEAjT,EAAG5F,UAAU8Y,aAAe,SAAuBrW,EAAKmH,EAAKlH,GAC3D,IACIhC,EAIA4J,EALAzH,EAAMJ,EAAItC,OAASuC,EAGvBnD,KAAK2L,QAAQrI,GAGb,IAAIgJ,EAAQ,EACZ,IAAKnL,EAAI,EAAGA,EAAI+B,EAAItC,OAAQO,IAAK,CAC/B4J,GAA6B,EAAxB/K,KAAKsJ,MAAMnI,EAAIgC,IAAcmJ,EAClC,IAAI9B,GAAwB,EAAftH,EAAIoG,MAAMnI,IAAUkJ,EAEjCiC,IADAvB,GAAa,SAARP,IACS,KAAQA,EAAQ,SAAa,GAC3CxK,KAAKsJ,MAAMnI,EAAIgC,GAAa,SAAJ4H,CAC1B,CACA,KAAO5J,EAAInB,KAAKY,OAASuC,EAAOhC,IAE9BmL,GADAvB,GAA6B,EAAxB/K,KAAKsJ,MAAMnI,EAAIgC,IAAcmJ,IACrB,GACbtM,KAAKsJ,MAAMnI,EAAIgC,GAAa,SAAJ4H,EAG1B,GAAc,IAAVuB,EAAa,OAAOtM,KAAKgL,QAK7B,IAFApL,GAAkB,IAAX0M,GACPA,EAAQ,EACHnL,EAAI,EAAGA,EAAInB,KAAKY,OAAQO,IAE3BmL,GADAvB,IAAsB,EAAhB/K,KAAKsJ,MAAMnI,IAAUmL,IACd,GACbtM,KAAKsJ,MAAMnI,GAAS,SAAJ4J,EAIlB,OAFA/K,KAAKqJ,SAAW,EAETrJ,KAAKgL,OACd,EAEA3E,EAAG5F,UAAU+Y,SAAW,SAAmBtW,EAAKuW,GAC9C,IAAItW,GAAQnD,KAAKY,OAASsC,EAAItC,QAE1BuL,EAAInM,KAAK0L,QACTU,EAAIlJ,EAGJwW,EAA8B,EAAxBtN,EAAE9C,MAAM8C,EAAExL,OAAS,GAGf,KADduC,EAAQ,GADMnD,KAAK4N,WAAW8L,MAG5BtN,EAAIA,EAAE4M,MAAM7V,GACZgJ,EAAEmM,OAAOnV,GACTuW,EAA8B,EAAxBtN,EAAE9C,MAAM8C,EAAExL,OAAS,IAI3B,IACI4M,EADAyJ,EAAI9K,EAAEvL,OAASwL,EAAExL,OAGrB,GAAa,QAAT6Y,EAAgB,EAClBjM,EAAI,IAAInH,EAAG,OACTzF,OAASqW,EAAI,EACfzJ,EAAElE,MAAQ,IAAIjJ,MAAMmN,EAAE5M,QACtB,IAAK,IAAIO,EAAI,EAAGA,EAAIqM,EAAE5M,OAAQO,IAC5BqM,EAAElE,MAAMnI,GAAK,CAEjB,CAEA,IAAIwY,EAAOxN,EAAET,QAAQ6N,aAAanN,EAAG,EAAG6K,GAClB,IAAlB0C,EAAKtQ,WACP8C,EAAIwN,EACAnM,IACFA,EAAElE,MAAM2N,GAAK,IAIjB,IAAK,IAAInU,EAAImU,EAAI,EAAGnU,GAAK,EAAGA,IAAK,CAC/B,IAAI8W,EAAmC,UAAL,EAAxBzN,EAAE7C,MAAM8C,EAAExL,OAASkC,KACE,EAA5BqJ,EAAE7C,MAAM8C,EAAExL,OAASkC,EAAI,IAO1B,IAHA8W,EAAK1Y,KAAKD,IAAK2Y,EAAKF,EAAO,EAAG,UAE9BvN,EAAEoN,aAAanN,EAAGwN,EAAI9W,GACA,IAAfqJ,EAAE9C,UACPuQ,IACAzN,EAAE9C,SAAW,EACb8C,EAAEoN,aAAanN,EAAG,EAAGtJ,GAChBqJ,EAAEU,WACLV,EAAE9C,UAAY,GAGdmE,IACFA,EAAElE,MAAMxG,GAAK8W,EAEjB,CAWA,OAVIpM,GACFA,EAAExC,QAEJmB,EAAEnB,QAGW,QAATyO,GAA4B,IAAVtW,GACpBgJ,EAAEuB,OAAOvK,GAGJ,CACL0W,IAAKrM,GAAK,KACVlF,IAAK6D,EAET,EAMA9F,EAAG5F,UAAUqZ,OAAS,SAAiB5W,EAAKuW,EAAMM,GAGhD,OAFAna,GAAQsD,EAAI2J,UAER7M,KAAK6M,SACA,CACLgN,IAAK,IAAIxT,EAAG,GACZiC,IAAK,IAAIjC,EAAG,IAKM,IAAlBrG,KAAKqJ,UAAmC,IAAjBnG,EAAImG,UAC7BpC,EAAMjH,KAAKyO,MAAMqL,OAAO5W,EAAKuW,GAEhB,QAATA,IACFI,EAAM5S,EAAI4S,IAAIpL,OAGH,QAATgL,IACFnR,EAAMrB,EAAIqB,IAAImG,MACVsL,GAA6B,IAAjBzR,EAAIe,UAClBf,EAAIH,KAAKjF,IAIN,CACL2W,IAAKA,EACLvR,IAAKA,IAIa,IAAlBtI,KAAKqJ,UAAmC,IAAjBnG,EAAImG,UAC7BpC,EAAMjH,KAAK8Z,OAAO5W,EAAIuL,MAAOgL,GAEhB,QAATA,IACFI,EAAM5S,EAAI4S,IAAIpL,OAGT,CACLoL,IAAKA,EACLvR,IAAKrB,EAAIqB,MAI0B,KAAlCtI,KAAKqJ,SAAWnG,EAAImG,WACvBpC,EAAMjH,KAAKyO,MAAMqL,OAAO5W,EAAIuL,MAAOgL,GAEtB,QAATA,IACFnR,EAAMrB,EAAIqB,IAAImG,MACVsL,GAA6B,IAAjBzR,EAAIe,UAClBf,EAAIqH,KAAKzM,IAIN,CACL2W,IAAK5S,EAAI4S,IACTvR,IAAKA,IAOLpF,EAAItC,OAASZ,KAAKY,QAAUZ,KAAKqI,IAAInF,GAAO,EACvC,CACL2W,IAAK,IAAIxT,EAAG,GACZiC,IAAKtI,MAKU,IAAfkD,EAAItC,OACO,QAAT6Y,EACK,CACLI,IAAK7Z,KAAKga,KAAK9W,EAAIoG,MAAM,IACzBhB,IAAK,MAII,QAATmR,EACK,CACLI,IAAK,KACLvR,IAAK,IAAIjC,EAAGrG,KAAKqH,KAAKnE,EAAIoG,MAAM,MAI7B,CACLuQ,IAAK7Z,KAAKga,KAAK9W,EAAIoG,MAAM,IACzBhB,IAAK,IAAIjC,EAAGrG,KAAKqH,KAAKnE,EAAIoG,MAAM,MAI7BtJ,KAAKwZ,SAAStW,EAAKuW,GAlF1B,IAAII,EAAKvR,EAAKrB,CAmFhB,EAGAZ,EAAG5F,UAAUoZ,IAAM,SAAc3W,GAC/B,OAAOlD,KAAK8Z,OAAO5W,EAAK,OAAO,GAAO2W,GACxC,EAGAxT,EAAG5F,UAAU6H,IAAM,SAAcpF,GAC/B,OAAOlD,KAAK8Z,OAAO5W,EAAK,OAAO,GAAOoF,GACxC,EAEAjC,EAAG5F,UAAUwZ,KAAO,SAAe/W,GACjC,OAAOlD,KAAK8Z,OAAO5W,EAAK,OAAO,GAAMoF,GACvC,EAGAjC,EAAG5F,UAAUyZ,SAAW,SAAmBhX,GACzC,IAAIiX,EAAKna,KAAK8Z,OAAO5W,GAGrB,GAAIiX,EAAG7R,IAAIuE,SAAU,OAAOsN,EAAGN,IAE/B,IAAIvR,EAA0B,IAApB6R,EAAGN,IAAIxQ,SAAiB8Q,EAAG7R,IAAIqH,KAAKzM,GAAOiX,EAAG7R,IAEpD8R,EAAOlX,EAAI+V,MAAM,GACjBoB,EAAKnX,EAAIuK,MAAM,GACfpF,EAAMC,EAAID,IAAI+R,GAGlB,OAAI/R,EAAM,GAAY,IAAPgS,GAAoB,IAARhS,EAAkB8R,EAAGN,IAGrB,IAApBM,EAAGN,IAAIxQ,SAAiB8Q,EAAGN,IAAIT,MAAM,GAAKe,EAAGN,IAAIzL,MAAM,EAChE,EAEA/H,EAAG5F,UAAU4G,KAAO,SAAenE,GACjCtD,EAAOsD,GAAO,UAId,IAHA,IAAIkE,GAAK,GAAK,IAAMlE,EAEhBoX,EAAM,EACDnZ,EAAInB,KAAKY,OAAS,EAAGO,GAAK,EAAGA,IACpCmZ,GAAOlT,EAAIkT,GAAuB,EAAhBta,KAAKsJ,MAAMnI,KAAW+B,EAG1C,OAAOoX,CACT,EAGAjU,EAAG5F,UAAUqM,MAAQ,SAAgB5J,GACnCtD,EAAOsD,GAAO,UAGd,IADA,IAAIoJ,EAAQ,EACHnL,EAAInB,KAAKY,OAAS,EAAGO,GAAK,EAAGA,IAAK,CACzC,IAAI4J,GAAqB,EAAhB/K,KAAKsJ,MAAMnI,IAAkB,SAARmL,EAC9BtM,KAAKsJ,MAAMnI,GAAM4J,EAAI7H,EAAO,EAC5BoJ,EAAQvB,EAAI7H,CACd,CAEA,OAAOlD,KAAKgL,OACd,EAEA3E,EAAG5F,UAAUuZ,KAAO,SAAe9W,GACjC,OAAOlD,KAAK0L,QAAQoB,MAAM5J,EAC5B,EAEAmD,EAAG5F,UAAU8Z,KAAO,SAAenT,GACjCxH,EAAsB,IAAfwH,EAAEiC,UACTzJ,GAAQwH,EAAEyF,UAEV,IAAIuI,EAAIpV,KACJqV,EAAIjO,EAAEsE,QAGR0J,EADiB,IAAfA,EAAE/L,SACA+L,EAAE6E,KAAK7S,GAEPgO,EAAE1J,QAaR,IATA,IAAI8O,EAAI,IAAInU,EAAG,GACXoU,EAAI,IAAIpU,EAAG,GAGXqU,EAAI,IAAIrU,EAAG,GACXsU,EAAI,IAAItU,EAAG,GAEXuU,EAAI,EAEDxF,EAAElN,UAAYmN,EAAEnN,UACrBkN,EAAE1H,OAAO,GACT2H,EAAE3H,OAAO,KACPkN,EAMJ,IAHA,IAAIC,EAAKxF,EAAE3J,QACPoP,EAAK1F,EAAE1J,SAEH0J,EAAEvI,UAAU,CAClB,IAAK,IAAI1L,EAAI,EAAG4Z,EAAK,EAAyB,KAArB3F,EAAE9L,MAAM,GAAKyR,IAAa5Z,EAAI,KAAMA,EAAG4Z,IAAO,GACvE,GAAI5Z,EAAI,EAEN,IADAiU,EAAE1H,OAAOvM,GACFA,KAAM,IACPqZ,EAAEQ,SAAWP,EAAEO,WACjBR,EAAErS,KAAK0S,GACPJ,EAAE9K,KAAKmL,IAGTN,EAAE9M,OAAO,GACT+M,EAAE/M,OAAO,GAIb,IAAK,IAAI5K,EAAI,EAAGmY,EAAK,EAAyB,KAArB5F,EAAE/L,MAAM,GAAK2R,IAAanY,EAAI,KAAMA,EAAGmY,IAAO,GACvE,GAAInY,EAAI,EAEN,IADAuS,EAAE3H,OAAO5K,GACFA,KAAM,IACP4X,EAAEM,SAAWL,EAAEK,WACjBN,EAAEvS,KAAK0S,GACPF,EAAEhL,KAAKmL,IAGTJ,EAAEhN,OAAO,GACTiN,EAAEjN,OAAO,GAIT0H,EAAE/M,IAAIgN,IAAM,GACdD,EAAEzF,KAAK0F,GACPmF,EAAE7K,KAAK+K,GACPD,EAAE9K,KAAKgL,KAEPtF,EAAE1F,KAAKyF,GACPsF,EAAE/K,KAAK6K,GACPG,EAAEhL,KAAK8K,GAEX,CAEA,MAAO,CACLtO,EAAGuO,EACHtO,EAAGuO,EACHO,IAAK7F,EAAEiD,OAAOsC,GAElB,EAKAvU,EAAG5F,UAAU0a,OAAS,SAAiB/T,GACrCxH,EAAsB,IAAfwH,EAAEiC,UACTzJ,GAAQwH,EAAEyF,UAEV,IAAIV,EAAInM,KACJoM,EAAIhF,EAAEsE,QAGRS,EADiB,IAAfA,EAAE9C,SACA8C,EAAE8N,KAAK7S,GAEP+E,EAAET,QAQR,IALA,IAuCIzE,EAvCAmU,EAAK,IAAI/U,EAAG,GACZgV,EAAK,IAAIhV,EAAG,GAEZiV,EAAQlP,EAAEV,QAEPS,EAAE7E,KAAK,GAAK,GAAK8E,EAAE9E,KAAK,GAAK,GAAG,CACrC,IAAK,IAAInG,EAAI,EAAG4Z,EAAK,EAAyB,KAArB5O,EAAE7C,MAAM,GAAKyR,IAAa5Z,EAAI,KAAMA,EAAG4Z,IAAO,GACvE,GAAI5Z,EAAI,EAEN,IADAgL,EAAEuB,OAAOvM,GACFA,KAAM,GACPia,EAAGJ,SACLI,EAAGjT,KAAKmT,GAGVF,EAAG1N,OAAO,GAId,IAAK,IAAI5K,EAAI,EAAGmY,EAAK,EAAyB,KAArB7O,EAAE9C,MAAM,GAAK2R,IAAanY,EAAI,KAAMA,EAAGmY,IAAO,GACvE,GAAInY,EAAI,EAEN,IADAsJ,EAAEsB,OAAO5K,GACFA,KAAM,GACPuY,EAAGL,SACLK,EAAGlT,KAAKmT,GAGVD,EAAG3N,OAAO,GAIVvB,EAAE9D,IAAI+D,IAAM,GACdD,EAAEwD,KAAKvD,GACPgP,EAAGzL,KAAK0L,KAERjP,EAAEuD,KAAKxD,GACPkP,EAAG1L,KAAKyL,GAEZ,CAaA,OATEnU,EADgB,IAAdkF,EAAE7E,KAAK,GACH8T,EAEAC,GAGA/T,KAAK,GAAK,GAChBL,EAAIkB,KAAKf,GAGJH,CACT,EAEAZ,EAAG5F,UAAUya,IAAM,SAAchY,GAC/B,GAAIlD,KAAK6M,SAAU,OAAO3J,EAAIgL,MAC9B,GAAIhL,EAAI2J,SAAU,OAAO7M,KAAKkO,MAE9B,IAAI/B,EAAInM,KAAK0L,QACTU,EAAIlJ,EAAIwI,QACZS,EAAE9C,SAAW,EACb+C,EAAE/C,SAAW,EAGb,IAAK,IAAIlG,EAAQ,EAAGgJ,EAAEjE,UAAYkE,EAAElE,SAAU/E,IAC5CgJ,EAAEuB,OAAO,GACTtB,EAAEsB,OAAO,GAGX,OAAG,CACD,KAAOvB,EAAEjE,UACPiE,EAAEuB,OAAO,GAEX,KAAOtB,EAAElE,UACPkE,EAAEsB,OAAO,GAGX,IAAIlK,EAAI2I,EAAE9D,IAAI+D,GACd,GAAI5I,EAAI,EAAG,CAET,IAAIwC,EAAImG,EACRA,EAAIC,EACJA,EAAIpG,CACN,MAAO,GAAU,IAANxC,GAAyB,IAAd4I,EAAE9E,KAAK,GAC3B,MAGF6E,EAAEwD,KAAKvD,EACT,CAEA,OAAOA,EAAEkM,OAAOnV,EAClB,EAGAkD,EAAG5F,UAAU8a,KAAO,SAAerY,GACjC,OAAOlD,KAAKua,KAAKrX,GAAKiJ,EAAE8N,KAAK/W,EAC/B,EAEAmD,EAAG5F,UAAUyH,OAAS,WACpB,OAA+B,KAAP,EAAhBlI,KAAKsJ,MAAM,GACrB,EAEAjD,EAAG5F,UAAUua,MAAQ,WACnB,OAA+B,KAAP,EAAhBhb,KAAKsJ,MAAM,GACrB,EAGAjD,EAAG5F,UAAUgN,MAAQ,SAAgBvK,GACnC,OAAOlD,KAAKsJ,MAAM,GAAKpG,CACzB,EAGAmD,EAAG5F,UAAU+a,MAAQ,SAAgB/L,GACnC7P,EAAsB,kBAAR6P,GACd,IAAIjM,EAAIiM,EAAM,GACV1J,GAAK0J,EAAMjM,GAAK,GAChBgK,EAAI,GAAKhK,EAGb,GAAIxD,KAAKY,QAAUmF,EAGjB,OAFA/F,KAAK2L,QAAQ5F,EAAI,GACjB/F,KAAKsJ,MAAMvD,IAAMyH,EACVxN,KAKT,IADA,IAAIsM,EAAQkB,EACHrM,EAAI4E,EAAa,IAAVuG,GAAenL,EAAInB,KAAKY,OAAQO,IAAK,CACnD,IAAI4J,EAAoB,EAAhB/K,KAAKsJ,MAAMnI,GAEnBmL,GADAvB,GAAKuB,KACS,GACdvB,GAAK,SACL/K,KAAKsJ,MAAMnI,GAAK4J,CAClB,CAKA,OAJc,IAAVuB,IACFtM,KAAKsJ,MAAMnI,GAAKmL,EAChBtM,KAAKY,UAEAZ,IACT,EAEAqG,EAAG5F,UAAUoM,OAAS,WACpB,OAAuB,IAAhB7M,KAAKY,QAAkC,IAAlBZ,KAAKsJ,MAAM,EACzC,EAEAjD,EAAG5F,UAAU6G,KAAO,SAAepE,GACjC,IAOI+D,EAPAoC,EAAWnG,EAAM,EAErB,GAAsB,IAAlBlD,KAAKqJ,WAAmBA,EAAU,OAAQ,EAC9C,GAAsB,IAAlBrJ,KAAKqJ,UAAkBA,EAAU,OAAO,EAK5C,GAHArJ,KAAKgL,QAGDhL,KAAKY,OAAS,EAChBqG,EAAM,MACD,CACDoC,IACFnG,GAAOA,GAGTtD,EAAOsD,GAAO,SAAW,qBAEzB,IAAI6H,EAAoB,EAAhB/K,KAAKsJ,MAAM,GACnBrC,EAAM8D,IAAM7H,EAAM,EAAI6H,EAAI7H,GAAO,EAAI,CACvC,CACA,OAAsB,IAAlBlD,KAAKqJ,SAA8B,GAANpC,EAC1BA,CACT,EAMAZ,EAAG5F,UAAU4H,IAAM,SAAcnF,GAC/B,GAAsB,IAAlBlD,KAAKqJ,UAAmC,IAAjBnG,EAAImG,SAAgB,OAAQ,EACvD,GAAsB,IAAlBrJ,KAAKqJ,UAAmC,IAAjBnG,EAAImG,SAAgB,OAAO,EAEtD,IAAIpC,EAAMjH,KAAKyb,KAAKvY,GACpB,OAAsB,IAAlBlD,KAAKqJ,SAA8B,GAANpC,EAC1BA,CACT,EAGAZ,EAAG5F,UAAUgb,KAAO,SAAevY,GAEjC,GAAIlD,KAAKY,OAASsC,EAAItC,OAAQ,OAAO,EACrC,GAAIZ,KAAKY,OAASsC,EAAItC,OAAQ,OAAQ,EAGtC,IADA,IAAIqG,EAAM,EACD9F,EAAInB,KAAKY,OAAS,EAAGO,GAAK,EAAGA,IAAK,CACzC,IAAIgL,EAAoB,EAAhBnM,KAAKsJ,MAAMnI,GACfiL,EAAmB,EAAflJ,EAAIoG,MAAMnI,GAElB,GAAIgL,IAAMC,EAAV,CACID,EAAIC,EACNnF,GAAO,EACEkF,EAAIC,IACbnF,EAAM,GAER,KANqB,CAOvB,CACA,OAAOA,CACT,EAEAZ,EAAG5F,UAAUib,IAAM,SAAcxY,GAC/B,OAA0B,IAAnBlD,KAAKsH,KAAKpE,EACnB,EAEAmD,EAAG5F,UAAUkb,GAAK,SAAazY,GAC7B,OAAyB,IAAlBlD,KAAKqI,IAAInF,EAClB,EAEAmD,EAAG5F,UAAUmb,KAAO,SAAe1Y,GACjC,OAAOlD,KAAKsH,KAAKpE,IAAQ,CAC3B,EAEAmD,EAAG5F,UAAUob,IAAM,SAAc3Y,GAC/B,OAAOlD,KAAKqI,IAAInF,IAAQ,CAC1B,EAEAmD,EAAG5F,UAAUqb,IAAM,SAAc5Y,GAC/B,OAA2B,IAApBlD,KAAKsH,KAAKpE,EACnB,EAEAmD,EAAG5F,UAAUsb,GAAK,SAAa7Y,GAC7B,OAA0B,IAAnBlD,KAAKqI,IAAInF,EAClB,EAEAmD,EAAG5F,UAAUub,KAAO,SAAe9Y,GACjC,OAAOlD,KAAKsH,KAAKpE,IAAQ,CAC3B,EAEAmD,EAAG5F,UAAUwb,IAAM,SAAc/Y,GAC/B,OAAOlD,KAAKqI,IAAInF,IAAQ,CAC1B,EAEAmD,EAAG5F,UAAUyb,IAAM,SAAchZ,GAC/B,OAA0B,IAAnBlD,KAAKsH,KAAKpE,EACnB,EAEAmD,EAAG5F,UAAU0b,GAAK,SAAajZ,GAC7B,OAAyB,IAAlBlD,KAAKqI,IAAInF,EAClB,EAMAmD,EAAGkB,IAAM,SAAcrE,GACrB,OAAO,IAAIkZ,EAAIlZ,EACjB,EAEAmD,EAAG5F,UAAUgH,MAAQ,SAAgB4U,GAGnC,OAFAzc,GAAQI,KAAKuH,IAAK,yCAClB3H,EAAyB,IAAlBI,KAAKqJ,SAAgB,iCACrBgT,EAAIC,UAAUtc,MAAMuc,UAAUF,EACvC,EAEAhW,EAAG5F,UAAUmH,QAAU,WAErB,OADAhI,EAAOI,KAAKuH,IAAK,wDACVvH,KAAKuH,IAAIiV,YAAYxc,KAC9B,EAEAqG,EAAG5F,UAAU8b,UAAY,SAAoBF,GAE3C,OADArc,KAAKuH,IAAM8U,EACJrc,IACT,EAEAqG,EAAG5F,UAAUgc,SAAW,SAAmBJ,GAEzC,OADAzc,GAAQI,KAAKuH,IAAK,yCACXvH,KAAKuc,UAAUF,EACxB,EAEAhW,EAAG5F,UAAUic,OAAS,SAAiBxZ,GAErC,OADAtD,EAAOI,KAAKuH,IAAK,sCACVvH,KAAKuH,IAAIqI,IAAI5P,KAAMkD,EAC5B,EAEAmD,EAAG5F,UAAUkc,QAAU,SAAkBzZ,GAEvC,OADAtD,EAAOI,KAAKuH,IAAK,uCACVvH,KAAKuH,IAAIY,KAAKnI,KAAMkD,EAC7B,EAEAmD,EAAG5F,UAAUmc,OAAS,SAAiB1Z,GAErC,OADAtD,EAAOI,KAAKuH,IAAK,sCACVvH,KAAKuH,IAAIsI,IAAI7P,KAAMkD,EAC5B,EAEAmD,EAAG5F,UAAUoc,QAAU,SAAkB3Z,GAEvC,OADAtD,EAAOI,KAAKuH,IAAK,uCACVvH,KAAKuH,IAAIoI,KAAK3P,KAAMkD,EAC7B,EAEAmD,EAAG5F,UAAUqc,OAAS,SAAiB5Z,GAErC,OADAtD,EAAOI,KAAKuH,IAAK,sCACVvH,KAAKuH,IAAIwV,IAAI/c,KAAMkD,EAC5B,EAEAmD,EAAG5F,UAAUuc,OAAS,SAAiB9Z,GAGrC,OAFAtD,EAAOI,KAAKuH,IAAK,sCACjBvH,KAAKuH,IAAI0V,SAASjd,KAAMkD,GACjBlD,KAAKuH,IAAI8C,IAAIrK,KAAMkD,EAC5B,EAEAmD,EAAG5F,UAAUyc,QAAU,SAAkBha,GAGvC,OAFAtD,EAAOI,KAAKuH,IAAK,sCACjBvH,KAAKuH,IAAI0V,SAASjd,KAAMkD,GACjBlD,KAAKuH,IAAIuM,KAAK9T,KAAMkD,EAC7B,EAEAmD,EAAG5F,UAAU0c,OAAS,WAGpB,OAFAvd,EAAOI,KAAKuH,IAAK,sCACjBvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAI4Q,IAAInY,KACtB,EAEAqG,EAAG5F,UAAU4c,QAAU,WAGrB,OAFAzd,EAAOI,KAAKuH,IAAK,uCACjBvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAI6Q,KAAKpY,KACvB,EAGAqG,EAAG5F,UAAU6c,QAAU,WAGrB,OAFA1d,EAAOI,KAAKuH,IAAK,uCACjBvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAIJ,KAAKnH,KACvB,EAEAqG,EAAG5F,UAAU8c,QAAU,WAGrB,OAFA3d,EAAOI,KAAKuH,IAAK,uCACjBvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAIgU,KAAKvb,KACvB,EAGAqG,EAAG5F,UAAU+c,OAAS,WAGpB,OAFA5d,EAAOI,KAAKuH,IAAK,sCACjBvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAIkH,IAAIzO,KACtB,EAEAqG,EAAG5F,UAAUiH,OAAS,SAAiBxE,GAGrC,OAFAtD,EAAOI,KAAKuH,MAAQrE,EAAIqE,IAAK,qBAC7BvH,KAAKuH,IAAI6V,SAASpd,MACXA,KAAKuH,IAAIgE,IAAIvL,KAAMkD,EAC5B,EAGA,IAAI6D,EAAS,CACX0W,KAAM,KACNC,KAAM,KACNC,KAAM,KACNC,OAAQ,MAIV,SAASC,EAAQC,EAAM1W,GAErBpH,KAAK8d,KAAOA,EACZ9d,KAAKoH,EAAI,IAAIf,EAAGe,EAAG,IACnBpH,KAAKgX,EAAIhX,KAAKoH,EAAEY,YAChBhI,KAAKkH,EAAI,IAAIb,EAAG,GAAGiS,OAAOtY,KAAKgX,GAAGrH,KAAK3P,KAAKoH,GAE5CpH,KAAKwE,IAAMxE,KAAK+d,MAClB,CAgDA,SAASC,IACPH,EAAOlZ,KACL3E,KACA,OACA,0EACJ,CA8DA,SAASie,IACPJ,EAAOlZ,KACL3E,KACA,OACA,iEACJ,CAGA,SAASke,IACPL,EAAOlZ,KACL3E,KACA,OACA,wDACJ,CAGA,SAASme,IAEPN,EAAOlZ,KACL3E,KACA,QACA,sEACJ,CA6CA,SAASoc,EAAKnF,GACZ,GAAiB,kBAANA,EAAgB,CACzB,IAAImH,EAAQ/X,EAAGgY,OAAOpH,GACtBjX,KAAKiX,EAAImH,EAAMhX,EACfpH,KAAKoe,MAAQA,CACf,MACExe,EAAOqX,EAAEyE,IAAI,GAAI,kCACjB1b,KAAKiX,EAAIA,EACTjX,KAAKoe,MAAQ,IAEjB,CAgOA,SAASE,EAAMrH,GACbmF,EAAIzX,KAAK3E,KAAMiX,GAEfjX,KAAKmD,MAAQnD,KAAKiX,EAAEjP,YAChBhI,KAAKmD,MAAQ,KAAO,IACtBnD,KAAKmD,OAAS,GAAMnD,KAAKmD,MAAQ,IAGnCnD,KAAKwD,EAAI,IAAI6C,EAAG,GAAGiS,OAAOtY,KAAKmD,OAC/BnD,KAAKqa,GAAKra,KAAKue,KAAKve,KAAKwD,EAAE2U,OAC3BnY,KAAKwe,KAAOxe,KAAKwD,EAAE2X,OAAOnb,KAAKiX,GAE/BjX,KAAKye,KAAOze,KAAKwe,KAAKnU,IAAIrK,KAAKwD,GAAG4V,MAAM,GAAGS,IAAI7Z,KAAKiX,GACpDjX,KAAKye,KAAOze,KAAKye,KAAKxE,KAAKja,KAAKwD,GAChCxD,KAAKye,KAAOze,KAAKwD,EAAEqM,IAAI7P,KAAKye,KAC9B,CA7aAZ,EAAOpd,UAAUsd,KAAO,WACtB,IAAIvZ,EAAM,IAAI6B,EAAG,MAEjB,OADA7B,EAAI8E,MAAQ,IAAIjJ,MAAMa,KAAKS,KAAK3B,KAAKgX,EAAI,KAClCxS,CACT,EAEAqZ,EAAOpd,UAAUie,QAAU,SAAkBxb,GAG3C,IACIyb,EADAnb,EAAIN,EAGR,GACElD,KAAK4e,MAAMpb,EAAGxD,KAAKwE,KAGnBma,GADAnb,GADAA,EAAIxD,KAAK6e,MAAMrb,IACT2E,KAAKnI,KAAKwE,MACPwD,kBACF2W,EAAO3e,KAAKgX,GAErB,IAAI3O,EAAMsW,EAAO3e,KAAKgX,GAAK,EAAIxT,EAAEiY,KAAKzb,KAAKoH,GAgB3C,OAfY,IAARiB,GACF7E,EAAE8F,MAAM,GAAK,EACb9F,EAAE5C,OAAS,GACFyH,EAAM,EACf7E,EAAEmM,KAAK3P,KAAKoH,QAEI0X,IAAZtb,EAAEwH,MAEJxH,EAAEwH,QAGFxH,EAAEub,SAICvb,CACT,EAEAqa,EAAOpd,UAAUme,MAAQ,SAAgBI,EAAO3d,GAC9C2d,EAAMtR,OAAO1N,KAAKgX,EAAG,EAAG3V,EAC1B,EAEAwc,EAAOpd,UAAUoe,MAAQ,SAAgB3b,GACvC,OAAOA,EAAI4Q,KAAK9T,KAAKkH,EACvB,EAQA7C,EAAS2Z,EAAMH,GAEfG,EAAKvd,UAAUme,MAAQ,SAAgBI,EAAOC,GAK5C,IAHA,IAAIpG,EAAO,QAEPqG,EAAShe,KAAKD,IAAI+d,EAAMpe,OAAQ,GAC3BO,EAAI,EAAGA,EAAI+d,EAAQ/d,IAC1B8d,EAAO3V,MAAMnI,GAAK6d,EAAM1V,MAAMnI,GAIhC,GAFA8d,EAAOre,OAASse,EAEZF,EAAMpe,QAAU,EAGlB,OAFAoe,EAAM1V,MAAM,GAAK,OACjB0V,EAAMpe,OAAS,GAKjB,IAAIue,EAAOH,EAAM1V,MAAM,GAGvB,IAFA2V,EAAO3V,MAAM2V,EAAOre,UAAYue,EAAOtG,EAElC1X,EAAI,GAAIA,EAAI6d,EAAMpe,OAAQO,IAAK,CAClC,IAAIie,EAAwB,EAAjBJ,EAAM1V,MAAMnI,GACvB6d,EAAM1V,MAAMnI,EAAI,KAAQie,EAAOvG,IAAS,EAAMsG,IAAS,GACvDA,EAAOC,CACT,CACAD,KAAU,GACVH,EAAM1V,MAAMnI,EAAI,IAAMge,EACT,IAATA,GAAcH,EAAMpe,OAAS,GAC/Boe,EAAMpe,QAAU,GAEhBoe,EAAMpe,QAAU,CAEpB,EAEAod,EAAKvd,UAAUoe,MAAQ,SAAgB3b,GAErCA,EAAIoG,MAAMpG,EAAItC,QAAU,EACxBsC,EAAIoG,MAAMpG,EAAItC,OAAS,GAAK,EAC5BsC,EAAItC,QAAU,EAId,IADA,IAAIyL,EAAK,EACAlL,EAAI,EAAGA,EAAI+B,EAAItC,OAAQO,IAAK,CACnC,IAAI4J,EAAmB,EAAf7H,EAAIoG,MAAMnI,GAClBkL,GAAU,IAAJtB,EACN7H,EAAIoG,MAAMnI,GAAU,SAALkL,EACfA,EAAS,GAAJtB,GAAasB,EAAK,SAAa,EACtC,CASA,OANkC,IAA9BnJ,EAAIoG,MAAMpG,EAAItC,OAAS,KACzBsC,EAAItC,SAC8B,IAA9BsC,EAAIoG,MAAMpG,EAAItC,OAAS,IACzBsC,EAAItC,UAGDsC,CACT,EAQAmB,EAAS4Z,EAAMJ,GAQfxZ,EAAS6Z,EAAML,GASfxZ,EAAS8Z,EAAQN,GAEjBM,EAAO1d,UAAUoe,MAAQ,SAAgB3b,GAGvC,IADA,IAAIoJ,EAAQ,EACHnL,EAAI,EAAGA,EAAI+B,EAAItC,OAAQO,IAAK,CACnC,IAAI2M,EAA0B,IAAL,EAAf5K,EAAIoG,MAAMnI,IAAiBmL,EACjCD,EAAU,SAALyB,EACTA,KAAQ,GAER5K,EAAIoG,MAAMnI,GAAKkL,EACfC,EAAQwB,CACV,CAIA,OAHc,IAAVxB,IACFpJ,EAAIoG,MAAMpG,EAAItC,UAAY0L,GAErBpJ,CACT,EAGAmD,EAAGgY,OAAS,SAAgBP,GAE1B,GAAI/W,EAAO+W,GAAO,OAAO/W,EAAO+W,GAEhC,IAAIM,EACJ,GAAa,SAATN,EACFM,EAAQ,IAAIJ,OACP,GAAa,SAATF,EACTM,EAAQ,IAAIH,OACP,GAAa,SAATH,EACTM,EAAQ,IAAIF,MACP,IAAa,WAATJ,EAGT,MAAM,IAAInV,MAAM,iBAAmBmV,GAFnCM,EAAQ,IAAID,CAGd,CAGA,OAFApX,EAAO+W,GAAQM,EAERA,CACT,EAiBAhC,EAAI3b,UAAU2c,SAAW,SAAmBjR,GAC1CvM,EAAsB,IAAfuM,EAAE9C,SAAgB,iCACzBzJ,EAAOuM,EAAE5E,IAAK,kCAChB,EAEA6U,EAAI3b,UAAUwc,SAAW,SAAmB9Q,EAAGC,GAC7CxM,EAAqC,KAA7BuM,EAAE9C,SAAW+C,EAAE/C,UAAiB,iCACxCzJ,EAAOuM,EAAE5E,KAAO4E,EAAE5E,MAAQ6E,EAAE7E,IAC1B,kCACJ,EAEA6U,EAAI3b,UAAU8d,KAAO,SAAepS,GAClC,OAAInM,KAAKoe,MAAcpe,KAAKoe,MAAMM,QAAQvS,GAAGoQ,UAAUvc,MAChDmM,EAAE8N,KAAKja,KAAKiX,GAAGsF,UAAUvc,KAClC,EAEAoc,EAAI3b,UAAUgO,IAAM,SAActC,GAChC,OAAIA,EAAEU,SACGV,EAAET,QAGJ1L,KAAKiX,EAAEpH,IAAI1D,GAAGoQ,UAAUvc,KACjC,EAEAoc,EAAI3b,UAAUmP,IAAM,SAAczD,EAAGC,GACnCpM,KAAKid,SAAS9Q,EAAGC,GAEjB,IAAInF,EAAMkF,EAAEyD,IAAIxD,GAIhB,OAHInF,EAAIoB,IAAIrI,KAAKiX,IAAM,GACrBhQ,EAAI0I,KAAK3P,KAAKiX,GAEThQ,EAAIsV,UAAUvc,KACvB,EAEAoc,EAAI3b,UAAU0H,KAAO,SAAegE,EAAGC,GACrCpM,KAAKid,SAAS9Q,EAAGC,GAEjB,IAAInF,EAAMkF,EAAEhE,KAAKiE,GAIjB,OAHInF,EAAIoB,IAAIrI,KAAKiX,IAAM,GACrBhQ,EAAI0I,KAAK3P,KAAKiX,GAEThQ,CACT,EAEAmV,EAAI3b,UAAUoP,IAAM,SAAc1D,EAAGC,GACnCpM,KAAKid,SAAS9Q,EAAGC,GAEjB,IAAInF,EAAMkF,EAAE0D,IAAIzD,GAIhB,OAHInF,EAAIK,KAAK,GAAK,GAChBL,EAAIkB,KAAKnI,KAAKiX,GAEThQ,EAAIsV,UAAUvc,KACvB,EAEAoc,EAAI3b,UAAUkP,KAAO,SAAexD,EAAGC,GACrCpM,KAAKid,SAAS9Q,EAAGC,GAEjB,IAAInF,EAAMkF,EAAEwD,KAAKvD,GAIjB,OAHInF,EAAIK,KAAK,GAAK,GAChBL,EAAIkB,KAAKnI,KAAKiX,GAEThQ,CACT,EAEAmV,EAAI3b,UAAUsc,IAAM,SAAc5Q,EAAGjJ,GAEnC,OADAlD,KAAKod,SAASjR,GACPnM,KAAKue,KAAKpS,EAAE6M,MAAM9V,GAC3B,EAEAkZ,EAAI3b,UAAUqT,KAAO,SAAe3H,EAAGC,GAErC,OADApM,KAAKid,SAAS9Q,EAAGC,GACVpM,KAAKue,KAAKpS,EAAE2H,KAAK1H,GAC1B,EAEAgQ,EAAI3b,UAAU4J,IAAM,SAAc8B,EAAGC,GAEnC,OADApM,KAAKid,SAAS9Q,EAAGC,GACVpM,KAAKue,KAAKpS,EAAE9B,IAAI+B,GACzB,EAEAgQ,EAAI3b,UAAU2X,KAAO,SAAejM,GAClC,OAAOnM,KAAK8T,KAAK3H,EAAGA,EAAET,QACxB,EAEA0Q,EAAI3b,UAAU0X,IAAM,SAAchM,GAChC,OAAOnM,KAAKqK,IAAI8B,EAAGA,EACrB,EAEAiQ,EAAI3b,UAAU0G,KAAO,SAAegF,GAClC,GAAIA,EAAEU,SAAU,OAAOV,EAAET,QAEzB,IAAI2T,EAAOrf,KAAKiX,EAAExJ,MAAM,GAIxB,GAHA7N,EAAOyf,EAAO,IAAM,GAGP,IAATA,EAAY,CACd,IAAI9T,EAAMvL,KAAKiX,EAAErH,IAAI,IAAIvJ,EAAG,IAAIqH,OAAO,GACvC,OAAO1N,KAAKuL,IAAIY,EAAGZ,EACrB,CAOA,IAFA,IAAIiC,EAAIxN,KAAKiX,EAAEtP,KAAK,GAChB5B,EAAI,GACAyH,EAAEX,UAA2B,IAAfW,EAAEC,MAAM,IAC5B1H,IACAyH,EAAEE,OAAO,GAEX9N,GAAQ4N,EAAEX,UAEV,IAAIyS,EAAM,IAAIjZ,EAAG,GAAGoB,MAAMzH,MACtBuf,EAAOD,EAAI9B,SAIXgC,EAAOxf,KAAKiX,EAAEtP,KAAK,GAAG+F,OAAO,GAC7B+R,EAAIzf,KAAKiX,EAAEjP,YAGf,IAFAyX,EAAI,IAAIpZ,EAAG,EAAIoZ,EAAIA,GAAGhY,MAAMzH,MAEW,IAAhCA,KAAKuL,IAAIkU,EAAGD,GAAMnX,IAAIkX,IAC3BE,EAAE9C,QAAQ4C,GAOZ,IAJA,IAAIzV,EAAI9J,KAAKuL,IAAIkU,EAAGjS,GAChBhK,EAAIxD,KAAKuL,IAAIY,EAAGqB,EAAE6L,KAAK,GAAG3L,OAAO,IACjC1H,EAAIhG,KAAKuL,IAAIY,EAAGqB,GAChByJ,EAAIlR,EACc,IAAfC,EAAEqC,IAAIiX,IAAY,CAEvB,IADA,IAAI9a,EAAMwB,EACD7E,EAAI,EAAoB,IAAjBqD,EAAI6D,IAAIiX,GAAYne,IAClCqD,EAAMA,EAAI2Y,SAEZvd,EAAOuB,EAAI8V,GACX,IAAI7K,EAAIpM,KAAKuL,IAAIzB,EAAG,IAAIzD,EAAG,GAAGiS,OAAOrB,EAAI9V,EAAI,IAE7CqC,EAAIA,EAAEwZ,OAAO5Q,GACbtC,EAAIsC,EAAE+Q,SACNnX,EAAIA,EAAEgX,OAAOlT,GACbmN,EAAI9V,CACN,CAEA,OAAOqC,CACT,EAEA4Y,EAAI3b,UAAU8a,KAAO,SAAepP,GAClC,IAAIuT,EAAMvT,EAAEgP,OAAOnb,KAAKiX,GACxB,OAAqB,IAAjByI,EAAIrW,UACNqW,EAAIrW,SAAW,EACRrJ,KAAKue,KAAKmB,GAAKlC,UAEfxd,KAAKue,KAAKmB,EAErB,EAEAtD,EAAI3b,UAAU8K,IAAM,SAAcY,EAAGjJ,GACnC,GAAIA,EAAI2J,SAAU,OAAO,IAAIxG,EAAG,GAAGoB,MAAMzH,MACzC,GAAoB,IAAhBkD,EAAIoE,KAAK,GAAU,OAAO6E,EAAET,QAEhC,IACIiU,EAAM,IAAItf,MAAM,IACpBsf,EAAI,GAAK,IAAItZ,EAAG,GAAGoB,MAAMzH,MACzB2f,EAAI,GAAKxT,EACT,IAAK,IAAIhL,EAAI,EAAGA,EAAIwe,EAAI/e,OAAQO,IAC9Bwe,EAAIxe,GAAKnB,KAAKqK,IAAIsV,EAAIxe,EAAI,GAAIgL,GAGhC,IAAIlF,EAAM0Y,EAAI,GACVC,EAAU,EACVC,EAAa,EACb1V,EAAQjH,EAAI8E,YAAc,GAK9B,IAJc,IAAVmC,IACFA,EAAQ,IAGLhJ,EAAI+B,EAAItC,OAAS,EAAGO,GAAK,EAAGA,IAAK,CAEpC,IADA,IAAIiK,EAAOlI,EAAIoG,MAAMnI,GACZ2B,EAAIqH,EAAQ,EAAGrH,GAAK,EAAGA,IAAK,CACnC,IAAI2M,EAAOrE,GAAQtI,EAAK,EACpBmE,IAAQ0Y,EAAI,KACd1Y,EAAMjH,KAAKmY,IAAIlR,IAGL,IAARwI,GAAyB,IAAZmQ,GAKjBA,IAAY,EACZA,GAAWnQ,GA9BE,MA+BboQ,GACwC,IAAN1e,GAAiB,IAAN2B,KAE7CmE,EAAMjH,KAAKqK,IAAIpD,EAAK0Y,EAAIC,IACxBC,EAAa,EACbD,EAAU,IAXRC,EAAa,CAYjB,CACA1V,EAAQ,EACV,CAEA,OAAOlD,CACT,EAEAmV,EAAI3b,UAAU6b,UAAY,SAAoBpZ,GAC5C,IAAIM,EAAIN,EAAI+W,KAAKja,KAAKiX,GAEtB,OAAOzT,IAAMN,EAAMM,EAAEkI,QAAUlI,CACjC,EAEA4Y,EAAI3b,UAAU+b,YAAc,SAAsBtZ,GAChD,IAAI+D,EAAM/D,EAAIwI,QAEd,OADAzE,EAAIM,IAAM,KACHN,CACT,EAMAZ,EAAGmB,KAAO,SAAetE,GACvB,OAAO,IAAIob,EAAKpb,EAClB,EAkBAmB,EAASia,EAAMlC,GAEfkC,EAAK7d,UAAU6b,UAAY,SAAoBpZ,GAC7C,OAAOlD,KAAKue,KAAKrb,EAAI8V,MAAMhZ,KAAKmD,OAClC,EAEAmb,EAAK7d,UAAU+b,YAAc,SAAsBtZ,GACjD,IAAIM,EAAIxD,KAAKue,KAAKrb,EAAImH,IAAIrK,KAAKwe,OAE/B,OADAhb,EAAE+D,IAAM,KACD/D,CACT,EAEA8a,EAAK7d,UAAUqT,KAAO,SAAe3H,EAAGC,GACtC,GAAID,EAAEU,UAAYT,EAAES,SAGlB,OAFAV,EAAE7C,MAAM,GAAK,EACb6C,EAAEvL,OAAS,EACJuL,EAGT,IAAInG,EAAImG,EAAE2H,KAAK1H,GACXtC,EAAI9D,EAAEmT,MAAMnZ,KAAKmD,OAAOkH,IAAIrK,KAAKye,MAAMvF,OAAOlZ,KAAKmD,OAAOkH,IAAIrK,KAAKiX,GACnE6I,EAAI9Z,EAAE2J,KAAK7F,GAAG4D,OAAO1N,KAAKmD,OAC1B8D,EAAM6Y,EAQV,OANIA,EAAEzX,IAAIrI,KAAKiX,IAAM,EACnBhQ,EAAM6Y,EAAEnQ,KAAK3P,KAAKiX,GACT6I,EAAExY,KAAK,GAAK,IACrBL,EAAM6Y,EAAE3X,KAAKnI,KAAKiX,IAGbhQ,EAAIsV,UAAUvc,KACvB,EAEAse,EAAK7d,UAAU4J,IAAM,SAAc8B,EAAGC,GACpC,GAAID,EAAEU,UAAYT,EAAES,SAAU,OAAO,IAAIxG,EAAG,GAAGkW,UAAUvc,MAEzD,IAAIgG,EAAImG,EAAE9B,IAAI+B,GACVtC,EAAI9D,EAAEmT,MAAMnZ,KAAKmD,OAAOkH,IAAIrK,KAAKye,MAAMvF,OAAOlZ,KAAKmD,OAAOkH,IAAIrK,KAAKiX,GACnE6I,EAAI9Z,EAAE2J,KAAK7F,GAAG4D,OAAO1N,KAAKmD,OAC1B8D,EAAM6Y,EAOV,OANIA,EAAEzX,IAAIrI,KAAKiX,IAAM,EACnBhQ,EAAM6Y,EAAEnQ,KAAK3P,KAAKiX,GACT6I,EAAExY,KAAK,GAAK,IACrBL,EAAM6Y,EAAE3X,KAAKnI,KAAKiX,IAGbhQ,EAAIsV,UAAUvc,KACvB,EAEAse,EAAK7d,UAAU8a,KAAO,SAAepP,GAGnC,OADUnM,KAAKue,KAAKpS,EAAEgP,OAAOnb,KAAKiX,GAAG5M,IAAIrK,KAAKqa,KACnCkC,UAAUvc,KACvB,CACD,CAr3GD,CAq3GoCO,EAAQP,K,0DCr3G5C,SAAS+f,EAAiBC,EAAWC,GACnC,OAAOD,EAAUrV,QAAQ,IAAIuV,OAAO,UAAYD,EAAgB,YAAa,KAAM,MAAMtV,QAAQ,OAAQ,KAAKA,QAAQ,aAAc,GACtI,CASe,SAASwV,EAAYC,EAASC,GACvCD,EAAQE,UACVF,EAAQE,UAAUC,OAAOF,GACa,kBAAtBD,EAAQC,UACxBD,EAAQC,UAAYN,EAAiBK,EAAQC,UAAWA,GAExDD,EAAQI,aAAa,QAAST,EAAiBK,EAAQC,WAAaD,EAAQC,UAAUI,SAAW,GAAIJ,GAEzG,CAnBA,iC,mCCQe,SAASK,EAASN,EAASC,GACpCD,EAAQE,UAAWF,EAAQE,UAAU1Q,IAAIyQ,GCHhC,SAAkBD,EAASC,GACxC,OAAID,EAAQE,YAAoBD,GAAaD,EAAQE,UAAUK,SAASN,IACkC,KAAlG,KAAOD,EAAQC,UAAUI,SAAWL,EAAQC,WAAa,KAAKO,QAAQ,IAAMP,EAAY,IAClG,CDAoEQ,CAAST,EAASC,KAA6C,kBAAtBD,EAAQC,UAAwBD,EAAQC,UAAYD,EAAQC,UAAY,IAAMA,EAAeD,EAAQI,aAAa,SAAUJ,EAAQC,WAAaD,EAAQC,UAAUI,SAAW,IAAM,IAAMJ,GACvS,C,oEERA7f,EAAQ8D,MAAQzE,EAAQ,KACxBW,EAAQV,OAASD,EAAQ,KACzBW,EAAQkE,IAAM7E,EAAQ,KACtBW,EAAQsgB,IAAMjhB,EAAQ,KACtBW,EAAQugB,IAAMlhB,EAAQ,I,mCCJtB,IAAID,EAASC,EAAQ,IACjBwE,EAAWxE,EAAQ,IAEnBmhB,EAAQ,CAAC,EAEb,SAASC,EAASC,GAChBthB,EAAOwC,MAAM8e,EAAGtgB,OAAQ,EAAG,qBAE3BZ,KAAKkhB,GAAK,IAAI7gB,MAAM,GACpB,IAAK,IAAIc,EAAI,EAAGA,EAAInB,KAAKkhB,GAAGtgB,OAAQO,IAClCnB,KAAKkhB,GAAG/f,GAAK+f,EAAG/f,EACpB,CAsBAX,EAAQ2gB,YApBR,SAAqBC,GACnB,SAASN,EAAI/gB,GACXqhB,EAAKzc,KAAK3E,KAAMD,GAChBC,KAAKqhB,UACP,CACAhd,EAASyc,EAAKM,GAGd,IADA,IAAI3c,EAAO6c,OAAO7c,KAAKuc,GACd7f,EAAI,EAAGA,EAAIsD,EAAK7D,OAAQO,IAAK,CACpC,IAAI4D,EAAMN,EAAKtD,GACf2f,EAAIrgB,UAAUsE,GAAOic,EAAMjc,EAC7B,CAMA,OAJA+b,EAAI9b,OAAS,SAAgBjF,GAC3B,OAAO,IAAI+gB,EAAI/gB,EACjB,EAEO+gB,CACT,EAIAE,EAAMK,SAAW,WACf,IAAIzc,EAAQ,IAAIqc,EAASjhB,KAAKD,QAAQmhB,IACtClhB,KAAKuhB,UAAY3c,CACnB,EAEAoc,EAAM1f,QAAU,SAAiB8D,EAAKC,EAAOhE,EAAKiE,GAChD,IAAIV,EAAQ5E,KAAKuhB,UACbC,EAAaxhB,KAAKgJ,YAAYF,OAAOrI,UAErCygB,EAAKtc,EAAMsc,GACf,GAAkB,YAAdlhB,KAAKC,KAAoB,CAC3B,IAAK,IAAIkB,EAAI,EAAGA,EAAInB,KAAKE,UAAWiB,IAClC+f,EAAG/f,IAAMiE,EAAIC,EAAQlE,GAEvBqgB,EAAWlgB,QAAQqD,KAAK3E,KAAMkhB,EAAI,EAAG7f,EAAKiE,GAE1C,IAASnE,EAAI,EAAGA,EAAInB,KAAKE,UAAWiB,IAClC+f,EAAG/f,GAAKE,EAAIiE,EAASnE,EACzB,KAAO,CACLqgB,EAAWlgB,QAAQqD,KAAK3E,KAAMoF,EAAKC,EAAOhE,EAAKiE,GAE/C,IAASnE,EAAI,EAAGA,EAAInB,KAAKE,UAAWiB,IAClCE,EAAIiE,EAASnE,IAAM+f,EAAG/f,GAExB,IAASA,EAAI,EAAGA,EAAInB,KAAKE,UAAWiB,IAClC+f,EAAG/f,GAAKiE,EAAIC,EAAQlE,EACxB,CACF,C,mCC9DA,IAAIvB,EAASC,EAAQ,IACjBwE,EAAWxE,EAAQ,IAEnBC,EAASD,EAAQ,KACjB6E,EAAM7E,EAAQ,KAElB,SAAS4hB,EAASxhB,EAAM8E,GACtBnF,EAAOwC,MAAM2C,EAAInE,OAAQ,GAAI,sBAE7B,IAAI8gB,EAAK3c,EAAIZ,MAAM,EAAG,GAClBwd,EAAK5c,EAAIZ,MAAM,EAAG,IAClByd,EAAK7c,EAAIZ,MAAM,GAAI,IAGrBnE,KAAK6hB,QADM,YAAT5hB,EACa,CACbyE,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK2c,IACnChd,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK4c,IACnCjd,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK6c,KAGtB,CACbld,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK6c,IACnCld,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK4c,IACnCjd,EAAIM,OAAO,CAAE/E,KAAM,UAAW8E,IAAK2c,IAGzC,CAEA,SAASX,EAAIhhB,GACXD,EAAO6E,KAAK3E,KAAMD,GAElB,IAAI6E,EAAQ,IAAI6c,EAASzhB,KAAKC,KAAMD,KAAKD,QAAQgF,KACjD/E,KAAK8hB,UAAYld,CACnB,CACAP,EAAS0c,EAAKjhB,GAEdS,EAAOC,QAAUugB,EAEjBA,EAAI/b,OAAS,SAAgBjF,GAC3B,OAAO,IAAIghB,EAAIhhB,EACjB,EAEAghB,EAAItgB,UAAUa,QAAU,SAAiB8D,EAAKC,EAAOhE,EAAKiE,GACxD,IAAIV,EAAQ5E,KAAK8hB,UAEjBld,EAAMid,QAAQ,GAAGvgB,QAAQ8D,EAAKC,EAAOhE,EAAKiE,GAC1CV,EAAMid,QAAQ,GAAGvgB,QAAQD,EAAKiE,EAAQjE,EAAKiE,GAC3CV,EAAMid,QAAQ,GAAGvgB,QAAQD,EAAKiE,EAAQjE,EAAKiE,EAC7C,EAEAyb,EAAItgB,UAAUyB,KAAOwC,EAAIjE,UAAUyB,KACnC6e,EAAItgB,UAAU0B,OAASuC,EAAIjE,UAAU0B,M,uBCrDrC,gBAAI4f,EAAgBliB,EAAQ,KACxBkH,EAASlH,EAAQ,KAEjBmiB,EAAKniB,EAAQ,KASjB,IAAIoiB,EAAY,CACd,QAAU,EAAM,KAAO,EAAM,QAAU,GA2BzCzhB,EAAQ0hB,mBAAqB1hB,EAAQ2hB,yBAA2B3hB,EAAQ4hB,iBAnCxE,SAA2B9Z,GACzB,IAAI8V,EAAQ,IAAI7U,EAAOxC,EAAOuB,GAAK8V,MAAO,OACtCtW,EAAM,IAAIyB,EAAOxC,EAAOuB,GAAKR,IAAK,OAEtC,OAAO,IAAIka,EAAG5D,EAAOtW,EACvB,EA+BAtH,EAAQ6hB,oBAAsB7hB,EAAQ8hB,cAzBtC,SAASD,EAAqBjE,EAAOmE,EAAKC,EAAWC,GACnD,OAAIlZ,EAAOmZ,SAASH,SAA2BzD,IAAnBmD,EAAUM,GAC7BF,EAAoBjE,EAAO,SAAUmE,EAAKC,IAGnDD,EAAMA,GAAO,SACbE,EAAOA,GAAQ,SACfD,EAAYA,GAAa,IAAIjZ,EAAO,CAAC,IAEhCA,EAAOmZ,SAASF,KACnBA,EAAY,IAAIjZ,EAAOiZ,EAAWC,IAGf,kBAAVrE,EACF,IAAI4D,EAAGD,EAAc3D,EAAOoE,GAAYA,GAAW,IAGvDjZ,EAAOmZ,SAAStE,KACnBA,EAAQ,IAAI7U,EAAO6U,EAAOmE,IAGrB,IAAIP,EAAG5D,EAAOoE,GAAW,IAClC,C,i6NCtCA,gBAAInc,EAAKxG,EAAQ,KAEb0G,EAAc,IADA1G,EAAQ,MAEtByG,EAAa,IAAID,EAAG,IACpBQ,EAAS,IAAIR,EAAG,IAChBM,EAAM,IAAIN,EAAG,IACbO,EAAQ,IAAIP,EAAG,GACfsc,EAAQ,IAAItc,EAAG,GACfU,EAASlH,EAAQ,KACjBoG,EAAcpG,EAAQ,KAG1B,SAAS+iB,EAAaC,EAAKN,GAMzB,OALAA,EAAMA,GAAO,OACRhZ,EAAOmZ,SAASG,KACnBA,EAAM,IAAItZ,EAAOsZ,EAAKN,IAExBviB,KAAK8iB,KAAO,IAAIzc,EAAGwc,GACZ7iB,IACT,CAEA,SAAS+iB,EAAcC,EAAMT,GAM3B,OALAA,EAAMA,GAAO,OACRhZ,EAAOmZ,SAASM,KACnBA,EAAO,IAAIzZ,EAAOyZ,EAAMT,IAE1BviB,KAAKijB,MAAQ,IAAI5c,EAAG2c,GACbhjB,IACT,CAlBAO,EAAOC,QAAUwhB,EAoBjB,IAAIkB,EAAa,CAAC,EAsDlB,SAASlB,EAAG5D,EAAOoE,EAAWW,GAC5BnjB,KAAKojB,aAAaZ,GAClBxiB,KAAKqjB,QAAU,IAAIhd,EAAG+X,GACtBpe,KAAKqe,OAAShY,EAAGmB,KAAKxH,KAAKqjB,SAC3BrjB,KAAKsjB,UAAYlF,EAAMxd,OACvBZ,KAAK8iB,UAAOhE,EACZ9e,KAAKijB,WAAQnE,EACb9e,KAAKujB,gBAAazE,EACdqE,GACFnjB,KAAK4iB,aAAeA,EACpB5iB,KAAK+iB,cAAgBA,GAErB/iB,KAAKujB,WAAa,CAEtB,CA0DA,SAASC,EAAkBC,EAAIlB,GAC7B,IAAImB,EAAM,IAAIna,EAAOka,EAAG3Y,WACxB,OAAKyX,EAGImB,EAAIzf,SAASse,GAFbmB,CAIX,CAhEApC,OAAOqC,eAAe3B,EAAGvhB,UAAW,cAAe,CACjDmjB,YAAY,EACZC,IAAK,WAIH,MAH+B,kBAApB7jB,KAAKujB,aACdvjB,KAAKujB,WAxEX,SAAoBnF,EAAOoE,GACzB,IAAI1a,EAAM0a,EAAUve,SAAS,OACzB6f,EAAM,CAAChc,EAAKsW,EAAMna,SAAS,KAAKG,KAAK,KACzC,GAAI0f,KAAOZ,EACT,OAAOA,EAAWY,GAEpB,IAyBIC,EAzBAC,EAAQ,EAEZ,GAAI5F,EAAMlW,WACPnB,EAAOZ,cACPY,EAAOX,WAAWgY,KAClB7X,EAAYiC,KAAK4V,GAclB,OAZA4F,GAAS,EAKPA,GAHU,OAARlc,GAAwB,OAARA,EAGT,EAIA,EAEXob,EAAWY,GAAOE,EACXA,EAOT,OALKzd,EAAYiC,KAAK4V,EAAM7V,KAAK,MAE/Byb,GAAS,GAGHlc,GACN,IAAK,KACCsW,EAAM9V,IAAIhC,GAAY+B,IAAIxB,KAE5Bmd,GAAS,GAEX,MACF,IAAK,MACHD,EAAM3F,EAAM9V,IAAI3B,IACR0B,IAAIzB,IAAUmd,EAAI1b,IAAIsa,KAE5BqB,GAAS,GAEX,MACF,QACEA,GAAS,EAGb,OADAd,EAAWY,GAAOE,EACXA,CACT,CAqBwBC,CAAWjkB,KAAKqjB,QAASrjB,KAAKkkB,QAE3ClkB,KAAKujB,UACd,IAEFvB,EAAGvhB,UAAU0jB,aAAe,WAK1B,OAJKnkB,KAAKijB,QACRjjB,KAAKijB,MAAQ,IAAI5c,EAAGJ,EAAYjG,KAAKsjB,aAEvCtjB,KAAK8iB,KAAO9iB,KAAKokB,KAAK3c,MAAMzH,KAAKqe,QAAQ3W,OAAO1H,KAAKijB,OAAOrb,UACrD5H,KAAKqkB,cACd,EAEArC,EAAGvhB,UAAU6jB,cAAgB,SAAUC,GAGrC,IAAIC,GADJD,GADAA,EAAQ,IAAIle,EAAGke,IACD9c,MAAMzH,KAAKqe,SACN3W,OAAO1H,KAAKijB,OAAOrb,UAClCvG,EAAM,IAAIkI,EAAOib,EAAO1Z,WACxBsT,EAAQpe,KAAKykB,WACjB,GAAIpjB,EAAIT,OAASwd,EAAMxd,OAAQ,CAC7B,IAAI8jB,EAAQ,IAAInb,EAAO6U,EAAMxd,OAASS,EAAIT,QAC1C8jB,EAAMC,KAAK,GACXtjB,EAAMkI,EAAOtH,OAAO,CAACyiB,EAAOrjB,GAC9B,CACA,OAAOA,CACT,EAEA2gB,EAAGvhB,UAAU4jB,aAAe,SAAsB9B,GAChD,OAAOiB,EAAkBxjB,KAAK8iB,KAAMP,EACtC,EAEAP,EAAGvhB,UAAUmkB,cAAgB,SAAuBrC,GAClD,OAAOiB,EAAkBxjB,KAAKijB,MAAOV,EACvC,EAEAP,EAAGvhB,UAAUgkB,SAAW,SAAUlC,GAChC,OAAOiB,EAAkBxjB,KAAKqjB,QAASd,EACzC,EAEAP,EAAGvhB,UAAUokB,aAAe,SAAUtC,GACpC,OAAOiB,EAAkBxjB,KAAKokB,KAAM7B,EACtC,EAEAP,EAAGvhB,UAAU2iB,aAAe,SAAUtb,EAAKya,GAOzC,OANAA,EAAMA,GAAO,OACRhZ,EAAOmZ,SAAS5a,KACnBA,EAAM,IAAIyB,EAAOzB,EAAKya,IAExBviB,KAAKkkB,MAAQpc,EACb9H,KAAKokB,KAAO,IAAI/d,EAAGyB,GACZ9H,IACT,C,6DCxJA,IAAIuJ,EAAS1J,EAAQ,IAAe0J,OAEhCub,EAAsBjlB,EAAQ,KAE9BklB,EAAY,IAehB,SAASC,EAAkBC,GAC1B,GAAI1b,EAAOmZ,SAASuC,GACnB,OAAOA,EACD,GAAI,kBAAoBA,EAC9B,OAAO1b,EAAO2b,KAAKD,EAAW,UAG/B,MAAM,IAAIE,UAAU,sDACrB,CAuFA,SAASC,EAAa1B,EAAKvZ,EAAOkb,GAEjC,IADA,IAAI3Y,EAAU,EACPvC,EAAQuC,EAAU2Y,GAAiC,IAAzB3B,EAAIvZ,EAAQuC,MAC1CA,EAQH,OALgBgX,EAAIvZ,EAAQuC,IAAYqY,KAErCrY,EAGIA,CACR,CAuDAnM,EAAOC,QAAU,CAChB8kB,UAzJD,SAAmBL,EAAWM,GAC7BN,EAAYD,EAAkBC,GAC9B,IAAIO,EAAaV,EAAoBS,GAIjCE,EAAwBD,EAAa,EAErCE,EAAcT,EAAUrkB,OAExB+kB,EAAS,EACb,GA/BmBC,KA+BfX,EAAUU,KACb,MAAM,IAAIhd,MAAM,iCAGjB,IAAIkd,EAAYZ,EAAUU,KAK1B,GAJkB,MAAdE,IACHA,EAAYZ,EAAUU,MAGnBD,EAAcC,EAASE,EAC1B,MAAM,IAAIld,MAAM,8BAAgCkd,EAAY,aAAeH,EAAcC,GAAU,eAGpG,GA3CkBG,IA2Cdb,EAAUU,KACb,MAAM,IAAIhd,MAAM,yCAGjB,IAAIod,EAAUd,EAAUU,KAExB,GAAID,EAAcC,EAAS,EAAII,EAC9B,MAAM,IAAIpd,MAAM,4BAA8Bod,EAAU,aAAeL,EAAcC,EAAS,GAAK,eAGpG,GAAIF,EAAwBM,EAC3B,MAAM,IAAIpd,MAAM,4BAA8Bod,EAAU,cAAgBN,EAAwB,mBAGjG,IAAIO,EAAUL,EAGd,GAFAA,GAAUI,EA1DQD,IA4Ddb,EAAUU,KACb,MAAM,IAAIhd,MAAM,yCAGjB,IAAIsd,EAAUhB,EAAUU,KAExB,GAAID,EAAcC,IAAWM,EAC5B,MAAM,IAAItd,MAAM,4BAA8Bsd,EAAU,iBAAmBP,EAAcC,GAAU,KAGpG,GAAIF,EAAwBQ,EAC3B,MAAM,IAAItd,MAAM,4BAA8Bsd,EAAU,cAAgBR,EAAwB,mBAGjG,IAAIS,EAAUP,EAGd,IAFAA,GAAUM,KAEKP,EACd,MAAM,IAAI/c,MAAM,4CAA8C+c,EAAcC,GAAU,kBAGvF,IAAIQ,EAAWX,EAAaO,EAC3BK,EAAWZ,EAAaS,EAErBI,EAAM9c,EAAO+c,YAAYH,EAAWJ,EAAUK,EAAWH,GAE7D,IAAKN,EAAS,EAAGA,EAASQ,IAAYR,EACrCU,EAAIV,GAAU,EAEfV,EAAUzZ,KAAK6a,EAAKV,EAAQK,EAAU9kB,KAAKQ,KAAKykB,EAAU,GAAIH,EAAUD,GAIxE,IAAK,IAAI/V,EAFT2V,EAASH,EAEYG,EAAS3V,EAAIoW,IAAYT,EAC7CU,EAAIV,GAAU,EAOf,OALAV,EAAUzZ,KAAK6a,EAAKV,EAAQO,EAAUhlB,KAAKQ,KAAK0kB,EAAU,GAAIF,EAAUD,GAGxEI,GADAA,EAAMA,EAAIpiB,SAAS,WA9FjB0G,QAAQ,KAAM,IACdA,QAAQ,MAAO,KACfA,QAAQ,MAAO,IAgGlB,EAuEC4b,UAvDD,SAAmBtB,EAAWM,GAC7BN,EAAYD,EAAkBC,GAC9B,IAAIO,EAAaV,EAAoBS,GAEjCiB,EAAiBvB,EAAUrkB,OAC/B,GAAI4lB,IAAgC,EAAbhB,EACtB,MAAM,IAAIL,UAAU,IAAMI,EAAM,yBAAwC,EAAbC,EAAiB,iBAAmBgB,EAAiB,KAGjH,IAAIL,EAAWf,EAAaH,EAAW,EAAGO,GACtCY,EAAWhB,EAAaH,EAAWO,EAAYP,EAAUrkB,QACzDmlB,EAAUP,EAAaW,EACvBF,EAAUT,EAAaY,EAEvBK,EAAU,EAAQV,EAAU,EAAI,EAAIE,EAEpCS,EAAcD,EAAU1B,EAExBsB,EAAM9c,EAAO+c,aAAaI,EAAc,EAAI,GAAKD,GAEjDd,EAAS,EA8Bb,OA7BAU,EAAIV,KA5IeC,GA6Ifc,EAGHL,EAAIV,KAAYc,GAIhBJ,EAAIV,KAAYZ,IAEhBsB,EAAIV,KAAsB,IAAVc,GAEjBJ,EAAIV,KAvJcG,EAwJlBO,EAAIV,KAAYI,EACZI,EAAW,GACdE,EAAIV,KAAY,EAChBA,GAAUV,EAAUzZ,KAAK6a,EAAKV,EAAQ,EAAGH,IAEzCG,GAAUV,EAAUzZ,KAAK6a,EAAKV,EAAQQ,EAAUX,GAEjDa,EAAIV,KA/JcG,EAgKlBO,EAAIV,KAAYM,EACZG,EAAW,GACdC,EAAIV,KAAY,EAChBV,EAAUzZ,KAAK6a,EAAKV,EAAQH,IAE5BP,EAAUzZ,KAAK6a,EAAKV,EAAQH,EAAaY,GAGnCC,CACR,E,mCCnLA,SAASM,EAAaC,GAErB,OADeA,EAAU,EAAK,IAAMA,EAAU,IAAM,EAAI,EAAI,EAE7D,CAEA,IAAIC,EAAmB,CACtBC,MAAOH,EAAa,KACpBI,MAAOJ,EAAa,KACpBK,MAAOL,EAAa,MAYrBpmB,EAAOC,QATP,SAA6B+kB,GAC5B,IAAIC,EAAaqB,EAAiBtB,GAClC,GAAIC,EACH,OAAOA,EAGR,MAAM,IAAI7c,MAAM,sBAAwB4c,EAAM,IAC/C,C","file":"static/js/main~b5906859.20a3cd18.chunk.js","sourcesContent":["'use strict';\n\nvar assert = require('minimalistic-assert');\n\nfunction Cipher(options) {\n this.options = options;\n\n this.type = this.options.type;\n this.blockSize = 8;\n this._init();\n\n this.buffer = new Array(this.blockSize);\n this.bufferOff = 0;\n}\nmodule.exports = Cipher;\n\nCipher.prototype._init = function _init() {\n // Might be overrided\n};\n\nCipher.prototype.update = function update(data) {\n if (data.length === 0)\n return [];\n\n if (this.type === 'decrypt')\n return this._updateDecrypt(data);\n else\n return this._updateEncrypt(data);\n};\n\nCipher.prototype._buffer = function _buffer(data, off) {\n // Append data to buffer\n var min = Math.min(this.buffer.length - this.bufferOff, data.length - off);\n for (var i = 0; i < min; i++)\n this.buffer[this.bufferOff + i] = data[off + i];\n this.bufferOff += min;\n\n // Shift next\n return min;\n};\n\nCipher.prototype._flushBuffer = function _flushBuffer(out, off) {\n this._update(this.buffer, 0, out, off);\n this.bufferOff = 0;\n return this.blockSize;\n};\n\nCipher.prototype._updateEncrypt = function _updateEncrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = ((this.bufferOff + data.length) / this.blockSize) | 0;\n var out = new Array(count * this.blockSize);\n\n if (this.bufferOff !== 0) {\n inputOff += this._buffer(data, inputOff);\n\n if (this.bufferOff === this.buffer.length)\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Write blocks\n var max = data.length - ((data.length - inputOff) % this.blockSize);\n for (; inputOff < max; inputOff += this.blockSize) {\n this._update(data, inputOff, out, outputOff);\n outputOff += this.blockSize;\n }\n\n // Queue rest\n for (; inputOff < data.length; inputOff++, this.bufferOff++)\n this.buffer[this.bufferOff] = data[inputOff];\n\n return out;\n};\n\nCipher.prototype._updateDecrypt = function _updateDecrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1;\n var out = new Array(count * this.blockSize);\n\n // TODO(indutny): optimize it, this is far from optimal\n for (; count > 0; count--) {\n inputOff += this._buffer(data, inputOff);\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Buffer rest of the input\n inputOff += this._buffer(data, inputOff);\n\n return out;\n};\n\nCipher.prototype.final = function final(buffer) {\n var first;\n if (buffer)\n first = this.update(buffer);\n\n var last;\n if (this.type === 'encrypt')\n last = this._finalEncrypt();\n else\n last = this._finalDecrypt();\n\n if (first)\n return first.concat(last);\n else\n return last;\n};\n\nCipher.prototype._pad = function _pad(buffer, off) {\n if (off === 0)\n return false;\n\n while (off < buffer.length)\n buffer[off++] = 0;\n\n return true;\n};\n\nCipher.prototype._finalEncrypt = function _finalEncrypt() {\n if (!this._pad(this.buffer, this.bufferOff))\n return [];\n\n var out = new Array(this.blockSize);\n this._update(this.buffer, 0, out, 0);\n return out;\n};\n\nCipher.prototype._unpad = function _unpad(buffer) {\n return buffer;\n};\n\nCipher.prototype._finalDecrypt = function _finalDecrypt() {\n assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt');\n var out = new Array(this.blockSize);\n this._flushBuffer(out, 0);\n\n return this._unpad(out);\n};\n","'use strict';\n\nexports.readUInt32BE = function readUInt32BE(bytes, off) {\n var res = (bytes[0 + off] << 24) |\n (bytes[1 + off] << 16) |\n (bytes[2 + off] << 8) |\n bytes[3 + off];\n return res >>> 0;\n};\n\nexports.writeUInt32BE = function writeUInt32BE(bytes, value, off) {\n bytes[0 + off] = value >>> 24;\n bytes[1 + off] = (value >>> 16) & 0xff;\n bytes[2 + off] = (value >>> 8) & 0xff;\n bytes[3 + off] = value & 0xff;\n};\n\nexports.ip = function ip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n }\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.rip = function rip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 0; i < 4; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n for (var i = 4; i < 8; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.pc1 = function pc1(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n // 7, 15, 23, 31, 39, 47, 55, 63\n // 6, 14, 22, 30, 39, 47, 55, 63\n // 5, 13, 21, 29, 39, 47, 55, 63\n // 4, 12, 20, 28\n for (var i = 7; i >= 5; i--) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n\n // 1, 9, 17, 25, 33, 41, 49, 57\n // 2, 10, 18, 26, 34, 42, 50, 58\n // 3, 11, 19, 27, 35, 43, 51, 59\n // 36, 44, 52, 60\n for (var i = 1; i <= 3; i++) {\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.r28shl = function r28shl(num, shift) {\n return ((num << shift) & 0xfffffff) | (num >>> (28 - shift));\n};\n\nvar pc2table = [\n // inL => outL\n 14, 11, 17, 4, 27, 23, 25, 0,\n 13, 22, 7, 18, 5, 9, 16, 24,\n 2, 20, 12, 21, 1, 8, 15, 26,\n\n // inR => outR\n 15, 4, 25, 19, 9, 1, 26, 16,\n 5, 11, 23, 8, 12, 7, 17, 0,\n 22, 3, 10, 14, 6, 20, 27, 24\n];\n\nexports.pc2 = function pc2(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n var len = pc2table.length >>> 1;\n for (var i = 0; i < len; i++) {\n outL <<= 1;\n outL |= (inL >>> pc2table[i]) & 0x1;\n }\n for (var i = len; i < pc2table.length; i++) {\n outR <<= 1;\n outR |= (inR >>> pc2table[i]) & 0x1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.expand = function expand(r, out, off) {\n var outL = 0;\n var outR = 0;\n\n outL = ((r & 1) << 5) | (r >>> 27);\n for (var i = 23; i >= 15; i -= 4) {\n outL <<= 6;\n outL |= (r >>> i) & 0x3f;\n }\n for (var i = 11; i >= 3; i -= 4) {\n outR |= (r >>> i) & 0x3f;\n outR <<= 6;\n }\n outR |= ((r & 0x1f) << 1) | (r >>> 31);\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nvar sTable = [\n 14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1,\n 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8,\n 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7,\n 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13,\n\n 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14,\n 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5,\n 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2,\n 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9,\n\n 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10,\n 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1,\n 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7,\n 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12,\n\n 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3,\n 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9,\n 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8,\n 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14,\n\n 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1,\n 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6,\n 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13,\n 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3,\n\n 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5,\n 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8,\n 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10,\n 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13,\n\n 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10,\n 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6,\n 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7,\n 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12,\n\n 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4,\n 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2,\n 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13,\n 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11\n];\n\nexports.substitute = function substitute(inL, inR) {\n var out = 0;\n for (var i = 0; i < 4; i++) {\n var b = (inL >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n for (var i = 0; i < 4; i++) {\n var b = (inR >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[4 * 0x40 + i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n return out >>> 0;\n};\n\nvar permuteTable = [\n 16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22,\n 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7\n];\n\nexports.permute = function permute(num) {\n var out = 0;\n for (var i = 0; i < permuteTable.length; i++) {\n out <<= 1;\n out |= (num >>> permuteTable[i]) & 0x1;\n }\n return out >>> 0;\n};\n\nexports.padSplit = function padSplit(num, size, group) {\n var str = num.toString(2);\n while (str.length < size)\n str = '0' + str;\n\n var out = [];\n for (var i = 0; i < size; i += group)\n out.push(str.slice(i, i + group));\n return out.join(' ');\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar utils = require('./utils');\nvar Cipher = require('./cipher');\n\nfunction DESState() {\n this.tmp = new Array(2);\n this.keys = null;\n}\n\nfunction DES(options) {\n Cipher.call(this, options);\n\n var state = new DESState();\n this._desState = state;\n\n this.deriveKeys(state, options.key);\n}\ninherits(DES, Cipher);\nmodule.exports = DES;\n\nDES.create = function create(options) {\n return new DES(options);\n};\n\nvar shiftTable = [\n 1, 1, 2, 2, 2, 2, 2, 2,\n 1, 2, 2, 2, 2, 2, 2, 1\n];\n\nDES.prototype.deriveKeys = function deriveKeys(state, key) {\n state.keys = new Array(16 * 2);\n\n assert.equal(key.length, this.blockSize, 'Invalid key length');\n\n var kL = utils.readUInt32BE(key, 0);\n var kR = utils.readUInt32BE(key, 4);\n\n utils.pc1(kL, kR, state.tmp, 0);\n kL = state.tmp[0];\n kR = state.tmp[1];\n for (var i = 0; i < state.keys.length; i += 2) {\n var shift = shiftTable[i >>> 1];\n kL = utils.r28shl(kL, shift);\n kR = utils.r28shl(kR, shift);\n utils.pc2(kL, kR, state.keys, i);\n }\n};\n\nDES.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._desState;\n\n var l = utils.readUInt32BE(inp, inOff);\n var r = utils.readUInt32BE(inp, inOff + 4);\n\n // Initial Permutation\n utils.ip(l, r, state.tmp, 0);\n l = state.tmp[0];\n r = state.tmp[1];\n\n if (this.type === 'encrypt')\n this._encrypt(state, l, r, state.tmp, 0);\n else\n this._decrypt(state, l, r, state.tmp, 0);\n\n l = state.tmp[0];\n r = state.tmp[1];\n\n utils.writeUInt32BE(out, l, outOff);\n utils.writeUInt32BE(out, r, outOff + 4);\n};\n\nDES.prototype._pad = function _pad(buffer, off) {\n var value = buffer.length - off;\n for (var i = off; i < buffer.length; i++)\n buffer[i] = value;\n\n return true;\n};\n\nDES.prototype._unpad = function _unpad(buffer) {\n var pad = buffer[buffer.length - 1];\n for (var i = buffer.length - pad; i < buffer.length; i++)\n assert.equal(buffer[i], pad);\n\n return buffer.slice(0, buffer.length - pad);\n};\n\nDES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) {\n var l = lStart;\n var r = rStart;\n\n // Apply f() x16 times\n for (var i = 0; i < state.keys.length; i += 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(r, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = r;\n r = (l ^ f) >>> 0;\n l = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(r, l, out, off);\n};\n\nDES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) {\n var l = rStart;\n var r = lStart;\n\n // Apply f() x16 times\n for (var i = state.keys.length - 2; i >= 0; i -= 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(l, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = l;\n l = (r ^ f) >>> 0;\n r = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(l, r, out, off);\n};\n","var randomBytes = require('randombytes');\nmodule.exports = findPrime;\nfindPrime.simpleSieve = simpleSieve;\nfindPrime.fermatTest = fermatTest;\nvar BN = require('bn.js');\nvar TWENTYFOUR = new BN(24);\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar ONE = new BN(1);\nvar TWO = new BN(2);\nvar FIVE = new BN(5);\nvar SIXTEEN = new BN(16);\nvar EIGHT = new BN(8);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar ELEVEN = new BN(11);\nvar FOUR = new BN(4);\nvar TWELVE = new BN(12);\nvar primes = null;\n\nfunction _getPrimes() {\n if (primes !== null)\n return primes;\n\n var limit = 0x100000;\n var res = [];\n res[0] = 2;\n for (var i = 1, k = 3; k < limit; k += 2) {\n var sqrt = Math.ceil(Math.sqrt(k));\n for (var j = 0; j < i && res[j] <= sqrt; j++)\n if (k % res[j] === 0)\n break;\n\n if (i !== j && res[j] <= sqrt)\n continue;\n\n res[i++] = k;\n }\n primes = res;\n return res;\n}\n\nfunction simpleSieve(p) {\n var primes = _getPrimes();\n\n for (var i = 0; i < primes.length; i++)\n if (p.modn(primes[i]) === 0) {\n if (p.cmpn(primes[i]) === 0) {\n return true;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\nfunction fermatTest(p) {\n var red = BN.mont(p);\n return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0;\n}\n\nfunction findPrime(bits, gen) {\n if (bits < 16) {\n // this is what openssl does\n if (gen === 2 || gen === 5) {\n return new BN([0x8c, 0x7b]);\n } else {\n return new BN([0x8c, 0x27]);\n }\n }\n gen = new BN(gen);\n\n var num, n2;\n\n while (true) {\n num = new BN(randomBytes(Math.ceil(bits / 8)));\n while (num.bitLength() > bits) {\n num.ishrn(1);\n }\n if (num.isEven()) {\n num.iadd(ONE);\n }\n if (!num.testn(1)) {\n num.iadd(TWO);\n }\n if (!gen.cmp(TWO)) {\n while (num.mod(TWENTYFOUR).cmp(ELEVEN)) {\n num.iadd(FOUR);\n }\n } else if (!gen.cmp(FIVE)) {\n while (num.mod(TEN).cmp(THREE)) {\n num.iadd(FOUR);\n }\n }\n n2 = num.shrn(1);\n if (simpleSieve(n2) && simpleSieve(num) &&\n fermatTest(n2) && fermatTest(num) &&\n millerRabin.test(n2) && millerRabin.test(num)) {\n return num;\n }\n }\n\n}\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n 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","function replaceClassName(origClass, classToRemove) {\n return origClass.replace(new RegExp(\"(^|\\\\s)\" + classToRemove + \"(?:\\\\s|$)\", 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n/**\n * Removes a CSS class from a given element.\n * \n * @param element the element\n * @param className the CSS class name\n */\n\n\nexport default function removeClass(element, className) {\n if (element.classList) {\n element.classList.remove(className);\n } else if (typeof element.className === 'string') {\n element.className = replaceClassName(element.className, className);\n } else {\n element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n }\n}","import hasClass from './hasClass';\n/**\n * Adds a CSS class to a given element.\n * \n * @param element the element\n * @param className the CSS class name\n */\n\nexport default function addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!hasClass(element, className)) if (typeof element.className === 'string') element.className = element.className + \" \" + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + \" \" + className);\n}","/**\n * Checks if a given element has a CSS class.\n * \n * @param element the element\n * @param className the CSS class name\n */\nexport default function hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);\n return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}","'use strict';\n\nexports.utils = require('./des/utils');\nexports.Cipher = require('./des/cipher');\nexports.DES = require('./des/des');\nexports.CBC = require('./des/cbc');\nexports.EDE = require('./des/ede');\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar proto = {};\n\nfunction CBCState(iv) {\n assert.equal(iv.length, 8, 'Invalid IV length');\n\n this.iv = new Array(8);\n for (var i = 0; i < this.iv.length; i++)\n this.iv[i] = iv[i];\n}\n\nfunction instantiate(Base) {\n function CBC(options) {\n Base.call(this, options);\n this._cbcInit();\n }\n inherits(CBC, Base);\n\n var keys = Object.keys(proto);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n CBC.prototype[key] = proto[key];\n }\n\n CBC.create = function create(options) {\n return new CBC(options);\n };\n\n return CBC;\n}\n\nexports.instantiate = instantiate;\n\nproto._cbcInit = function _cbcInit() {\n var state = new CBCState(this.options.iv);\n this._cbcState = state;\n};\n\nproto._update = function _update(inp, inOff, out, outOff) {\n var state = this._cbcState;\n var superProto = this.constructor.super_.prototype;\n\n var iv = state.iv;\n if (this.type === 'encrypt') {\n for (var i = 0; i < this.blockSize; i++)\n iv[i] ^= inp[inOff + i];\n\n superProto._update.call(this, iv, 0, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = out[outOff + i];\n } else {\n superProto._update.call(this, inp, inOff, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n out[outOff + i] ^= iv[i];\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = inp[inOff + i];\n }\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar Cipher = require('./cipher');\nvar DES = require('./des');\n\nfunction EDEState(type, key) {\n assert.equal(key.length, 24, 'Invalid key length');\n\n var k1 = key.slice(0, 8);\n var k2 = key.slice(8, 16);\n var k3 = key.slice(16, 24);\n\n if (type === 'encrypt') {\n this.ciphers = [\n DES.create({ type: 'encrypt', key: k1 }),\n DES.create({ type: 'decrypt', key: k2 }),\n DES.create({ type: 'encrypt', key: k3 })\n ];\n } else {\n this.ciphers = [\n DES.create({ type: 'decrypt', key: k3 }),\n DES.create({ type: 'encrypt', key: k2 }),\n DES.create({ type: 'decrypt', key: k1 })\n ];\n }\n}\n\nfunction EDE(options) {\n Cipher.call(this, options);\n\n var state = new EDEState(this.type, this.options.key);\n this._edeState = state;\n}\ninherits(EDE, Cipher);\n\nmodule.exports = EDE;\n\nEDE.create = function create(options) {\n return new EDE(options);\n};\n\nEDE.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._edeState;\n\n state.ciphers[0]._update(inp, inOff, out, outOff);\n state.ciphers[1]._update(out, outOff, out, outOff);\n state.ciphers[2]._update(out, outOff, out, outOff);\n};\n\nEDE.prototype._pad = DES.prototype._pad;\nEDE.prototype._unpad = DES.prototype._unpad;\n","var generatePrime = require('./lib/generatePrime')\nvar primes = require('./lib/primes.json')\n\nvar DH = require('./lib/dh')\n\nfunction getDiffieHellman (mod) {\n var prime = new Buffer(primes[mod].prime, 'hex')\n var gen = new Buffer(primes[mod].gen, 'hex')\n\n return new DH(prime, gen)\n}\n\nvar ENCODINGS = {\n 'binary': true, 'hex': true, 'base64': true\n}\n\nfunction createDiffieHellman (prime, enc, generator, genc) {\n if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) {\n return createDiffieHellman(prime, 'binary', enc, generator)\n }\n\n enc = enc || 'binary'\n genc = genc || 'binary'\n generator = generator || new Buffer([2])\n\n if (!Buffer.isBuffer(generator)) {\n generator = new Buffer(generator, genc)\n }\n\n if (typeof prime === 'number') {\n return new DH(generatePrime(prime, generator), generator, true)\n }\n\n if (!Buffer.isBuffer(prime)) {\n prime = new Buffer(prime, enc)\n }\n\n return new DH(prime, generator, true)\n}\n\nexports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman\nexports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman\n","var BN = require('bn.js');\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar TWENTYFOUR = new BN(24);\nvar ELEVEN = new BN(11);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar primes = require('./generatePrime');\nvar randomBytes = require('randombytes');\nmodule.exports = DH;\n\nfunction setPublicKey(pub, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc);\n }\n this._pub = new BN(pub);\n return this;\n}\n\nfunction setPrivateKey(priv, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc);\n }\n this._priv = new BN(priv);\n return this;\n}\n\nvar primeCache = {};\nfunction checkPrime(prime, generator) {\n var gen = generator.toString('hex');\n var hex = [gen, prime.toString(16)].join('_');\n if (hex in primeCache) {\n return primeCache[hex];\n }\n var error = 0;\n\n if (prime.isEven() ||\n !primes.simpleSieve ||\n !primes.fermatTest(prime) ||\n !millerRabin.test(prime)) {\n //not a prime so +1\n error += 1;\n\n if (gen === '02' || gen === '05') {\n // we'd be able to check the generator\n // it would fail so +8\n error += 8;\n } else {\n //we wouldn't be able to test the generator\n // so +4\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n }\n if (!millerRabin.test(prime.shrn(1))) {\n //not a safe prime\n error += 2;\n }\n var rem;\n switch (gen) {\n case '02':\n if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) {\n // unsuidable generator\n error += 8;\n }\n break;\n case '05':\n rem = prime.mod(TEN);\n if (rem.cmp(THREE) && rem.cmp(SEVEN)) {\n // prime mod 10 needs to equal 3 or 7\n error += 8;\n }\n break;\n default:\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n}\n\nfunction DH(prime, generator, malleable) {\n this.setGenerator(generator);\n this.__prime = new BN(prime);\n this._prime = BN.mont(this.__prime);\n this._primeLen = prime.length;\n this._pub = undefined;\n this._priv = undefined;\n this._primeCode = undefined;\n if (malleable) {\n this.setPublicKey = setPublicKey;\n this.setPrivateKey = setPrivateKey;\n } else {\n this._primeCode = 8;\n }\n}\nObject.defineProperty(DH.prototype, 'verifyError', {\n enumerable: true,\n get: function () {\n if (typeof this._primeCode !== 'number') {\n this._primeCode = checkPrime(this.__prime, this.__gen);\n }\n return this._primeCode;\n }\n});\nDH.prototype.generateKeys = function () {\n if (!this._priv) {\n this._priv = new BN(randomBytes(this._primeLen));\n }\n this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed();\n return this.getPublicKey();\n};\n\nDH.prototype.computeSecret = function (other) {\n other = new BN(other);\n other = other.toRed(this._prime);\n var secret = other.redPow(this._priv).fromRed();\n var out = new Buffer(secret.toArray());\n var prime = this.getPrime();\n if (out.length < prime.length) {\n var front = new Buffer(prime.length - out.length);\n front.fill(0);\n out = Buffer.concat([front, out]);\n }\n return out;\n};\n\nDH.prototype.getPublicKey = function getPublicKey(enc) {\n return formatReturnValue(this._pub, enc);\n};\n\nDH.prototype.getPrivateKey = function getPrivateKey(enc) {\n return formatReturnValue(this._priv, enc);\n};\n\nDH.prototype.getPrime = function (enc) {\n return formatReturnValue(this.__prime, enc);\n};\n\nDH.prototype.getGenerator = function (enc) {\n return formatReturnValue(this._gen, enc);\n};\n\nDH.prototype.setGenerator = function (gen, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(gen)) {\n gen = new Buffer(gen, enc);\n }\n this.__gen = gen;\n this._gen = new BN(gen);\n return this;\n};\n\nfunction formatReturnValue(bn, enc) {\n var buf = new Buffer(bn.toArray());\n if (!enc) {\n return buf;\n } else {\n return buf.toString(enc);\n }\n}\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\n\nvar getParamBytesForAlg = require('./param-bytes-for-alg');\n\nvar MAX_OCTET = 0x80,\n\tCLASS_UNIVERSAL = 0,\n\tPRIMITIVE_BIT = 0x20,\n\tTAG_SEQ = 0x10,\n\tTAG_INT = 0x02,\n\tENCODED_TAG_SEQ = (TAG_SEQ | PRIMITIVE_BIT) | (CLASS_UNIVERSAL << 6),\n\tENCODED_TAG_INT = TAG_INT | (CLASS_UNIVERSAL << 6);\n\nfunction base64Url(base64) {\n\treturn base64\n\t\t.replace(/=/g, '')\n\t\t.replace(/\\+/g, '-')\n\t\t.replace(/\\//g, '_');\n}\n\nfunction signatureAsBuffer(signature) {\n\tif (Buffer.isBuffer(signature)) {\n\t\treturn signature;\n\t} else if ('string' === typeof signature) {\n\t\treturn Buffer.from(signature, 'base64');\n\t}\n\n\tthrow new TypeError('ECDSA signature must be a Base64 string or a Buffer');\n}\n\nfunction derToJose(signature, alg) {\n\tsignature = signatureAsBuffer(signature);\n\tvar paramBytes = getParamBytesForAlg(alg);\n\n\t// the DER encoded param should at most be the param size, plus a padding\n\t// zero, since due to being a signed integer\n\tvar maxEncodedParamLength = paramBytes + 1;\n\n\tvar inputLength = signature.length;\n\n\tvar offset = 0;\n\tif (signature[offset++] !== ENCODED_TAG_SEQ) {\n\t\tthrow new Error('Could not find expected \"seq\"');\n\t}\n\n\tvar seqLength = signature[offset++];\n\tif (seqLength === (MAX_OCTET | 1)) {\n\t\tseqLength = signature[offset++];\n\t}\n\n\tif (inputLength - offset < seqLength) {\n\t\tthrow new Error('\"seq\" specified length of \"' + seqLength + '\", only \"' + (inputLength - offset) + '\" remaining');\n\t}\n\n\tif (signature[offset++] !== ENCODED_TAG_INT) {\n\t\tthrow new Error('Could not find expected \"int\" for \"r\"');\n\t}\n\n\tvar rLength = signature[offset++];\n\n\tif (inputLength - offset - 2 < rLength) {\n\t\tthrow new Error('\"r\" specified length of \"' + rLength + '\", only \"' + (inputLength - offset - 2) + '\" available');\n\t}\n\n\tif (maxEncodedParamLength < rLength) {\n\t\tthrow new Error('\"r\" specified length of \"' + rLength + '\", max of \"' + maxEncodedParamLength + '\" is acceptable');\n\t}\n\n\tvar rOffset = offset;\n\toffset += rLength;\n\n\tif (signature[offset++] !== ENCODED_TAG_INT) {\n\t\tthrow new Error('Could not find expected \"int\" for \"s\"');\n\t}\n\n\tvar sLength = signature[offset++];\n\n\tif (inputLength - offset !== sLength) {\n\t\tthrow new Error('\"s\" specified length of \"' + sLength + '\", expected \"' + (inputLength - offset) + '\"');\n\t}\n\n\tif (maxEncodedParamLength < sLength) {\n\t\tthrow new Error('\"s\" specified length of \"' + sLength + '\", max of \"' + maxEncodedParamLength + '\" is acceptable');\n\t}\n\n\tvar sOffset = offset;\n\toffset += sLength;\n\n\tif (offset !== inputLength) {\n\t\tthrow new Error('Expected to consume entire buffer, but \"' + (inputLength - offset) + '\" bytes remain');\n\t}\n\n\tvar rPadding = paramBytes - rLength,\n\t\tsPadding = paramBytes - sLength;\n\n\tvar dst = Buffer.allocUnsafe(rPadding + rLength + sPadding + sLength);\n\n\tfor (offset = 0; offset < rPadding; ++offset) {\n\t\tdst[offset] = 0;\n\t}\n\tsignature.copy(dst, offset, rOffset + Math.max(-rPadding, 0), rOffset + rLength);\n\n\toffset = paramBytes;\n\n\tfor (var o = offset; offset < o + sPadding; ++offset) {\n\t\tdst[offset] = 0;\n\t}\n\tsignature.copy(dst, offset, sOffset + Math.max(-sPadding, 0), sOffset + sLength);\n\n\tdst = dst.toString('base64');\n\tdst = base64Url(dst);\n\n\treturn dst;\n}\n\nfunction countPadding(buf, start, stop) {\n\tvar padding = 0;\n\twhile (start + padding < stop && buf[start + padding] === 0) {\n\t\t++padding;\n\t}\n\n\tvar needsSign = buf[start + padding] >= MAX_OCTET;\n\tif (needsSign) {\n\t\t--padding;\n\t}\n\n\treturn padding;\n}\n\nfunction joseToDer(signature, alg) {\n\tsignature = signatureAsBuffer(signature);\n\tvar paramBytes = getParamBytesForAlg(alg);\n\n\tvar signatureBytes = signature.length;\n\tif (signatureBytes !== paramBytes * 2) {\n\t\tthrow new TypeError('\"' + alg + '\" signatures must be \"' + paramBytes * 2 + '\" bytes, saw \"' + signatureBytes + '\"');\n\t}\n\n\tvar rPadding = countPadding(signature, 0, paramBytes);\n\tvar sPadding = countPadding(signature, paramBytes, signature.length);\n\tvar rLength = paramBytes - rPadding;\n\tvar sLength = paramBytes - sPadding;\n\n\tvar rsBytes = 1 + 1 + rLength + 1 + 1 + sLength;\n\n\tvar shortLength = rsBytes < MAX_OCTET;\n\n\tvar dst = Buffer.allocUnsafe((shortLength ? 2 : 3) + rsBytes);\n\n\tvar offset = 0;\n\tdst[offset++] = ENCODED_TAG_SEQ;\n\tif (shortLength) {\n\t\t// Bit 8 has value \"0\"\n\t\t// bits 7-1 give the length.\n\t\tdst[offset++] = rsBytes;\n\t} else {\n\t\t// Bit 8 of first octet has value \"1\"\n\t\t// bits 7-1 give the number of additional length octets.\n\t\tdst[offset++] = MAX_OCTET\t| 1;\n\t\t// length, base 256\n\t\tdst[offset++] = rsBytes & 0xff;\n\t}\n\tdst[offset++] = ENCODED_TAG_INT;\n\tdst[offset++] = rLength;\n\tif (rPadding < 0) {\n\t\tdst[offset++] = 0;\n\t\toffset += signature.copy(dst, offset, 0, paramBytes);\n\t} else {\n\t\toffset += signature.copy(dst, offset, rPadding, paramBytes);\n\t}\n\tdst[offset++] = ENCODED_TAG_INT;\n\tdst[offset++] = sLength;\n\tif (sPadding < 0) {\n\t\tdst[offset++] = 0;\n\t\tsignature.copy(dst, offset, paramBytes);\n\t} else {\n\t\tsignature.copy(dst, offset, paramBytes + sPadding);\n\t}\n\n\treturn dst;\n}\n\nmodule.exports = {\n\tderToJose: derToJose,\n\tjoseToDer: joseToDer\n};\n","'use strict';\n\nfunction getParamSize(keySize) {\n\tvar result = ((keySize / 8) | 0) + (keySize % 8 === 0 ? 0 : 1);\n\treturn result;\n}\n\nvar paramBytesForAlg = {\n\tES256: getParamSize(256),\n\tES384: getParamSize(384),\n\tES512: getParamSize(521)\n};\n\nfunction getParamBytesForAlg(alg) {\n\tvar paramBytes = paramBytesForAlg[alg];\n\tif (paramBytes) {\n\t\treturn paramBytes;\n\t}\n\n\tthrow new Error('Unknown algorithm \"' + alg + '\"');\n}\n\nmodule.exports = getParamBytesForAlg;\n"],"sourceRoot":""}