| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826138271382813829138301383113832138331383413835138361383713838138391384013841138421384313844138451384613847138481384913850138511385213853138541385513856138571385813859138601386113862138631386413865138661386713868138691387013871138721387313874138751387613877138781387913880138811388213883138841388513886138871388813889138901389113892138931389413895138961389713898138991390013901139021390313904139051390613907139081390913910139111391213913139141391513916139171391813919139201392113922139231392413925139261392713928139291393013931139321393313934139351393613937139381393913940139411394213943139441394513946139471394813949139501395113952139531395413955139561395713958139591396013961139621396313964139651396613967139681396913970139711397213973139741397513976139771397813979139801398113982139831398413985139861398713988139891399013991139921399313994139951399613997139981399914000140011400214003140041400514006140071400814009140101401114012140131401414015140161401714018140191402014021140221402314024140251402614027140281402914030140311403214033140341403514036140371403814039140401404114042140431404414045140461404714048140491405014051140521405314054140551405614057140581405914060140611406214063140641406514066140671406814069140701407114072140731407414075140761407714078140791408014081140821408314084140851408614087140881408914090140911409214093140941409514096140971409814099141001410114102141031410414105141061410714108141091411014111141121411314114141151411614117141181411914120141211412214123141241412514126141271412814129141301413114132141331413414135141361413714138141391414014141141421414314144141451414614147141481414914150141511415214153141541415514156141571415814159141601416114162141631416414165141661416714168141691417014171141721417314174141751417614177141781417914180141811418214183141841418514186141871418814189141901419114192141931419414195141961419714198141991420014201142021420314204142051420614207142081420914210142111421214213142141421514216142171421814219142201422114222142231422414225142261422714228142291423014231142321423314234142351423614237142381423914240142411424214243142441424514246142471424814249142501425114252142531425414255142561425714258142591426014261142621426314264142651426614267142681426914270142711427214273142741427514276142771427814279142801428114282142831428414285142861428714288142891429014291142921429314294142951429614297142981429914300143011430214303143041430514306143071430814309143101431114312143131431414315143161431714318143191432014321143221432314324143251432614327143281432914330143311433214333143341433514336143371433814339143401434114342143431434414345143461434714348143491435014351143521435314354143551435614357143581435914360143611436214363143641436514366143671436814369143701437114372143731437414375143761437714378143791438014381143821438314384143851438614387143881438914390143911439214393143941439514396143971439814399144001440114402144031440414405144061440714408144091441014411144121441314414144151441614417144181441914420144211442214423144241442514426144271442814429144301443114432144331443414435144361443714438144391444014441144421444314444144451444614447144481444914450144511445214453144541445514456144571445814459144601446114462144631446414465144661446714468144691447014471144721447314474144751447614477144781447914480144811448214483144841448514486144871448814489144901449114492144931449414495144961449714498144991450014501145021450314504145051450614507145081450914510145111451214513145141451514516145171451814519145201452114522145231452414525145261452714528145291453014531145321453314534145351453614537145381453914540145411454214543145441454514546145471454814549145501455114552145531455414555145561455714558145591456014561145621456314564145651456614567145681456914570145711457214573145741457514576145771457814579145801458114582145831458414585145861458714588145891459014591145921459314594145951459614597145981459914600146011460214603146041460514606146071460814609146101461114612146131461414615146161461714618146191462014621146221462314624146251462614627146281462914630146311463214633146341463514636146371463814639146401464114642146431464414645146461464714648146491465014651146521465314654146551465614657146581465914660146611466214663146641466514666146671466814669146701467114672146731467414675146761467714678146791468014681146821468314684146851468614687146881468914690146911469214693146941469514696146971469814699147001470114702147031470414705147061470714708147091471014711147121471314714147151471614717147181471914720147211472214723147241472514726147271472814729147301473114732147331473414735147361473714738147391474014741147421474314744147451474614747147481474914750147511475214753147541475514756147571475814759147601476114762147631476414765147661476714768147691477014771147721477314774147751477614777147781477914780147811478214783147841478514786147871478814789147901479114792147931479414795147961479714798147991480014801148021480314804148051480614807148081480914810148111481214813148141481514816148171481814819148201482114822148231482414825148261482714828148291483014831148321483314834148351483614837148381483914840148411484214843148441484514846148471484814849148501485114852148531485414855148561485714858148591486014861148621486314864148651486614867148681486914870148711487214873148741487514876148771487814879148801488114882148831488414885148861488714888148891489014891148921489314894148951489614897148981489914900149011490214903149041490514906149071490814909149101491114912149131491414915149161491714918149191492014921149221492314924149251492614927149281492914930149311493214933149341493514936149371493814939149401494114942149431494414945149461494714948149491495014951149521495314954149551495614957149581495914960149611496214963149641496514966149671496814969149701497114972149731497414975149761497714978149791498014981149821498314984149851498614987149881498914990149911499214993149941499514996149971499814999150001500115002150031500415005150061500715008150091501015011150121501315014150151501615017150181501915020150211502215023150241502515026150271502815029150301503115032150331503415035150361503715038150391504015041150421504315044150451504615047150481504915050150511505215053150541505515056150571505815059150601506115062150631506415065150661506715068150691507015071150721507315074150751507615077150781507915080150811508215083150841508515086150871508815089150901509115092150931509415095150961509715098150991510015101151021510315104151051510615107151081510915110151111511215113151141511515116151171511815119151201512115122151231512415125151261512715128151291513015131151321513315134151351513615137151381513915140151411514215143151441514515146151471514815149151501515115152151531515415155151561515715158151591516015161151621516315164151651516615167151681516915170151711517215173151741517515176151771517815179151801518115182151831518415185151861518715188151891519015191151921519315194151951519615197151981519915200152011520215203152041520515206152071520815209152101521115212152131521415215152161521715218152191522015221152221522315224152251522615227152281522915230152311523215233152341523515236152371523815239152401524115242152431524415245152461524715248152491525015251152521525315254152551525615257152581525915260152611526215263152641526515266152671526815269152701527115272152731527415275152761527715278152791528015281152821528315284152851528615287152881528915290152911529215293152941529515296152971529815299153001530115302153031530415305153061530715308153091531015311153121531315314153151531615317153181531915320153211532215323153241532515326153271532815329153301533115332153331533415335153361533715338153391534015341153421534315344153451534615347153481534915350153511535215353153541535515356153571535815359153601536115362153631536415365153661536715368153691537015371153721537315374153751537615377153781537915380153811538215383153841538515386153871538815389153901539115392153931539415395153961539715398153991540015401154021540315404154051540615407154081540915410154111541215413154141541515416154171541815419154201542115422154231542415425154261542715428154291543015431154321543315434154351543615437154381543915440154411544215443154441544515446154471544815449154501545115452154531545415455154561545715458154591546015461154621546315464154651546615467154681546915470154711547215473154741547515476154771547815479154801548115482154831548415485154861548715488154891549015491154921549315494154951549615497154981549915500155011550215503155041550515506155071550815509155101551115512155131551415515155161551715518155191552015521155221552315524155251552615527155281552915530155311553215533155341553515536155371553815539155401554115542155431554415545155461554715548155491555015551155521555315554155551555615557155581555915560155611556215563155641556515566155671556815569155701557115572155731557415575155761557715578155791558015581155821558315584155851558615587155881558915590155911559215593155941559515596155971559815599156001560115602156031560415605156061560715608156091561015611156121561315614156151561615617156181561915620156211562215623156241562515626156271562815629156301563115632156331563415635156361563715638156391564015641156421564315644156451564615647156481564915650156511565215653156541565515656156571565815659156601566115662156631566415665156661566715668156691567015671156721567315674156751567615677156781567915680156811568215683156841568515686156871568815689156901569115692156931569415695156961569715698156991570015701157021570315704157051570615707157081570915710157111571215713157141571515716157171571815719157201572115722157231572415725157261572715728157291573015731157321573315734157351573615737157381573915740157411574215743157441574515746157471574815749157501575115752157531575415755157561575715758157591576015761157621576315764157651576615767157681576915770157711577215773157741577515776157771577815779157801578115782157831578415785157861578715788157891579015791157921579315794157951579615797157981579915800158011580215803158041580515806158071580815809158101581115812158131581415815158161581715818158191582015821158221582315824158251582615827158281582915830158311583215833158341583515836158371583815839158401584115842158431584415845158461584715848158491585015851158521585315854158551585615857158581585915860158611586215863158641586515866158671586815869158701587115872158731587415875158761587715878158791588015881158821588315884158851588615887158881588915890158911589215893158941589515896158971589815899159001590115902159031590415905159061590715908159091591015911159121591315914159151591615917159181591915920159211592215923159241592515926159271592815929159301593115932159331593415935159361593715938159391594015941159421594315944159451594615947159481594915950159511595215953159541595515956159571595815959159601596115962159631596415965159661596715968159691597015971159721597315974159751597615977159781597915980159811598215983159841598515986159871598815989159901599115992159931599415995159961599715998159991600016001160021600316004160051600616007160081600916010160111601216013160141601516016160171601816019160201602116022160231602416025160261602716028160291603016031160321603316034160351603616037160381603916040160411604216043160441604516046160471604816049160501605116052160531605416055160561605716058160591606016061160621606316064160651606616067160681606916070160711607216073160741607516076160771607816079160801608116082160831608416085160861608716088160891609016091160921609316094160951609616097160981609916100161011610216103161041610516106161071610816109161101611116112161131611416115161161611716118161191612016121161221612316124161251612616127161281612916130161311613216133161341613516136161371613816139161401614116142161431614416145161461614716148161491615016151161521615316154161551615616157161581615916160161611616216163161641616516166161671616816169161701617116172161731617416175161761617716178161791618016181161821618316184161851618616187161881618916190161911619216193161941619516196161971619816199162001620116202162031620416205162061620716208162091621016211162121621316214162151621616217162181621916220162211622216223162241622516226162271622816229162301623116232162331623416235162361623716238162391624016241162421624316244162451624616247162481624916250162511625216253162541625516256162571625816259162601626116262162631626416265162661626716268162691627016271162721627316274162751627616277162781627916280162811628216283162841628516286162871628816289162901629116292162931629416295162961629716298162991630016301163021630316304163051630616307163081630916310163111631216313163141631516316163171631816319163201632116322163231632416325163261632716328163291633016331163321633316334163351633616337163381633916340163411634216343163441634516346163471634816349163501635116352163531635416355163561635716358163591636016361163621636316364163651636616367163681636916370163711637216373163741637516376163771637816379163801638116382163831638416385163861638716388163891639016391163921639316394163951639616397163981639916400164011640216403164041640516406164071640816409164101641116412164131641416415164161641716418164191642016421164221642316424164251642616427164281642916430164311643216433164341643516436164371643816439164401644116442164431644416445164461644716448164491645016451164521645316454164551645616457164581645916460164611646216463164641646516466164671646816469164701647116472164731647416475164761647716478164791648016481164821648316484164851648616487164881648916490164911649216493164941649516496164971649816499165001650116502165031650416505165061650716508165091651016511165121651316514165151651616517165181651916520165211652216523165241652516526165271652816529165301653116532165331653416535165361653716538165391654016541165421654316544165451654616547165481654916550165511655216553165541655516556165571655816559165601656116562165631656416565165661656716568165691657016571165721657316574165751657616577165781657916580165811658216583165841658516586165871658816589165901659116592165931659416595165961659716598165991660016601166021660316604166051660616607166081660916610166111661216613166141661516616166171661816619166201662116622166231662416625166261662716628166291663016631166321663316634166351663616637166381663916640166411664216643166441664516646166471664816649166501665116652166531665416655166561665716658166591666016661166621666316664166651666616667166681666916670166711667216673166741667516676166771667816679166801668116682166831668416685166861668716688166891669016691166921669316694166951669616697166981669916700167011670216703167041670516706167071670816709167101671116712167131671416715167161671716718167191672016721167221672316724167251672616727167281672916730167311673216733167341673516736167371673816739167401674116742167431674416745167461674716748167491675016751167521675316754167551675616757167581675916760167611676216763167641676516766167671676816769167701677116772167731677416775167761677716778167791678016781167821678316784167851678616787167881678916790167911679216793167941679516796167971679816799168001680116802168031680416805168061680716808168091681016811168121681316814168151681616817168181681916820168211682216823168241682516826168271682816829168301683116832168331683416835168361683716838168391684016841168421684316844168451684616847168481684916850168511685216853168541685516856168571685816859168601686116862168631686416865168661686716868168691687016871168721687316874168751687616877168781687916880168811688216883168841688516886168871688816889168901689116892168931689416895168961689716898168991690016901169021690316904169051690616907169081690916910169111691216913169141691516916169171691816919169201692116922169231692416925169261692716928169291693016931169321693316934169351693616937169381693916940169411694216943169441694516946169471694816949169501695116952169531695416955169561695716958169591696016961169621696316964169651696616967169681696916970169711697216973169741697516976169771697816979169801698116982169831698416985169861698716988169891699016991169921699316994169951699616997169981699917000170011700217003170041700517006170071700817009170101701117012170131701417015170161701717018170191702017021170221702317024170251702617027170281702917030170311703217033170341703517036170371703817039170401704117042170431704417045170461704717048170491705017051170521705317054170551705617057170581705917060170611706217063170641706517066170671706817069170701707117072170731707417075170761707717078170791708017081170821708317084170851708617087170881708917090170911709217093170941709517096170971709817099171001710117102171031710417105171061710717108171091711017111171121711317114171151711617117171181711917120171211712217123171241712517126171271712817129171301713117132171331713417135171361713717138171391714017141171421714317144171451714617147171481714917150171511715217153171541715517156171571715817159171601716117162171631716417165171661716717168171691717017171171721717317174171751717617177171781717917180171811718217183171841718517186171871718817189171901719117192171931719417195171961719717198171991720017201172021720317204172051720617207172081720917210172111721217213172141721517216172171721817219172201722117222172231722417225172261722717228172291723017231172321723317234172351723617237172381723917240172411724217243172441724517246172471724817249172501725117252172531725417255172561725717258172591726017261172621726317264172651726617267172681726917270172711727217273172741727517276172771727817279172801728117282172831728417285172861728717288172891729017291172921729317294172951729617297172981729917300173011730217303173041730517306173071730817309173101731117312173131731417315173161731717318173191732017321173221732317324173251732617327173281732917330173311733217333173341733517336173371733817339173401734117342173431734417345173461734717348173491735017351173521735317354173551735617357173581735917360173611736217363173641736517366173671736817369173701737117372173731737417375173761737717378173791738017381173821738317384173851738617387173881738917390173911739217393173941739517396173971739817399174001740117402174031740417405174061740717408174091741017411174121741317414174151741617417174181741917420174211742217423174241742517426174271742817429174301743117432174331743417435174361743717438174391744017441174421744317444174451744617447174481744917450174511745217453174541745517456174571745817459174601746117462174631746417465174661746717468174691747017471174721747317474174751747617477174781747917480174811748217483174841748517486174871748817489174901749117492174931749417495174961749717498174991750017501175021750317504175051750617507175081750917510175111751217513175141751517516175171751817519175201752117522175231752417525175261752717528175291753017531175321753317534175351753617537175381753917540175411754217543175441754517546175471754817549175501755117552175531755417555175561755717558175591756017561175621756317564175651756617567175681756917570175711757217573175741757517576175771757817579175801758117582175831758417585175861758717588175891759017591175921759317594175951759617597175981759917600176011760217603176041760517606176071760817609176101761117612176131761417615176161761717618176191762017621176221762317624176251762617627176281762917630176311763217633176341763517636176371763817639176401764117642176431764417645176461764717648176491765017651176521765317654176551765617657176581765917660176611766217663176641766517666176671766817669176701767117672176731767417675176761767717678176791768017681176821768317684176851768617687176881768917690176911769217693176941769517696176971769817699177001770117702177031770417705177061770717708177091771017711177121771317714177151771617717177181771917720177211772217723177241772517726177271772817729177301773117732177331773417735177361773717738177391774017741177421774317744177451774617747177481774917750177511775217753177541775517756177571775817759177601776117762177631776417765177661776717768177691777017771177721777317774177751777617777177781777917780177811778217783177841778517786177871778817789177901779117792177931779417795177961779717798177991780017801178021780317804178051780617807178081780917810178111781217813178141781517816178171781817819178201782117822178231782417825178261782717828178291783017831178321783317834178351783617837178381783917840178411784217843178441784517846178471784817849178501785117852178531785417855178561785717858178591786017861178621786317864178651786617867178681786917870178711787217873178741787517876178771787817879178801788117882178831788417885178861788717888178891789017891178921789317894178951789617897178981789917900179011790217903179041790517906179071790817909179101791117912179131791417915179161791717918179191792017921179221792317924179251792617927179281792917930179311793217933179341793517936179371793817939179401794117942179431794417945179461794717948179491795017951179521795317954179551795617957179581795917960179611796217963179641796517966179671796817969179701797117972179731797417975179761797717978179791798017981179821798317984179851798617987179881798917990179911799217993179941799517996179971799817999180001800118002180031800418005180061800718008180091801018011180121801318014180151801618017180181801918020180211802218023180241802518026180271802818029180301803118032180331803418035180361803718038180391804018041180421804318044180451804618047180481804918050180511805218053180541805518056180571805818059180601806118062180631806418065180661806718068180691807018071180721807318074180751807618077180781807918080180811808218083180841808518086180871808818089180901809118092180931809418095180961809718098180991810018101181021810318104181051810618107181081810918110181111811218113181141811518116181171811818119181201812118122181231812418125181261812718128181291813018131181321813318134181351813618137181381813918140181411814218143181441814518146181471814818149181501815118152181531815418155181561815718158181591816018161181621816318164181651816618167181681816918170181711817218173181741817518176181771817818179181801818118182181831818418185181861818718188181891819018191181921819318194181951819618197181981819918200182011820218203182041820518206182071820818209182101821118212182131821418215182161821718218182191822018221182221822318224182251822618227182281822918230182311823218233182341823518236182371823818239182401824118242182431824418245182461824718248182491825018251182521825318254182551825618257182581825918260182611826218263182641826518266182671826818269182701827118272182731827418275182761827718278182791828018281182821828318284182851828618287182881828918290182911829218293182941829518296182971829818299183001830118302183031830418305183061830718308183091831018311183121831318314183151831618317183181831918320183211832218323183241832518326183271832818329183301833118332183331833418335183361833718338183391834018341183421834318344183451834618347183481834918350183511835218353183541835518356183571835818359183601836118362183631836418365183661836718368183691837018371183721837318374183751837618377183781837918380183811838218383183841838518386183871838818389183901839118392183931839418395183961839718398183991840018401184021840318404184051840618407184081840918410184111841218413184141841518416184171841818419184201842118422184231842418425184261842718428184291843018431184321843318434184351843618437184381843918440184411844218443184441844518446184471844818449184501845118452184531845418455184561845718458184591846018461184621846318464184651846618467184681846918470184711847218473184741847518476184771847818479184801848118482184831848418485184861848718488184891849018491184921849318494184951849618497184981849918500185011850218503185041850518506185071850818509185101851118512185131851418515185161851718518185191852018521185221852318524185251852618527185281852918530185311853218533185341853518536185371853818539185401854118542185431854418545185461854718548185491855018551185521855318554185551855618557185581855918560185611856218563185641856518566185671856818569185701857118572185731857418575185761857718578185791858018581185821858318584185851858618587185881858918590185911859218593185941859518596185971859818599186001860118602186031860418605186061860718608186091861018611186121861318614186151861618617186181861918620186211862218623186241862518626186271862818629186301863118632186331863418635186361863718638186391864018641186421864318644186451864618647186481864918650186511865218653186541865518656186571865818659186601866118662186631866418665186661866718668186691867018671186721867318674186751867618677186781867918680186811868218683186841868518686186871868818689186901869118692186931869418695186961869718698186991870018701187021870318704187051870618707187081870918710187111871218713187141871518716187171871818719187201872118722187231872418725187261872718728187291873018731187321873318734187351873618737187381873918740187411874218743187441874518746187471874818749187501875118752187531875418755187561875718758187591876018761187621876318764187651876618767187681876918770187711877218773187741877518776187771877818779187801878118782187831878418785187861878718788187891879018791187921879318794187951879618797187981879918800188011880218803188041880518806188071880818809188101881118812188131881418815188161881718818188191882018821188221882318824188251882618827188281882918830188311883218833188341883518836188371883818839188401884118842188431884418845188461884718848188491885018851188521885318854188551885618857188581885918860188611886218863188641886518866188671886818869188701887118872188731887418875188761887718878188791888018881188821888318884188851888618887188881888918890188911889218893188941889518896188971889818899189001890118902189031890418905189061890718908189091891018911189121891318914189151891618917189181891918920189211892218923189241892518926189271892818929189301893118932189331893418935189361893718938189391894018941189421894318944189451894618947189481894918950189511895218953189541895518956189571895818959189601896118962189631896418965189661896718968189691897018971189721897318974189751897618977189781897918980189811898218983189841898518986189871898818989189901899118992189931899418995189961899718998189991900019001190021900319004190051900619007190081900919010190111901219013190141901519016190171901819019190201902119022190231902419025190261902719028190291903019031190321903319034190351903619037190381903919040190411904219043190441904519046190471904819049190501905119052190531905419055190561905719058190591906019061190621906319064190651906619067190681906919070190711907219073190741907519076190771907819079190801908119082190831908419085190861908719088190891909019091190921909319094190951909619097190981909919100191011910219103191041910519106191071910819109191101911119112191131911419115191161911719118191191912019121191221912319124191251912619127191281912919130191311913219133191341913519136191371913819139191401914119142191431914419145191461914719148191491915019151191521915319154191551915619157191581915919160191611916219163191641916519166191671916819169191701917119172191731917419175191761917719178191791918019181191821918319184191851918619187191881918919190191911919219193191941919519196191971919819199192001920119202192031920419205192061920719208192091921019211192121921319214192151921619217192181921919220192211922219223192241922519226192271922819229192301923119232192331923419235192361923719238192391924019241192421924319244192451924619247192481924919250192511925219253192541925519256192571925819259192601926119262192631926419265192661926719268192691927019271192721927319274192751927619277192781927919280192811928219283192841928519286192871928819289192901929119292192931929419295192961929719298192991930019301193021930319304193051930619307193081930919310193111931219313193141931519316193171931819319193201932119322193231932419325193261932719328193291933019331193321933319334193351933619337193381933919340193411934219343193441934519346193471934819349193501935119352193531935419355193561935719358193591936019361193621936319364193651936619367193681936919370193711937219373193741937519376193771937819379193801938119382193831938419385193861938719388193891939019391193921939319394193951939619397193981939919400194011940219403194041940519406194071940819409194101941119412194131941419415194161941719418194191942019421194221942319424194251942619427194281942919430194311943219433194341943519436194371943819439194401944119442194431944419445194461944719448194491945019451194521945319454194551945619457194581945919460194611946219463194641946519466194671946819469194701947119472194731947419475194761947719478194791948019481194821948319484194851948619487194881948919490194911949219493194941949519496194971949819499195001950119502195031950419505195061950719508195091951019511195121951319514195151951619517195181951919520195211952219523195241952519526195271952819529195301953119532195331953419535195361953719538195391954019541195421954319544195451954619547195481954919550195511955219553195541955519556195571955819559195601956119562195631956419565195661956719568195691957019571195721957319574195751957619577195781957919580195811958219583195841958519586195871958819589195901959119592195931959419595195961959719598195991960019601196021960319604196051960619607196081960919610196111961219613196141961519616196171961819619196201962119622196231962419625196261962719628196291963019631196321963319634196351963619637196381963919640196411964219643196441964519646196471964819649196501965119652196531965419655196561965719658196591966019661196621966319664196651966619667196681966919670196711967219673196741967519676196771967819679196801968119682196831968419685196861968719688196891969019691196921969319694196951969619697196981969919700197011970219703197041970519706197071970819709197101971119712197131971419715197161971719718197191972019721197221972319724197251972619727197281972919730197311973219733197341973519736197371973819739197401974119742197431974419745197461974719748197491975019751197521975319754197551975619757197581975919760197611976219763197641976519766197671976819769197701977119772197731977419775197761977719778197791978019781197821978319784197851978619787197881978919790197911979219793197941979519796197971979819799198001980119802198031980419805198061980719808198091981019811198121981319814198151981619817198181981919820198211982219823198241982519826198271982819829198301983119832198331983419835198361983719838198391984019841198421984319844198451984619847198481984919850198511985219853198541985519856198571985819859198601986119862198631986419865198661986719868198691987019871198721987319874198751987619877198781987919880198811988219883198841988519886198871988819889198901989119892198931989419895198961989719898198991990019901199021990319904199051990619907199081990919910199111991219913199141991519916199171991819919199201992119922199231992419925199261992719928199291993019931199321993319934199351993619937199381993919940199411994219943199441994519946199471994819949199501995119952199531995419955199561995719958199591996019961199621996319964199651996619967199681996919970199711997219973199741997519976199771997819979199801998119982199831998419985199861998719988199891999019991199921999319994199951999619997199981999920000200012000220003200042000520006200072000820009200102001120012200132001420015200162001720018200192002020021200222002320024200252002620027200282002920030200312003220033200342003520036200372003820039200402004120042200432004420045200462004720048200492005020051200522005320054200552005620057200582005920060200612006220063200642006520066200672006820069200702007120072200732007420075200762007720078200792008020081200822008320084200852008620087200882008920090200912009220093200942009520096200972009820099201002010120102201032010420105201062010720108201092011020111201122011320114201152011620117201182011920120201212012220123201242012520126201272012820129201302013120132201332013420135201362013720138201392014020141201422014320144201452014620147201482014920150201512015220153201542015520156201572015820159201602016120162201632016420165201662016720168201692017020171201722017320174201752017620177201782017920180201812018220183201842018520186201872018820189201902019120192201932019420195201962019720198201992020020201202022020320204202052020620207202082020920210202112021220213202142021520216202172021820219202202022120222202232022420225202262022720228202292023020231202322023320234202352023620237202382023920240202412024220243202442024520246202472024820249202502025120252202532025420255202562025720258202592026020261202622026320264202652026620267202682026920270202712027220273202742027520276202772027820279202802028120282202832028420285202862028720288202892029020291202922029320294202952029620297202982029920300203012030220303203042030520306203072030820309203102031120312203132031420315203162031720318203192032020321203222032320324203252032620327203282032920330203312033220333203342033520336203372033820339203402034120342203432034420345203462034720348203492035020351203522035320354203552035620357203582035920360203612036220363203642036520366203672036820369203702037120372203732037420375203762037720378203792038020381203822038320384203852038620387203882038920390203912039220393203942039520396203972039820399204002040120402204032040420405204062040720408204092041020411204122041320414204152041620417204182041920420204212042220423204242042520426204272042820429204302043120432204332043420435204362043720438204392044020441204422044320444204452044620447204482044920450204512045220453204542045520456204572045820459204602046120462204632046420465204662046720468204692047020471204722047320474204752047620477204782047920480204812048220483204842048520486204872048820489204902049120492204932049420495204962049720498204992050020501205022050320504205052050620507205082050920510205112051220513205142051520516205172051820519205202052120522205232052420525205262052720528205292053020531205322053320534205352053620537205382053920540205412054220543205442054520546205472054820549205502055120552205532055420555205562055720558205592056020561205622056320564205652056620567205682056920570205712057220573205742057520576205772057820579205802058120582205832058420585205862058720588205892059020591205922059320594205952059620597205982059920600206012060220603206042060520606206072060820609206102061120612206132061420615206162061720618206192062020621206222062320624206252062620627206282062920630206312063220633206342063520636206372063820639206402064120642206432064420645206462064720648206492065020651206522065320654206552065620657206582065920660206612066220663206642066520666206672066820669206702067120672206732067420675206762067720678206792068020681206822068320684206852068620687206882068920690206912069220693206942069520696206972069820699207002070120702207032070420705207062070720708207092071020711207122071320714207152071620717207182071920720207212072220723207242072520726207272072820729207302073120732207332073420735207362073720738207392074020741207422074320744207452074620747207482074920750207512075220753207542075520756207572075820759207602076120762207632076420765207662076720768207692077020771207722077320774207752077620777207782077920780207812078220783207842078520786207872078820789207902079120792207932079420795207962079720798207992080020801208022080320804208052080620807208082080920810208112081220813208142081520816208172081820819208202082120822208232082420825208262082720828208292083020831208322083320834208352083620837208382083920840208412084220843208442084520846208472084820849208502085120852208532085420855208562085720858208592086020861208622086320864208652086620867208682086920870208712087220873208742087520876208772087820879208802088120882208832088420885208862088720888208892089020891208922089320894208952089620897208982089920900209012090220903209042090520906209072090820909209102091120912209132091420915209162091720918209192092020921209222092320924209252092620927209282092920930209312093220933209342093520936209372093820939209402094120942209432094420945209462094720948209492095020951209522095320954209552095620957209582095920960209612096220963209642096520966209672096820969209702097120972209732097420975209762097720978209792098020981209822098320984209852098620987209882098920990209912099220993209942099520996209972099820999210002100121002210032100421005210062100721008210092101021011210122101321014210152101621017210182101921020210212102221023210242102521026210272102821029210302103121032210332103421035210362103721038210392104021041210422104321044210452104621047210482104921050210512105221053210542105521056210572105821059210602106121062210632106421065210662106721068210692107021071210722107321074210752107621077210782107921080210812108221083210842108521086210872108821089210902109121092210932109421095210962109721098210992110021101211022110321104211052110621107211082110921110211112111221113211142111521116211172111821119211202112121122211232112421125211262112721128211292113021131211322113321134211352113621137211382113921140211412114221143211442114521146211472114821149211502115121152211532115421155211562115721158211592116021161211622116321164211652116621167211682116921170211712117221173211742117521176211772117821179211802118121182211832118421185211862118721188211892119021191211922119321194211952119621197211982119921200212012120221203212042120521206212072120821209212102121121212212132121421215212162121721218212192122021221212222122321224212252122621227212282122921230212312123221233212342123521236212372123821239212402124121242212432124421245212462124721248212492125021251212522125321254212552125621257212582125921260212612126221263212642126521266212672126821269212702127121272212732127421275212762127721278212792128021281212822128321284212852128621287212882128921290212912129221293212942129521296212972129821299213002130121302213032130421305213062130721308213092131021311213122131321314213152131621317213182131921320213212132221323213242132521326213272132821329213302133121332213332133421335213362133721338213392134021341213422134321344213452134621347213482134921350213512135221353213542135521356213572135821359213602136121362213632136421365213662136721368213692137021371213722137321374213752137621377213782137921380213812138221383213842138521386213872138821389213902139121392213932139421395213962139721398213992140021401214022140321404214052140621407214082140921410214112141221413214142141521416214172141821419214202142121422214232142421425214262142721428214292143021431214322143321434214352143621437214382143921440214412144221443214442144521446214472144821449214502145121452214532145421455214562145721458214592146021461214622146321464214652146621467214682146921470214712147221473214742147521476214772147821479214802148121482214832148421485214862148721488214892149021491214922149321494214952149621497214982149921500215012150221503215042150521506215072150821509215102151121512215132151421515215162151721518215192152021521215222152321524215252152621527215282152921530215312153221533215342153521536215372153821539215402154121542215432154421545215462154721548215492155021551215522155321554215552155621557215582155921560215612156221563215642156521566215672156821569215702157121572215732157421575215762157721578215792158021581215822158321584215852158621587215882158921590215912159221593215942159521596215972159821599216002160121602216032160421605216062160721608216092161021611216122161321614216152161621617216182161921620216212162221623216242162521626216272162821629216302163121632216332163421635216362163721638216392164021641216422164321644216452164621647216482164921650216512165221653216542165521656216572165821659216602166121662216632166421665216662166721668216692167021671216722167321674216752167621677216782167921680216812168221683216842168521686216872168821689216902169121692216932169421695216962169721698216992170021701217022170321704217052170621707217082170921710217112171221713217142171521716217172171821719217202172121722217232172421725217262172721728217292173021731217322173321734217352173621737217382173921740217412174221743217442174521746217472174821749217502175121752217532175421755217562175721758217592176021761217622176321764217652176621767217682176921770217712177221773217742177521776217772177821779217802178121782217832178421785217862178721788217892179021791217922179321794217952179621797217982179921800218012180221803218042180521806218072180821809218102181121812218132181421815218162181721818218192182021821218222182321824218252182621827218282182921830218312183221833218342183521836218372183821839218402184121842218432184421845218462184721848218492185021851218522185321854218552185621857218582185921860218612186221863218642186521866218672186821869218702187121872218732187421875218762187721878218792188021881218822188321884218852188621887218882188921890218912189221893218942189521896218972189821899219002190121902219032190421905219062190721908219092191021911219122191321914219152191621917219182191921920219212192221923219242192521926219272192821929219302193121932219332193421935219362193721938219392194021941219422194321944219452194621947219482194921950219512195221953219542195521956219572195821959219602196121962219632196421965219662196721968219692197021971219722197321974219752197621977219782197921980219812198221983219842198521986219872198821989219902199121992219932199421995219962199721998219992200022001220022200322004220052200622007220082200922010220112201222013220142201522016220172201822019220202202122022220232202422025220262202722028220292203022031220322203322034220352203622037220382203922040220412204222043220442204522046220472204822049220502205122052220532205422055220562205722058220592206022061220622206322064220652206622067220682206922070220712207222073220742207522076220772207822079220802208122082220832208422085220862208722088220892209022091220922209322094220952209622097220982209922100221012210222103221042210522106221072210822109221102211122112221132211422115221162211722118221192212022121221222212322124221252212622127221282212922130221312213222133221342213522136221372213822139221402214122142221432214422145221462214722148221492215022151221522215322154221552215622157221582215922160221612216222163221642216522166221672216822169221702217122172221732217422175221762217722178221792218022181221822218322184221852218622187221882218922190221912219222193221942219522196221972219822199222002220122202222032220422205222062220722208222092221022211222122221322214222152221622217222182221922220222212222222223222242222522226222272222822229222302223122232222332223422235222362223722238222392224022241222422224322244222452224622247222482224922250222512225222253222542225522256222572225822259222602226122262222632226422265222662226722268222692227022271222722227322274222752227622277222782227922280222812228222283222842228522286222872228822289222902229122292222932229422295222962229722298222992230022301223022230322304223052230622307223082230922310223112231222313223142231522316223172231822319223202232122322223232232422325223262232722328223292233022331223322233322334223352233622337223382233922340223412234222343223442234522346223472234822349223502235122352223532235422355223562235722358223592236022361223622236322364223652236622367223682236922370223712237222373223742237522376223772237822379223802238122382223832238422385223862238722388223892239022391223922239322394223952239622397223982239922400224012240222403224042240522406224072240822409224102241122412224132241422415224162241722418224192242022421224222242322424224252242622427224282242922430224312243222433224342243522436224372243822439224402244122442224432244422445224462244722448224492245022451224522245322454224552245622457224582245922460224612246222463224642246522466224672246822469224702247122472224732247422475224762247722478224792248022481224822248322484224852248622487224882248922490224912249222493224942249522496224972249822499225002250122502225032250422505225062250722508225092251022511225122251322514225152251622517225182251922520225212252222523225242252522526225272252822529225302253122532225332253422535225362253722538225392254022541225422254322544225452254622547225482254922550225512255222553225542255522556225572255822559225602256122562225632256422565225662256722568225692257022571225722257322574225752257622577225782257922580225812258222583225842258522586225872258822589225902259122592225932259422595225962259722598225992260022601226022260322604226052260622607226082260922610226112261222613226142261522616226172261822619226202262122622226232262422625226262262722628226292263022631226322263322634226352263622637226382263922640226412264222643226442264522646226472264822649226502265122652226532265422655226562265722658226592266022661226622266322664226652266622667226682266922670226712267222673226742267522676226772267822679226802268122682226832268422685226862268722688226892269022691226922269322694226952269622697226982269922700227012270222703227042270522706227072270822709227102271122712227132271422715227162271722718227192272022721227222272322724227252272622727227282272922730227312273222733227342273522736227372273822739227402274122742227432274422745227462274722748227492275022751227522275322754227552275622757227582275922760227612276222763227642276522766227672276822769227702277122772227732277422775227762277722778227792278022781227822278322784227852278622787227882278922790227912279222793227942279522796227972279822799228002280122802228032280422805228062280722808228092281022811228122281322814228152281622817228182281922820228212282222823228242282522826228272282822829228302283122832228332283422835228362283722838228392284022841228422284322844228452284622847228482284922850228512285222853228542285522856228572285822859228602286122862228632286422865228662286722868228692287022871228722287322874228752287622877228782287922880228812288222883228842288522886228872288822889228902289122892228932289422895228962289722898228992290022901229022290322904229052290622907229082290922910229112291222913229142291522916229172291822919229202292122922229232292422925229262292722928229292293022931229322293322934229352293622937229382293922940229412294222943229442294522946229472294822949229502295122952229532295422955229562295722958229592296022961229622296322964229652296622967229682296922970229712297222973229742297522976229772297822979229802298122982229832298422985229862298722988229892299022991229922299322994229952299622997229982299923000230012300223003230042300523006230072300823009230102301123012230132301423015230162301723018230192302023021230222302323024230252302623027230282302923030230312303223033230342303523036230372303823039230402304123042230432304423045230462304723048230492305023051230522305323054230552305623057230582305923060230612306223063230642306523066230672306823069230702307123072230732307423075230762307723078230792308023081230822308323084230852308623087230882308923090230912309223093230942309523096230972309823099231002310123102231032310423105231062310723108231092311023111231122311323114231152311623117231182311923120231212312223123231242312523126231272312823129231302313123132231332313423135231362313723138231392314023141231422314323144231452314623147231482314923150231512315223153231542315523156231572315823159231602316123162231632316423165231662316723168231692317023171231722317323174231752317623177231782317923180231812318223183231842318523186231872318823189231902319123192231932319423195231962319723198231992320023201232022320323204232052320623207232082320923210232112321223213232142321523216232172321823219232202322123222232232322423225232262322723228232292323023231232322323323234232352323623237232382323923240232412324223243232442324523246232472324823249232502325123252232532325423255232562325723258232592326023261232622326323264232652326623267232682326923270232712327223273232742327523276232772327823279232802328123282232832328423285232862328723288232892329023291232922329323294232952329623297232982329923300233012330223303233042330523306233072330823309233102331123312233132331423315233162331723318233192332023321233222332323324233252332623327233282332923330233312333223333233342333523336233372333823339233402334123342233432334423345233462334723348233492335023351233522335323354233552335623357233582335923360233612336223363233642336523366233672336823369233702337123372233732337423375233762337723378233792338023381233822338323384233852338623387233882338923390233912339223393233942339523396233972339823399234002340123402234032340423405234062340723408234092341023411234122341323414234152341623417234182341923420234212342223423234242342523426234272342823429234302343123432234332343423435234362343723438234392344023441234422344323444234452344623447234482344923450234512345223453234542345523456234572345823459234602346123462234632346423465234662346723468234692347023471234722347323474234752347623477234782347923480234812348223483234842348523486234872348823489234902349123492234932349423495234962349723498234992350023501235022350323504235052350623507235082350923510235112351223513235142351523516235172351823519235202352123522235232352423525235262352723528235292353023531235322353323534235352353623537235382353923540235412354223543235442354523546235472354823549235502355123552235532355423555235562355723558235592356023561235622356323564235652356623567235682356923570235712357223573235742357523576235772357823579235802358123582235832358423585235862358723588235892359023591235922359323594235952359623597235982359923600236012360223603236042360523606236072360823609236102361123612236132361423615236162361723618236192362023621236222362323624236252362623627236282362923630236312363223633236342363523636236372363823639236402364123642236432364423645236462364723648236492365023651236522365323654236552365623657236582365923660236612366223663236642366523666236672366823669236702367123672236732367423675236762367723678236792368023681236822368323684236852368623687236882368923690236912369223693236942369523696236972369823699237002370123702237032370423705237062370723708237092371023711237122371323714237152371623717237182371923720237212372223723237242372523726237272372823729237302373123732237332373423735237362373723738237392374023741237422374323744237452374623747237482374923750237512375223753237542375523756237572375823759237602376123762237632376423765237662376723768237692377023771237722377323774237752377623777237782377923780237812378223783237842378523786237872378823789237902379123792237932379423795237962379723798237992380023801238022380323804238052380623807238082380923810238112381223813238142381523816238172381823819238202382123822238232382423825238262382723828238292383023831238322383323834238352383623837238382383923840238412384223843238442384523846238472384823849238502385123852238532385423855238562385723858238592386023861238622386323864238652386623867238682386923870238712387223873238742387523876238772387823879238802388123882238832388423885238862388723888238892389023891238922389323894238952389623897238982389923900239012390223903239042390523906239072390823909239102391123912239132391423915239162391723918239192392023921239222392323924239252392623927239282392923930239312393223933239342393523936239372393823939239402394123942239432394423945239462394723948239492395023951239522395323954239552395623957239582395923960239612396223963239642396523966239672396823969239702397123972239732397423975239762397723978239792398023981239822398323984239852398623987239882398923990239912399223993239942399523996239972399823999240002400124002240032400424005240062400724008240092401024011240122401324014240152401624017240182401924020240212402224023240242402524026240272402824029240302403124032240332403424035240362403724038240392404024041240422404324044240452404624047240482404924050240512405224053240542405524056240572405824059240602406124062240632406424065240662406724068240692407024071240722407324074240752407624077240782407924080240812408224083240842408524086240872408824089240902409124092240932409424095240962409724098240992410024101241022410324104241052410624107241082410924110241112411224113241142411524116241172411824119241202412124122241232412424125241262412724128241292413024131241322413324134241352413624137241382413924140241412414224143241442414524146241472414824149241502415124152241532415424155241562415724158241592416024161241622416324164241652416624167241682416924170241712417224173241742417524176241772417824179241802418124182241832418424185241862418724188241892419024191241922419324194241952419624197241982419924200242012420224203242042420524206242072420824209242102421124212242132421424215242162421724218242192422024221242222422324224242252422624227242282422924230242312423224233242342423524236242372423824239242402424124242242432424424245242462424724248242492425024251242522425324254242552425624257242582425924260242612426224263242642426524266242672426824269242702427124272242732427424275242762427724278242792428024281242822428324284242852428624287242882428924290242912429224293242942429524296242972429824299243002430124302243032430424305243062430724308243092431024311243122431324314243152431624317243182431924320243212432224323243242432524326243272432824329243302433124332243332433424335243362433724338243392434024341243422434324344243452434624347243482434924350243512435224353243542435524356243572435824359243602436124362243632436424365243662436724368243692437024371243722437324374243752437624377243782437924380243812438224383243842438524386243872438824389243902439124392243932439424395243962439724398243992440024401244022440324404244052440624407244082440924410244112441224413244142441524416244172441824419244202442124422244232442424425244262442724428244292443024431244322443324434244352443624437244382443924440244412444224443244442444524446244472444824449244502445124452244532445424455244562445724458244592446024461244622446324464244652446624467244682446924470244712447224473244742447524476244772447824479244802448124482244832448424485244862448724488244892449024491244922449324494244952449624497244982449924500245012450224503245042450524506245072450824509245102451124512245132451424515245162451724518245192452024521245222452324524245252452624527245282452924530245312453224533245342453524536245372453824539245402454124542245432454424545245462454724548245492455024551245522455324554245552455624557245582455924560245612456224563245642456524566245672456824569245702457124572245732457424575245762457724578245792458024581245822458324584245852458624587245882458924590245912459224593245942459524596245972459824599246002460124602246032460424605246062460724608246092461024611246122461324614246152461624617246182461924620246212462224623246242462524626246272462824629246302463124632246332463424635246362463724638246392464024641246422464324644246452464624647246482464924650246512465224653246542465524656246572465824659246602466124662246632466424665246662466724668246692467024671246722467324674246752467624677246782467924680246812468224683246842468524686246872468824689246902469124692246932469424695246962469724698246992470024701247022470324704247052470624707247082470924710247112471224713247142471524716247172471824719247202472124722247232472424725247262472724728247292473024731247322473324734247352473624737247382473924740247412474224743247442474524746247472474824749247502475124752247532475424755247562475724758247592476024761247622476324764247652476624767247682476924770247712477224773247742477524776247772477824779247802478124782247832478424785247862478724788247892479024791247922479324794247952479624797247982479924800248012480224803248042480524806248072480824809248102481124812248132481424815248162481724818248192482024821248222482324824248252482624827248282482924830248312483224833248342483524836248372483824839248402484124842248432484424845248462484724848248492485024851248522485324854248552485624857248582485924860248612486224863248642486524866248672486824869248702487124872248732487424875248762487724878248792488024881248822488324884248852488624887248882488924890248912489224893248942489524896248972489824899249002490124902249032490424905249062490724908249092491024911249122491324914249152491624917249182491924920249212492224923249242492524926249272492824929249302493124932249332493424935249362493724938249392494024941249422494324944249452494624947249482494924950249512495224953249542495524956249572495824959249602496124962249632496424965249662496724968249692497024971249722497324974249752497624977249782497924980249812498224983249842498524986249872498824989249902499124992249932499424995249962499724998249992500025001250022500325004250052500625007250082500925010250112501225013250142501525016250172501825019250202502125022250232502425025250262502725028250292503025031250322503325034250352503625037250382503925040250412504225043250442504525046250472504825049250502505125052250532505425055250562505725058250592506025061250622506325064250652506625067250682506925070250712507225073250742507525076250772507825079250802508125082250832508425085250862508725088250892509025091250922509325094250952509625097250982509925100251012510225103251042510525106251072510825109251102511125112251132511425115251162511725118251192512025121251222512325124251252512625127251282512925130251312513225133251342513525136251372513825139251402514125142251432514425145251462514725148251492515025151251522515325154251552515625157251582515925160251612516225163251642516525166251672516825169251702517125172251732517425175251762517725178251792518025181251822518325184251852518625187251882518925190251912519225193251942519525196251972519825199252002520125202252032520425205252062520725208252092521025211252122521325214252152521625217252182521925220252212522225223252242522525226252272522825229252302523125232252332523425235252362523725238252392524025241252422524325244252452524625247252482524925250252512525225253252542525525256252572525825259252602526125262252632526425265252662526725268252692527025271252722527325274252752527625277252782527925280252812528225283252842528525286252872528825289252902529125292252932529425295252962529725298252992530025301253022530325304253052530625307253082530925310253112531225313253142531525316253172531825319253202532125322253232532425325253262532725328253292533025331253322533325334253352533625337253382533925340253412534225343253442534525346253472534825349253502535125352253532535425355253562535725358253592536025361253622536325364253652536625367253682536925370253712537225373253742537525376253772537825379253802538125382253832538425385253862538725388253892539025391253922539325394253952539625397253982539925400254012540225403254042540525406254072540825409254102541125412254132541425415254162541725418254192542025421254222542325424254252542625427254282542925430254312543225433254342543525436254372543825439254402544125442254432544425445254462544725448254492545025451254522545325454254552545625457254582545925460254612546225463254642546525466254672546825469254702547125472254732547425475254762547725478254792548025481254822548325484254852548625487254882548925490254912549225493254942549525496254972549825499255002550125502255032550425505255062550725508255092551025511255122551325514255152551625517255182551925520255212552225523255242552525526255272552825529255302553125532255332553425535255362553725538255392554025541255422554325544255452554625547255482554925550255512555225553255542555525556255572555825559255602556125562255632556425565255662556725568255692557025571255722557325574255752557625577255782557925580255812558225583255842558525586255872558825589255902559125592255932559425595255962559725598255992560025601256022560325604256052560625607256082560925610256112561225613256142561525616256172561825619256202562125622256232562425625256262562725628256292563025631256322563325634256352563625637256382563925640256412564225643256442564525646256472564825649256502565125652256532565425655256562565725658256592566025661256622566325664256652566625667256682566925670256712567225673256742567525676256772567825679256802568125682256832568425685256862568725688256892569025691256922569325694256952569625697256982569925700257012570225703257042570525706257072570825709257102571125712257132571425715257162571725718257192572025721257222572325724257252572625727257282572925730257312573225733257342573525736257372573825739257402574125742257432574425745257462574725748257492575025751257522575325754257552575625757257582575925760257612576225763257642576525766257672576825769257702577125772257732577425775257762577725778257792578025781257822578325784257852578625787257882578925790257912579225793257942579525796257972579825799258002580125802258032580425805258062580725808258092581025811258122581325814258152581625817258182581925820258212582225823258242582525826258272582825829258302583125832258332583425835258362583725838258392584025841258422584325844258452584625847258482584925850258512585225853258542585525856258572585825859258602586125862258632586425865258662586725868258692587025871258722587325874258752587625877258782587925880258812588225883258842588525886258872588825889258902589125892258932589425895258962589725898258992590025901259022590325904259052590625907259082590925910259112591225913259142591525916259172591825919259202592125922259232592425925259262592725928259292593025931259322593325934259352593625937259382593925940259412594225943259442594525946259472594825949259502595125952259532595425955259562595725958259592596025961259622596325964259652596625967259682596925970259712597225973259742597525976259772597825979259802598125982259832598425985259862598725988259892599025991259922599325994259952599625997259982599926000260012600226003260042600526006260072600826009260102601126012260132601426015260162601726018260192602026021260222602326024260252602626027260282602926030260312603226033260342603526036260372603826039260402604126042260432604426045260462604726048260492605026051260522605326054260552605626057260582605926060260612606226063260642606526066260672606826069260702607126072260732607426075260762607726078260792608026081260822608326084260852608626087260882608926090260912609226093260942609526096260972609826099261002610126102261032610426105261062610726108261092611026111261122611326114261152611626117261182611926120261212612226123261242612526126261272612826129261302613126132261332613426135261362613726138261392614026141261422614326144261452614626147261482614926150261512615226153261542615526156261572615826159261602616126162261632616426165261662616726168261692617026171261722617326174261752617626177261782617926180261812618226183261842618526186261872618826189261902619126192261932619426195261962619726198261992620026201262022620326204262052620626207262082620926210262112621226213262142621526216262172621826219262202622126222262232622426225262262622726228262292623026231262322623326234262352623626237262382623926240262412624226243262442624526246262472624826249262502625126252262532625426255262562625726258262592626026261262622626326264262652626626267262682626926270262712627226273262742627526276262772627826279262802628126282262832628426285262862628726288262892629026291262922629326294262952629626297262982629926300263012630226303263042630526306263072630826309263102631126312263132631426315263162631726318263192632026321263222632326324263252632626327263282632926330263312633226333263342633526336263372633826339263402634126342263432634426345263462634726348263492635026351263522635326354263552635626357263582635926360263612636226363263642636526366263672636826369263702637126372263732637426375263762637726378263792638026381263822638326384263852638626387263882638926390263912639226393263942639526396263972639826399264002640126402264032640426405264062640726408264092641026411264122641326414264152641626417264182641926420264212642226423264242642526426264272642826429264302643126432264332643426435264362643726438264392644026441264422644326444264452644626447264482644926450264512645226453264542645526456264572645826459264602646126462264632646426465264662646726468264692647026471264722647326474264752647626477264782647926480264812648226483264842648526486264872648826489264902649126492264932649426495264962649726498264992650026501265022650326504265052650626507265082650926510265112651226513265142651526516265172651826519265202652126522265232652426525265262652726528265292653026531265322653326534265352653626537265382653926540265412654226543265442654526546265472654826549265502655126552265532655426555265562655726558265592656026561265622656326564265652656626567265682656926570265712657226573265742657526576265772657826579265802658126582265832658426585265862658726588265892659026591265922659326594265952659626597265982659926600266012660226603266042660526606266072660826609266102661126612266132661426615266162661726618266192662026621266222662326624266252662626627266282662926630266312663226633266342663526636266372663826639266402664126642266432664426645266462664726648266492665026651266522665326654266552665626657266582665926660266612666226663266642666526666266672666826669266702667126672266732667426675266762667726678266792668026681266822668326684266852668626687266882668926690266912669226693266942669526696266972669826699267002670126702267032670426705267062670726708267092671026711267122671326714267152671626717267182671926720267212672226723267242672526726267272672826729267302673126732267332673426735267362673726738267392674026741267422674326744267452674626747267482674926750267512675226753267542675526756267572675826759267602676126762267632676426765267662676726768267692677026771267722677326774267752677626777267782677926780267812678226783267842678526786267872678826789267902679126792267932679426795267962679726798267992680026801268022680326804268052680626807268082680926810268112681226813268142681526816268172681826819268202682126822268232682426825268262682726828268292683026831268322683326834268352683626837268382683926840268412684226843268442684526846268472684826849268502685126852268532685426855268562685726858268592686026861268622686326864268652686626867268682686926870268712687226873268742687526876268772687826879268802688126882268832688426885268862688726888268892689026891268922689326894268952689626897268982689926900269012690226903269042690526906269072690826909269102691126912269132691426915269162691726918269192692026921269222692326924269252692626927269282692926930269312693226933269342693526936269372693826939269402694126942269432694426945269462694726948269492695026951269522695326954269552695626957269582695926960269612696226963269642696526966269672696826969269702697126972269732697426975269762697726978269792698026981269822698326984269852698626987269882698926990269912699226993269942699526996269972699826999270002700127002270032700427005270062700727008270092701027011270122701327014270152701627017270182701927020270212702227023270242702527026270272702827029270302703127032270332703427035270362703727038270392704027041270422704327044270452704627047270482704927050270512705227053270542705527056270572705827059270602706127062270632706427065270662706727068270692707027071270722707327074270752707627077270782707927080270812708227083270842708527086270872708827089270902709127092270932709427095270962709727098270992710027101271022710327104271052710627107271082710927110271112711227113271142711527116271172711827119271202712127122271232712427125271262712727128271292713027131271322713327134271352713627137271382713927140271412714227143271442714527146271472714827149271502715127152271532715427155271562715727158271592716027161271622716327164271652716627167271682716927170271712717227173271742717527176271772717827179271802718127182271832718427185271862718727188271892719027191271922719327194271952719627197271982719927200272012720227203272042720527206272072720827209272102721127212272132721427215272162721727218272192722027221272222722327224272252722627227272282722927230272312723227233272342723527236272372723827239272402724127242272432724427245272462724727248272492725027251272522725327254272552725627257272582725927260272612726227263272642726527266272672726827269272702727127272272732727427275272762727727278272792728027281272822728327284272852728627287272882728927290272912729227293272942729527296272972729827299273002730127302273032730427305273062730727308273092731027311273122731327314273152731627317273182731927320273212732227323273242732527326273272732827329273302733127332273332733427335273362733727338273392734027341273422734327344273452734627347273482734927350273512735227353273542735527356273572735827359273602736127362273632736427365273662736727368273692737027371273722737327374273752737627377273782737927380273812738227383273842738527386273872738827389273902739127392273932739427395273962739727398273992740027401274022740327404274052740627407274082740927410274112741227413274142741527416274172741827419274202742127422274232742427425274262742727428274292743027431274322743327434274352743627437274382743927440274412744227443274442744527446274472744827449274502745127452274532745427455274562745727458274592746027461274622746327464274652746627467274682746927470274712747227473274742747527476274772747827479274802748127482274832748427485274862748727488274892749027491274922749327494274952749627497274982749927500275012750227503275042750527506275072750827509275102751127512275132751427515275162751727518275192752027521275222752327524275252752627527275282752927530275312753227533275342753527536275372753827539275402754127542275432754427545275462754727548275492755027551275522755327554275552755627557275582755927560275612756227563275642756527566275672756827569275702757127572275732757427575275762757727578275792758027581275822758327584275852758627587275882758927590275912759227593275942759527596275972759827599276002760127602276032760427605276062760727608276092761027611276122761327614276152761627617276182761927620276212762227623276242762527626276272762827629276302763127632276332763427635276362763727638276392764027641276422764327644276452764627647276482764927650276512765227653276542765527656276572765827659276602766127662276632766427665276662766727668276692767027671276722767327674276752767627677276782767927680276812768227683276842768527686276872768827689276902769127692276932769427695276962769727698276992770027701277022770327704277052770627707277082770927710277112771227713277142771527716277172771827719277202772127722277232772427725277262772727728277292773027731277322773327734277352773627737277382773927740277412774227743277442774527746277472774827749277502775127752277532775427755277562775727758277592776027761277622776327764277652776627767277682776927770277712777227773277742777527776277772777827779277802778127782277832778427785277862778727788277892779027791277922779327794277952779627797277982779927800278012780227803278042780527806278072780827809278102781127812278132781427815278162781727818278192782027821278222782327824278252782627827278282782927830278312783227833278342783527836278372783827839278402784127842278432784427845278462784727848278492785027851278522785327854278552785627857278582785927860278612786227863278642786527866278672786827869278702787127872278732787427875278762787727878278792788027881278822788327884278852788627887278882788927890278912789227893278942789527896278972789827899279002790127902279032790427905279062790727908279092791027911279122791327914279152791627917279182791927920279212792227923279242792527926279272792827929279302793127932279332793427935279362793727938279392794027941279422794327944279452794627947279482794927950279512795227953279542795527956279572795827959279602796127962279632796427965279662796727968279692797027971279722797327974279752797627977279782797927980279812798227983279842798527986279872798827989279902799127992279932799427995279962799727998279992800028001280022800328004280052800628007280082800928010280112801228013280142801528016280172801828019280202802128022280232802428025280262802728028280292803028031280322803328034280352803628037280382803928040280412804228043280442804528046280472804828049280502805128052280532805428055280562805728058280592806028061280622806328064280652806628067280682806928070280712807228073280742807528076280772807828079280802808128082280832808428085280862808728088280892809028091280922809328094280952809628097280982809928100281012810228103281042810528106281072810828109281102811128112281132811428115281162811728118281192812028121281222812328124281252812628127281282812928130281312813228133281342813528136281372813828139281402814128142281432814428145281462814728148281492815028151281522815328154281552815628157281582815928160281612816228163281642816528166281672816828169281702817128172281732817428175281762817728178281792818028181281822818328184281852818628187281882818928190281912819228193281942819528196281972819828199282002820128202282032820428205282062820728208282092821028211282122821328214282152821628217282182821928220282212822228223282242822528226282272822828229282302823128232282332823428235282362823728238282392824028241282422824328244282452824628247282482824928250282512825228253282542825528256282572825828259282602826128262282632826428265282662826728268282692827028271282722827328274282752827628277282782827928280282812828228283282842828528286282872828828289282902829128292282932829428295282962829728298282992830028301283022830328304283052830628307283082830928310283112831228313283142831528316283172831828319283202832128322283232832428325283262832728328283292833028331283322833328334283352833628337283382833928340283412834228343283442834528346283472834828349283502835128352283532835428355283562835728358283592836028361283622836328364283652836628367283682836928370283712837228373283742837528376283772837828379283802838128382283832838428385283862838728388283892839028391283922839328394283952839628397283982839928400284012840228403284042840528406284072840828409284102841128412284132841428415284162841728418284192842028421284222842328424284252842628427284282842928430284312843228433284342843528436284372843828439284402844128442284432844428445284462844728448284492845028451284522845328454284552845628457284582845928460284612846228463284642846528466284672846828469284702847128472284732847428475284762847728478284792848028481284822848328484284852848628487284882848928490284912849228493284942849528496284972849828499285002850128502285032850428505285062850728508285092851028511285122851328514285152851628517285182851928520285212852228523285242852528526285272852828529285302853128532285332853428535285362853728538285392854028541285422854328544285452854628547285482854928550285512855228553285542855528556285572855828559285602856128562285632856428565285662856728568285692857028571285722857328574285752857628577285782857928580285812858228583285842858528586285872858828589285902859128592285932859428595285962859728598285992860028601286022860328604286052860628607286082860928610286112861228613286142861528616286172861828619286202862128622286232862428625286262862728628286292863028631286322863328634286352863628637286382863928640286412864228643286442864528646286472864828649286502865128652286532865428655286562865728658286592866028661286622866328664286652866628667286682866928670286712867228673286742867528676286772867828679286802868128682286832868428685286862868728688286892869028691286922869328694286952869628697286982869928700287012870228703287042870528706287072870828709287102871128712287132871428715287162871728718287192872028721287222872328724287252872628727287282872928730287312873228733287342873528736287372873828739287402874128742287432874428745287462874728748287492875028751287522875328754287552875628757287582875928760287612876228763287642876528766287672876828769287702877128772287732877428775287762877728778287792878028781287822878328784287852878628787287882878928790287912879228793287942879528796287972879828799288002880128802288032880428805288062880728808288092881028811288122881328814288152881628817288182881928820288212882228823288242882528826288272882828829288302883128832288332883428835288362883728838288392884028841288422884328844288452884628847288482884928850288512885228853288542885528856288572885828859288602886128862288632886428865288662886728868288692887028871288722887328874288752887628877288782887928880288812888228883288842888528886288872888828889288902889128892288932889428895288962889728898288992890028901289022890328904289052890628907289082890928910289112891228913289142891528916289172891828919289202892128922289232892428925289262892728928289292893028931289322893328934289352893628937289382893928940289412894228943289442894528946289472894828949289502895128952289532895428955289562895728958289592896028961289622896328964289652896628967289682896928970289712897228973289742897528976289772897828979289802898128982289832898428985289862898728988289892899028991289922899328994289952899628997289982899929000290012900229003290042900529006290072900829009290102901129012290132901429015290162901729018290192902029021290222902329024290252902629027290282902929030290312903229033290342903529036290372903829039290402904129042290432904429045290462904729048290492905029051290522905329054290552905629057290582905929060290612906229063290642906529066290672906829069290702907129072290732907429075290762907729078290792908029081290822908329084290852908629087290882908929090290912909229093290942909529096290972909829099291002910129102291032910429105291062910729108291092911029111291122911329114291152911629117291182911929120291212912229123291242912529126291272912829129291302913129132291332913429135291362913729138291392914029141291422914329144291452914629147291482914929150291512915229153291542915529156291572915829159291602916129162291632916429165291662916729168291692917029171291722917329174291752917629177291782917929180291812918229183291842918529186291872918829189291902919129192291932919429195291962919729198291992920029201292022920329204292052920629207292082920929210292112921229213292142921529216292172921829219292202922129222292232922429225292262922729228292292923029231292322923329234292352923629237292382923929240292412924229243292442924529246292472924829249292502925129252292532925429255292562925729258292592926029261292622926329264292652926629267292682926929270292712927229273292742927529276292772927829279292802928129282292832928429285292862928729288292892929029291292922929329294292952929629297292982929929300293012930229303293042930529306293072930829309293102931129312293132931429315293162931729318293192932029321293222932329324293252932629327293282932929330293312933229333293342933529336293372933829339293402934129342293432934429345293462934729348293492935029351293522935329354293552935629357293582935929360293612936229363293642936529366293672936829369293702937129372293732937429375293762937729378293792938029381293822938329384293852938629387293882938929390293912939229393293942939529396293972939829399294002940129402294032940429405294062940729408294092941029411294122941329414294152941629417294182941929420294212942229423294242942529426294272942829429294302943129432294332943429435294362943729438294392944029441294422944329444294452944629447294482944929450294512945229453294542945529456294572945829459294602946129462294632946429465294662946729468294692947029471294722947329474294752947629477294782947929480294812948229483294842948529486294872948829489294902949129492294932949429495294962949729498294992950029501295022950329504295052950629507295082950929510295112951229513295142951529516295172951829519295202952129522295232952429525295262952729528295292953029531295322953329534295352953629537295382953929540295412954229543295442954529546295472954829549295502955129552295532955429555295562955729558295592956029561295622956329564295652956629567295682956929570295712957229573295742957529576295772957829579295802958129582295832958429585295862958729588295892959029591295922959329594295952959629597295982959929600296012960229603296042960529606296072960829609296102961129612296132961429615296162961729618296192962029621296222962329624296252962629627296282962929630296312963229633296342963529636296372963829639296402964129642296432964429645296462964729648296492965029651296522965329654296552965629657296582965929660296612966229663296642966529666296672966829669296702967129672296732967429675296762967729678296792968029681296822968329684296852968629687296882968929690296912969229693296942969529696296972969829699297002970129702297032970429705297062970729708297092971029711297122971329714297152971629717297182971929720297212972229723297242972529726297272972829729297302973129732297332973429735297362973729738297392974029741297422974329744297452974629747297482974929750297512975229753297542975529756297572975829759297602976129762297632976429765297662976729768297692977029771297722977329774297752977629777297782977929780297812978229783297842978529786297872978829789297902979129792297932979429795297962979729798297992980029801298022980329804298052980629807298082980929810298112981229813298142981529816298172981829819298202982129822298232982429825298262982729828298292983029831298322983329834298352983629837298382983929840298412984229843298442984529846298472984829849298502985129852298532985429855298562985729858298592986029861298622986329864298652986629867298682986929870298712987229873298742987529876298772987829879298802988129882298832988429885298862988729888298892989029891298922989329894298952989629897298982989929900299012990229903299042990529906299072990829909299102991129912299132991429915299162991729918299192992029921299222992329924299252992629927299282992929930299312993229933299342993529936299372993829939299402994129942299432994429945299462994729948299492995029951299522995329954299552995629957299582995929960299612996229963299642996529966299672996829969299702997129972299732997429975299762997729978299792998029981299822998329984299852998629987299882998929990299912999229993299942999529996299972999829999300003000130002300033000430005300063000730008300093001030011300123001330014300153001630017300183001930020300213002230023300243002530026300273002830029300303003130032300333003430035300363003730038300393004030041300423004330044300453004630047300483004930050300513005230053300543005530056300573005830059300603006130062300633006430065300663006730068300693007030071300723007330074300753007630077300783007930080300813008230083300843008530086300873008830089300903009130092300933009430095300963009730098300993010030101301023010330104301053010630107301083010930110301113011230113301143011530116301173011830119301203012130122301233012430125301263012730128301293013030131301323013330134301353013630137301383013930140301413014230143301443014530146301473014830149301503015130152301533015430155301563015730158301593016030161301623016330164301653016630167301683016930170301713017230173301743017530176301773017830179301803018130182301833018430185301863018730188301893019030191301923019330194301953019630197301983019930200302013020230203302043020530206302073020830209302103021130212302133021430215302163021730218302193022030221302223022330224302253022630227302283022930230302313023230233302343023530236302373023830239302403024130242302433024430245302463024730248302493025030251302523025330254302553025630257302583025930260302613026230263302643026530266302673026830269302703027130272302733027430275302763027730278302793028030281302823028330284302853028630287302883028930290302913029230293302943029530296302973029830299303003030130302303033030430305303063030730308303093031030311303123031330314303153031630317303183031930320303213032230323303243032530326303273032830329303303033130332303333033430335303363033730338303393034030341303423034330344303453034630347303483034930350303513035230353303543035530356303573035830359303603036130362303633036430365303663036730368303693037030371303723037330374303753037630377303783037930380303813038230383303843038530386303873038830389303903039130392303933039430395303963039730398303993040030401304023040330404304053040630407304083040930410304113041230413304143041530416304173041830419304203042130422304233042430425304263042730428304293043030431304323043330434304353043630437304383043930440304413044230443304443044530446304473044830449304503045130452304533045430455304563045730458304593046030461304623046330464304653046630467304683046930470304713047230473304743047530476304773047830479304803048130482304833048430485304863048730488304893049030491304923049330494304953049630497304983049930500305013050230503305043050530506305073050830509305103051130512305133051430515305163051730518305193052030521305223052330524305253052630527305283052930530305313053230533305343053530536305373053830539305403054130542305433054430545305463054730548305493055030551305523055330554305553055630557305583055930560305613056230563305643056530566305673056830569305703057130572305733057430575305763057730578305793058030581305823058330584305853058630587305883058930590305913059230593305943059530596305973059830599306003060130602306033060430605306063060730608306093061030611306123061330614306153061630617306183061930620306213062230623306243062530626306273062830629306303063130632306333063430635306363063730638306393064030641306423064330644306453064630647306483064930650306513065230653306543065530656306573065830659306603066130662306633066430665306663066730668306693067030671306723067330674306753067630677306783067930680306813068230683306843068530686306873068830689306903069130692306933069430695306963069730698306993070030701307023070330704307053070630707307083070930710307113071230713307143071530716307173071830719307203072130722307233072430725307263072730728307293073030731307323073330734307353073630737307383073930740307413074230743307443074530746307473074830749307503075130752307533075430755307563075730758307593076030761307623076330764307653076630767307683076930770307713077230773307743077530776307773077830779307803078130782307833078430785307863078730788307893079030791307923079330794307953079630797307983079930800308013080230803308043080530806308073080830809308103081130812308133081430815308163081730818308193082030821308223082330824308253082630827308283082930830308313083230833308343083530836308373083830839308403084130842308433084430845308463084730848308493085030851308523085330854308553085630857308583085930860308613086230863308643086530866308673086830869308703087130872308733087430875308763087730878308793088030881308823088330884308853088630887308883088930890308913089230893308943089530896308973089830899309003090130902309033090430905309063090730908309093091030911309123091330914309153091630917309183091930920309213092230923309243092530926309273092830929309303093130932309333093430935309363093730938309393094030941309423094330944309453094630947309483094930950309513095230953309543095530956309573095830959309603096130962309633096430965309663096730968309693097030971309723097330974309753097630977309783097930980309813098230983309843098530986309873098830989309903099130992309933099430995309963099730998309993100031001310023100331004310053100631007310083100931010310113101231013310143101531016310173101831019310203102131022310233102431025310263102731028310293103031031310323103331034310353103631037310383103931040310413104231043310443104531046310473104831049310503105131052310533105431055310563105731058310593106031061310623106331064310653106631067310683106931070310713107231073310743107531076310773107831079310803108131082310833108431085310863108731088310893109031091310923109331094310953109631097310983109931100311013110231103311043110531106311073110831109311103111131112311133111431115311163111731118311193112031121311223112331124311253112631127311283112931130311313113231133311343113531136311373113831139311403114131142311433114431145311463114731148311493115031151311523115331154311553115631157311583115931160311613116231163311643116531166311673116831169311703117131172311733117431175311763117731178311793118031181311823118331184311853118631187311883118931190311913119231193311943119531196311973119831199312003120131202312033120431205312063120731208312093121031211312123121331214312153121631217312183121931220312213122231223312243122531226312273122831229312303123131232312333123431235312363123731238312393124031241312423124331244312453124631247312483124931250312513125231253312543125531256312573125831259312603126131262312633126431265312663126731268312693127031271312723127331274312753127631277312783127931280312813128231283312843128531286312873128831289312903129131292312933129431295312963129731298312993130031301313023130331304313053130631307313083130931310313113131231313313143131531316313173131831319313203132131322313233132431325313263132731328313293133031331313323133331334313353133631337313383133931340313413134231343313443134531346313473134831349313503135131352313533135431355313563135731358313593136031361313623136331364313653136631367313683136931370313713137231373313743137531376313773137831379313803138131382313833138431385313863138731388313893139031391313923139331394313953139631397313983139931400314013140231403314043140531406314073140831409314103141131412314133141431415314163141731418314193142031421314223142331424314253142631427314283142931430314313143231433314343143531436314373143831439314403144131442314433144431445314463144731448314493145031451314523145331454314553145631457314583145931460314613146231463314643146531466314673146831469314703147131472314733147431475314763147731478314793148031481314823148331484314853148631487314883148931490314913149231493314943149531496314973149831499315003150131502315033150431505315063150731508315093151031511315123151331514315153151631517315183151931520315213152231523315243152531526315273152831529315303153131532315333153431535315363153731538315393154031541315423154331544315453154631547315483154931550315513155231553315543155531556315573155831559315603156131562315633156431565315663156731568315693157031571315723157331574315753157631577315783157931580315813158231583315843158531586315873158831589315903159131592315933159431595315963159731598315993160031601316023160331604316053160631607316083160931610316113161231613316143161531616316173161831619316203162131622316233162431625316263162731628316293163031631316323163331634316353163631637316383163931640316413164231643316443164531646316473164831649316503165131652316533165431655316563165731658316593166031661316623166331664316653166631667316683166931670316713167231673316743167531676316773167831679316803168131682316833168431685316863168731688316893169031691316923169331694316953169631697316983169931700317013170231703317043170531706317073170831709317103171131712317133171431715317163171731718317193172031721317223172331724317253172631727317283172931730317313173231733317343173531736317373173831739317403174131742317433174431745317463174731748317493175031751317523175331754317553175631757317583175931760317613176231763317643176531766317673176831769317703177131772317733177431775317763177731778317793178031781317823178331784317853178631787317883178931790317913179231793317943179531796317973179831799318003180131802318033180431805318063180731808318093181031811318123181331814318153181631817318183181931820318213182231823318243182531826318273182831829318303183131832318333183431835318363183731838318393184031841318423184331844318453184631847318483184931850318513185231853318543185531856318573185831859318603186131862318633186431865318663186731868318693187031871318723187331874318753187631877318783187931880318813188231883318843188531886318873188831889318903189131892318933189431895318963189731898318993190031901319023190331904319053190631907319083190931910319113191231913319143191531916319173191831919319203192131922319233192431925319263192731928319293193031931319323193331934319353193631937319383193931940319413194231943319443194531946319473194831949319503195131952319533195431955319563195731958319593196031961319623196331964319653196631967319683196931970319713197231973319743197531976319773197831979319803198131982319833198431985319863198731988319893199031991319923199331994319953199631997319983199932000320013200232003320043200532006320073200832009320103201132012320133201432015320163201732018320193202032021320223202332024320253202632027320283202932030320313203232033320343203532036320373203832039320403204132042320433204432045320463204732048320493205032051320523205332054320553205632057320583205932060320613206232063320643206532066320673206832069320703207132072320733207432075320763207732078320793208032081320823208332084320853208632087320883208932090320913209232093320943209532096320973209832099321003210132102321033210432105321063210732108321093211032111321123211332114321153211632117321183211932120321213212232123321243212532126321273212832129321303213132132321333213432135321363213732138321393214032141321423214332144321453214632147321483214932150321513215232153321543215532156321573215832159321603216132162321633216432165321663216732168321693217032171321723217332174321753217632177321783217932180321813218232183321843218532186321873218832189321903219132192321933219432195321963219732198321993220032201322023220332204322053220632207322083220932210322113221232213322143221532216322173221832219322203222132222322233222432225322263222732228322293223032231322323223332234322353223632237322383223932240322413224232243322443224532246322473224832249322503225132252322533225432255322563225732258322593226032261322623226332264322653226632267322683226932270322713227232273322743227532276322773227832279322803228132282322833228432285322863228732288322893229032291322923229332294322953229632297322983229932300323013230232303323043230532306323073230832309323103231132312323133231432315323163231732318323193232032321323223232332324323253232632327323283232932330323313233232333323343233532336323373233832339323403234132342323433234432345323463234732348323493235032351323523235332354323553235632357323583235932360323613236232363323643236532366323673236832369323703237132372323733237432375323763237732378323793238032381323823238332384323853238632387323883238932390323913239232393323943239532396323973239832399324003240132402324033240432405324063240732408324093241032411324123241332414324153241632417324183241932420324213242232423324243242532426324273242832429324303243132432324333243432435324363243732438324393244032441324423244332444324453244632447324483244932450324513245232453324543245532456324573245832459324603246132462324633246432465324663246732468324693247032471324723247332474324753247632477324783247932480324813248232483324843248532486324873248832489324903249132492324933249432495324963249732498324993250032501325023250332504325053250632507325083250932510325113251232513325143251532516325173251832519325203252132522325233252432525325263252732528325293253032531325323253332534325353253632537325383253932540325413254232543325443254532546325473254832549325503255132552325533255432555325563255732558325593256032561325623256332564325653256632567325683256932570325713257232573325743257532576325773257832579325803258132582325833258432585325863258732588325893259032591325923259332594325953259632597325983259932600326013260232603326043260532606326073260832609326103261132612326133261432615326163261732618326193262032621326223262332624326253262632627326283262932630326313263232633326343263532636326373263832639326403264132642326433264432645326463264732648326493265032651326523265332654326553265632657326583265932660326613266232663326643266532666326673266832669326703267132672326733267432675326763267732678326793268032681326823268332684326853268632687326883268932690326913269232693326943269532696326973269832699327003270132702327033270432705327063270732708327093271032711327123271332714327153271632717327183271932720327213272232723327243272532726327273272832729327303273132732327333273432735327363273732738327393274032741327423274332744327453274632747327483274932750327513275232753327543275532756327573275832759327603276132762327633276432765327663276732768327693277032771327723277332774327753277632777327783277932780327813278232783327843278532786327873278832789327903279132792327933279432795327963279732798327993280032801328023280332804328053280632807328083280932810328113281232813328143281532816328173281832819328203282132822328233282432825328263282732828328293283032831328323283332834328353283632837328383283932840328413284232843328443284532846328473284832849328503285132852328533285432855328563285732858328593286032861328623286332864328653286632867328683286932870328713287232873328743287532876328773287832879328803288132882328833288432885328863288732888328893289032891328923289332894328953289632897328983289932900329013290232903329043290532906329073290832909329103291132912329133291432915329163291732918329193292032921329223292332924329253292632927329283292932930329313293232933329343293532936329373293832939329403294132942329433294432945329463294732948329493295032951329523295332954329553295632957329583295932960329613296232963329643296532966329673296832969329703297132972329733297432975329763297732978329793298032981329823298332984329853298632987329883298932990329913299232993329943299532996329973299832999330003300133002330033300433005330063300733008330093301033011330123301333014330153301633017330183301933020330213302233023330243302533026330273302833029330303303133032330333303433035330363303733038330393304033041330423304333044330453304633047330483304933050330513305233053330543305533056330573305833059330603306133062330633306433065330663306733068330693307033071330723307333074330753307633077330783307933080330813308233083330843308533086330873308833089330903309133092330933309433095330963309733098330993310033101331023310333104331053310633107331083310933110331113311233113331143311533116331173311833119331203312133122331233312433125331263312733128331293313033131331323313333134331353313633137331383313933140331413314233143331443314533146331473314833149331503315133152331533315433155331563315733158331593316033161331623316333164331653316633167331683316933170331713317233173331743317533176331773317833179331803318133182331833318433185331863318733188331893319033191331923319333194331953319633197331983319933200332013320233203332043320533206332073320833209332103321133212332133321433215332163321733218332193322033221332223322333224332253322633227332283322933230332313323233233332343323533236332373323833239332403324133242332433324433245332463324733248332493325033251332523325333254332553325633257332583325933260332613326233263332643326533266332673326833269332703327133272332733327433275332763327733278332793328033281332823328333284332853328633287332883328933290332913329233293332943329533296332973329833299333003330133302333033330433305333063330733308333093331033311333123331333314333153331633317333183331933320333213332233323333243332533326333273332833329333303333133332333333333433335333363333733338333393334033341333423334333344333453334633347333483334933350333513335233353333543335533356333573335833359333603336133362333633336433365333663336733368333693337033371333723337333374333753337633377333783337933380333813338233383333843338533386333873338833389333903339133392333933339433395333963339733398333993340033401334023340333404334053340633407334083340933410334113341233413334143341533416334173341833419334203342133422334233342433425334263342733428334293343033431334323343333434334353343633437334383343933440334413344233443334443344533446334473344833449334503345133452334533345433455334563345733458334593346033461334623346333464334653346633467334683346933470334713347233473334743347533476334773347833479334803348133482334833348433485334863348733488334893349033491334923349333494334953349633497334983349933500335013350233503335043350533506335073350833509335103351133512335133351433515335163351733518335193352033521335223352333524335253352633527335283352933530335313353233533335343353533536335373353833539335403354133542335433354433545335463354733548335493355033551335523355333554335553355633557335583355933560335613356233563335643356533566335673356833569335703357133572335733357433575335763357733578335793358033581335823358333584335853358633587335883358933590335913359233593335943359533596335973359833599336003360133602336033360433605336063360733608336093361033611336123361333614336153361633617336183361933620336213362233623336243362533626336273362833629336303363133632336333363433635336363363733638336393364033641336423364333644336453364633647336483364933650336513365233653336543365533656336573365833659336603366133662336633366433665336663366733668336693367033671336723367333674336753367633677336783367933680336813368233683336843368533686336873368833689336903369133692336933369433695336963369733698336993370033701337023370333704337053370633707337083370933710337113371233713337143371533716337173371833719337203372133722337233372433725337263372733728337293373033731337323373333734337353373633737337383373933740337413374233743337443374533746337473374833749337503375133752337533375433755337563375733758337593376033761337623376333764337653376633767337683376933770337713377233773337743377533776337773377833779337803378133782337833378433785337863378733788337893379033791337923379333794337953379633797337983379933800338013380233803338043380533806338073380833809338103381133812338133381433815338163381733818338193382033821338223382333824338253382633827338283382933830338313383233833338343383533836338373383833839338403384133842338433384433845338463384733848338493385033851338523385333854338553385633857338583385933860338613386233863338643386533866338673386833869338703387133872338733387433875338763387733878338793388033881338823388333884338853388633887338883388933890338913389233893338943389533896338973389833899339003390133902339033390433905339063390733908339093391033911339123391333914339153391633917339183391933920339213392233923339243392533926339273392833929339303393133932339333393433935339363393733938339393394033941339423394333944339453394633947339483394933950339513395233953339543395533956339573395833959339603396133962339633396433965339663396733968339693397033971339723397333974339753397633977339783397933980339813398233983339843398533986339873398833989339903399133992339933399433995339963399733998339993400034001340023400334004340053400634007340083400934010340113401234013340143401534016340173401834019340203402134022340233402434025340263402734028340293403034031340323403334034340353403634037340383403934040340413404234043340443404534046340473404834049340503405134052340533405434055340563405734058340593406034061340623406334064340653406634067340683406934070340713407234073340743407534076340773407834079340803408134082340833408434085340863408734088340893409034091340923409334094340953409634097340983409934100341013410234103341043410534106341073410834109341103411134112341133411434115341163411734118341193412034121341223412334124341253412634127341283412934130341313413234133341343413534136341373413834139341403414134142341433414434145341463414734148341493415034151341523415334154341553415634157341583415934160341613416234163341643416534166341673416834169341703417134172341733417434175341763417734178341793418034181341823418334184341853418634187341883418934190341913419234193341943419534196341973419834199342003420134202342033420434205342063420734208342093421034211342123421334214342153421634217342183421934220342213422234223342243422534226342273422834229342303423134232342333423434235342363423734238342393424034241342423424334244342453424634247342483424934250342513425234253342543425534256342573425834259342603426134262342633426434265342663426734268342693427034271342723427334274342753427634277342783427934280342813428234283342843428534286342873428834289342903429134292342933429434295342963429734298342993430034301343023430334304343053430634307343083430934310343113431234313343143431534316343173431834319343203432134322343233432434325343263432734328343293433034331343323433334334343353433634337343383433934340343413434234343343443434534346343473434834349343503435134352343533435434355343563435734358343593436034361343623436334364343653436634367343683436934370343713437234373343743437534376343773437834379343803438134382343833438434385343863438734388343893439034391343923439334394343953439634397343983439934400344013440234403344043440534406344073440834409344103441134412344133441434415344163441734418344193442034421344223442334424344253442634427344283442934430344313443234433344343443534436344373443834439344403444134442344433444434445344463444734448344493445034451344523445334454344553445634457344583445934460344613446234463344643446534466344673446834469344703447134472344733447434475344763447734478344793448034481344823448334484344853448634487344883448934490344913449234493344943449534496344973449834499345003450134502345033450434505345063450734508345093451034511345123451334514345153451634517345183451934520345213452234523345243452534526345273452834529345303453134532345333453434535345363453734538345393454034541345423454334544345453454634547345483454934550345513455234553345543455534556345573455834559345603456134562345633456434565345663456734568345693457034571345723457334574345753457634577345783457934580345813458234583345843458534586345873458834589345903459134592345933459434595345963459734598345993460034601346023460334604346053460634607346083460934610346113461234613346143461534616346173461834619346203462134622346233462434625346263462734628346293463034631346323463334634346353463634637346383463934640346413464234643346443464534646346473464834649346503465134652346533465434655346563465734658346593466034661346623466334664346653466634667346683466934670346713467234673346743467534676346773467834679346803468134682346833468434685346863468734688346893469034691346923469334694346953469634697346983469934700347013470234703347043470534706347073470834709347103471134712347133471434715347163471734718347193472034721347223472334724347253472634727347283472934730347313473234733347343473534736347373473834739347403474134742347433474434745347463474734748347493475034751347523475334754347553475634757347583475934760347613476234763347643476534766347673476834769347703477134772347733477434775347763477734778347793478034781347823478334784347853478634787347883478934790347913479234793347943479534796347973479834799348003480134802348033480434805348063480734808348093481034811348123481334814348153481634817348183481934820348213482234823348243482534826348273482834829348303483134832348333483434835348363483734838348393484034841348423484334844348453484634847348483484934850348513485234853348543485534856348573485834859348603486134862348633486434865348663486734868348693487034871348723487334874348753487634877348783487934880348813488234883348843488534886348873488834889348903489134892348933489434895348963489734898348993490034901349023490334904349053490634907349083490934910349113491234913349143491534916349173491834919349203492134922349233492434925349263492734928349293493034931349323493334934349353493634937349383493934940349413494234943349443494534946349473494834949349503495134952349533495434955349563495734958349593496034961349623496334964349653496634967349683496934970349713497234973349743497534976349773497834979349803498134982349833498434985349863498734988349893499034991349923499334994349953499634997349983499935000350013500235003350043500535006350073500835009350103501135012350133501435015350163501735018350193502035021350223502335024350253502635027350283502935030350313503235033350343503535036350373503835039350403504135042350433504435045350463504735048350493505035051350523505335054350553505635057350583505935060350613506235063350643506535066350673506835069350703507135072350733507435075350763507735078350793508035081350823508335084350853508635087350883508935090350913509235093350943509535096350973509835099351003510135102351033510435105351063510735108351093511035111351123511335114351153511635117351183511935120351213512235123351243512535126351273512835129351303513135132351333513435135351363513735138351393514035141351423514335144351453514635147351483514935150351513515235153351543515535156351573515835159351603516135162351633516435165351663516735168351693517035171351723517335174351753517635177351783517935180351813518235183351843518535186351873518835189351903519135192351933519435195351963519735198351993520035201352023520335204352053520635207352083520935210352113521235213352143521535216352173521835219352203522135222352233522435225352263522735228352293523035231352323523335234352353523635237352383523935240352413524235243352443524535246352473524835249352503525135252352533525435255352563525735258352593526035261352623526335264352653526635267352683526935270352713527235273352743527535276352773527835279352803528135282352833528435285352863528735288352893529035291352923529335294352953529635297352983529935300353013530235303353043530535306353073530835309353103531135312353133531435315353163531735318353193532035321353223532335324353253532635327353283532935330353313533235333353343533535336353373533835339353403534135342353433534435345353463534735348353493535035351353523535335354353553535635357353583535935360353613536235363353643536535366353673536835369353703537135372353733537435375353763537735378353793538035381353823538335384353853538635387353883538935390353913539235393353943539535396353973539835399354003540135402354033540435405354063540735408354093541035411354123541335414354153541635417354183541935420354213542235423354243542535426354273542835429354303543135432354333543435435354363543735438354393544035441354423544335444354453544635447354483544935450354513545235453354543545535456354573545835459354603546135462354633546435465354663546735468354693547035471354723547335474354753547635477354783547935480354813548235483354843548535486354873548835489354903549135492354933549435495354963549735498354993550035501355023550335504355053550635507355083550935510355113551235513355143551535516355173551835519355203552135522355233552435525355263552735528355293553035531355323553335534355353553635537355383553935540355413554235543355443554535546355473554835549355503555135552355533555435555355563555735558355593556035561355623556335564355653556635567355683556935570355713557235573355743557535576355773557835579355803558135582355833558435585355863558735588355893559035591355923559335594355953559635597355983559935600356013560235603356043560535606356073560835609356103561135612356133561435615356163561735618356193562035621356223562335624356253562635627356283562935630356313563235633356343563535636356373563835639356403564135642356433564435645356463564735648356493565035651356523565335654356553565635657356583565935660356613566235663356643566535666356673566835669356703567135672356733567435675356763567735678356793568035681356823568335684356853568635687356883568935690356913569235693356943569535696356973569835699357003570135702357033570435705357063570735708357093571035711357123571335714357153571635717357183571935720357213572235723357243572535726357273572835729357303573135732357333573435735357363573735738357393574035741357423574335744357453574635747357483574935750357513575235753357543575535756357573575835759357603576135762357633576435765357663576735768357693577035771357723577335774357753577635777357783577935780357813578235783357843578535786357873578835789357903579135792357933579435795357963579735798357993580035801358023580335804358053580635807358083580935810358113581235813358143581535816358173581835819358203582135822358233582435825358263582735828358293583035831358323583335834358353583635837358383583935840358413584235843358443584535846358473584835849358503585135852358533585435855358563585735858358593586035861358623586335864358653586635867358683586935870358713587235873358743587535876358773587835879358803588135882358833588435885358863588735888358893589035891358923589335894358953589635897358983589935900359013590235903359043590535906359073590835909359103591135912359133591435915359163591735918359193592035921359223592335924359253592635927359283592935930359313593235933359343593535936359373593835939359403594135942359433594435945359463594735948359493595035951359523595335954359553595635957359583595935960359613596235963359643596535966359673596835969359703597135972359733597435975359763597735978359793598035981359823598335984359853598635987359883598935990359913599235993359943599535996359973599835999360003600136002360033600436005360063600736008360093601036011360123601336014360153601636017360183601936020360213602236023360243602536026360273602836029360303603136032360333603436035360363603736038360393604036041360423604336044360453604636047360483604936050360513605236053360543605536056360573605836059360603606136062360633606436065360663606736068360693607036071360723607336074360753607636077360783607936080360813608236083360843608536086360873608836089360903609136092360933609436095360963609736098360993610036101361023610336104361053610636107361083610936110361113611236113361143611536116361173611836119361203612136122361233612436125361263612736128361293613036131361323613336134361353613636137361383613936140361413614236143361443614536146361473614836149361503615136152361533615436155361563615736158361593616036161361623616336164361653616636167361683616936170361713617236173361743617536176361773617836179361803618136182361833618436185361863618736188361893619036191361923619336194361953619636197361983619936200362013620236203362043620536206362073620836209362103621136212362133621436215362163621736218362193622036221362223622336224362253622636227362283622936230362313623236233362343623536236362373623836239362403624136242362433624436245362463624736248362493625036251362523625336254362553625636257362583625936260362613626236263362643626536266362673626836269362703627136272362733627436275362763627736278362793628036281362823628336284362853628636287362883628936290362913629236293362943629536296362973629836299363003630136302363033630436305363063630736308363093631036311363123631336314363153631636317363183631936320363213632236323363243632536326363273632836329363303633136332363333633436335363363633736338363393634036341363423634336344363453634636347363483634936350363513635236353363543635536356363573635836359363603636136362363633636436365363663636736368363693637036371363723637336374363753637636377363783637936380363813638236383363843638536386363873638836389363903639136392363933639436395363963639736398363993640036401364023640336404364053640636407364083640936410364113641236413364143641536416364173641836419364203642136422364233642436425364263642736428364293643036431364323643336434364353643636437364383643936440364413644236443364443644536446364473644836449364503645136452364533645436455364563645736458364593646036461364623646336464364653646636467364683646936470364713647236473364743647536476364773647836479364803648136482364833648436485364863648736488364893649036491364923649336494364953649636497364983649936500365013650236503365043650536506365073650836509365103651136512365133651436515365163651736518365193652036521365223652336524365253652636527365283652936530365313653236533365343653536536365373653836539365403654136542365433654436545365463654736548365493655036551365523655336554365553655636557365583655936560365613656236563365643656536566365673656836569365703657136572365733657436575365763657736578365793658036581365823658336584365853658636587365883658936590365913659236593365943659536596365973659836599366003660136602366033660436605366063660736608366093661036611366123661336614366153661636617366183661936620366213662236623366243662536626366273662836629366303663136632366333663436635366363663736638366393664036641366423664336644366453664636647366483664936650366513665236653366543665536656366573665836659366603666136662366633666436665366663666736668366693667036671366723667336674366753667636677366783667936680366813668236683366843668536686366873668836689366903669136692366933669436695366963669736698366993670036701367023670336704367053670636707367083670936710367113671236713367143671536716367173671836719367203672136722367233672436725367263672736728367293673036731367323673336734367353673636737367383673936740367413674236743367443674536746367473674836749367503675136752367533675436755367563675736758367593676036761367623676336764367653676636767367683676936770367713677236773367743677536776367773677836779367803678136782367833678436785367863678736788367893679036791367923679336794367953679636797367983679936800368013680236803368043680536806368073680836809368103681136812368133681436815368163681736818368193682036821368223682336824368253682636827368283682936830368313683236833368343683536836368373683836839368403684136842368433684436845368463684736848368493685036851368523685336854368553685636857368583685936860368613686236863368643686536866368673686836869368703687136872368733687436875368763687736878368793688036881368823688336884368853688636887368883688936890368913689236893368943689536896368973689836899369003690136902369033690436905369063690736908369093691036911369123691336914369153691636917369183691936920369213692236923369243692536926369273692836929369303693136932369333693436935369363693736938369393694036941369423694336944369453694636947369483694936950369513695236953369543695536956369573695836959369603696136962369633696436965369663696736968369693697036971369723697336974369753697636977369783697936980369813698236983369843698536986369873698836989369903699136992369933699436995369963699736998369993700037001370023700337004370053700637007370083700937010370113701237013370143701537016370173701837019370203702137022370233702437025370263702737028370293703037031370323703337034370353703637037370383703937040370413704237043370443704537046370473704837049370503705137052370533705437055370563705737058370593706037061370623706337064370653706637067370683706937070370713707237073370743707537076370773707837079370803708137082370833708437085370863708737088370893709037091370923709337094370953709637097370983709937100371013710237103371043710537106371073710837109371103711137112371133711437115371163711737118371193712037121371223712337124371253712637127371283712937130371313713237133371343713537136371373713837139371403714137142371433714437145371463714737148371493715037151371523715337154371553715637157371583715937160371613716237163371643716537166371673716837169371703717137172371733717437175371763717737178371793718037181371823718337184371853718637187371883718937190371913719237193371943719537196371973719837199372003720137202372033720437205372063720737208372093721037211372123721337214372153721637217372183721937220372213722237223372243722537226372273722837229372303723137232372333723437235372363723737238372393724037241372423724337244372453724637247372483724937250372513725237253372543725537256372573725837259372603726137262372633726437265372663726737268372693727037271372723727337274372753727637277372783727937280372813728237283372843728537286372873728837289372903729137292372933729437295372963729737298372993730037301373023730337304373053730637307373083730937310373113731237313373143731537316373173731837319373203732137322373233732437325373263732737328373293733037331373323733337334373353733637337373383733937340373413734237343373443734537346373473734837349373503735137352373533735437355373563735737358373593736037361373623736337364373653736637367373683736937370373713737237373373743737537376373773737837379373803738137382373833738437385373863738737388373893739037391373923739337394373953739637397373983739937400374013740237403374043740537406374073740837409374103741137412374133741437415374163741737418374193742037421374223742337424374253742637427374283742937430374313743237433374343743537436374373743837439374403744137442374433744437445374463744737448374493745037451374523745337454374553745637457374583745937460374613746237463374643746537466374673746837469374703747137472374733747437475374763747737478374793748037481374823748337484374853748637487374883748937490374913749237493374943749537496374973749837499375003750137502375033750437505375063750737508375093751037511375123751337514375153751637517375183751937520375213752237523375243752537526375273752837529375303753137532375333753437535375363753737538375393754037541375423754337544375453754637547375483754937550375513755237553375543755537556375573755837559375603756137562375633756437565375663756737568375693757037571375723757337574375753757637577375783757937580375813758237583375843758537586375873758837589375903759137592375933759437595375963759737598375993760037601376023760337604376053760637607376083760937610376113761237613376143761537616376173761837619376203762137622376233762437625376263762737628376293763037631376323763337634376353763637637376383763937640376413764237643376443764537646376473764837649376503765137652376533765437655376563765737658376593766037661376623766337664376653766637667376683766937670376713767237673376743767537676376773767837679376803768137682376833768437685376863768737688376893769037691376923769337694376953769637697376983769937700377013770237703377043770537706377073770837709377103771137712377133771437715377163771737718377193772037721377223772337724377253772637727377283772937730377313773237733377343773537736377373773837739377403774137742377433774437745377463774737748377493775037751377523775337754377553775637757377583775937760377613776237763377643776537766377673776837769377703777137772377733777437775377763777737778377793778037781377823778337784377853778637787377883778937790377913779237793377943779537796377973779837799378003780137802378033780437805378063780737808378093781037811378123781337814378153781637817378183781937820378213782237823378243782537826378273782837829378303783137832378333783437835378363783737838378393784037841378423784337844378453784637847378483784937850378513785237853378543785537856378573785837859378603786137862378633786437865378663786737868378693787037871378723787337874378753787637877378783787937880378813788237883378843788537886378873788837889378903789137892378933789437895378963789737898378993790037901379023790337904379053790637907379083790937910379113791237913379143791537916379173791837919379203792137922379233792437925379263792737928379293793037931379323793337934379353793637937379383793937940379413794237943379443794537946379473794837949379503795137952379533795437955379563795737958379593796037961379623796337964379653796637967379683796937970379713797237973379743797537976379773797837979379803798137982379833798437985379863798737988379893799037991379923799337994379953799637997379983799938000380013800238003380043800538006380073800838009380103801138012380133801438015380163801738018380193802038021380223802338024380253802638027380283802938030380313803238033380343803538036380373803838039380403804138042380433804438045380463804738048380493805038051380523805338054380553805638057380583805938060380613806238063380643806538066380673806838069380703807138072380733807438075380763807738078380793808038081380823808338084380853808638087380883808938090380913809238093380943809538096380973809838099381003810138102381033810438105381063810738108381093811038111381123811338114381153811638117381183811938120381213812238123381243812538126381273812838129381303813138132381333813438135381363813738138381393814038141381423814338144381453814638147381483814938150381513815238153381543815538156381573815838159381603816138162381633816438165381663816738168381693817038171381723817338174381753817638177381783817938180381813818238183381843818538186381873818838189381903819138192381933819438195381963819738198381993820038201382023820338204382053820638207382083820938210382113821238213382143821538216382173821838219382203822138222382233822438225382263822738228382293823038231382323823338234382353823638237382383823938240382413824238243382443824538246382473824838249382503825138252382533825438255382563825738258382593826038261382623826338264382653826638267382683826938270382713827238273382743827538276382773827838279382803828138282382833828438285382863828738288382893829038291382923829338294382953829638297382983829938300383013830238303383043830538306383073830838309383103831138312383133831438315383163831738318383193832038321383223832338324383253832638327383283832938330383313833238333383343833538336383373833838339383403834138342383433834438345383463834738348383493835038351383523835338354383553835638357383583835938360383613836238363383643836538366383673836838369383703837138372383733837438375383763837738378383793838038381383823838338384383853838638387383883838938390383913839238393383943839538396383973839838399384003840138402384033840438405384063840738408384093841038411384123841338414384153841638417384183841938420384213842238423384243842538426384273842838429384303843138432384333843438435384363843738438384393844038441384423844338444384453844638447384483844938450384513845238453384543845538456384573845838459384603846138462384633846438465384663846738468384693847038471384723847338474384753847638477384783847938480384813848238483384843848538486384873848838489384903849138492384933849438495384963849738498384993850038501385023850338504385053850638507385083850938510385113851238513385143851538516385173851838519385203852138522385233852438525385263852738528385293853038531385323853338534385353853638537385383853938540385413854238543385443854538546385473854838549385503855138552385533855438555385563855738558385593856038561385623856338564385653856638567385683856938570385713857238573385743857538576385773857838579385803858138582385833858438585385863858738588385893859038591385923859338594385953859638597385983859938600386013860238603386043860538606386073860838609386103861138612386133861438615386163861738618386193862038621386223862338624386253862638627386283862938630386313863238633386343863538636386373863838639386403864138642386433864438645386463864738648386493865038651386523865338654386553865638657386583865938660386613866238663386643866538666386673866838669386703867138672386733867438675386763867738678386793868038681386823868338684386853868638687386883868938690386913869238693386943869538696386973869838699387003870138702387033870438705387063870738708387093871038711387123871338714387153871638717387183871938720387213872238723387243872538726387273872838729387303873138732387333873438735387363873738738387393874038741387423874338744387453874638747387483874938750387513875238753387543875538756387573875838759387603876138762387633876438765387663876738768387693877038771387723877338774387753877638777387783877938780387813878238783387843878538786387873878838789387903879138792387933879438795387963879738798387993880038801388023880338804388053880638807388083880938810388113881238813388143881538816388173881838819388203882138822388233882438825388263882738828388293883038831388323883338834388353883638837388383883938840388413884238843388443884538846388473884838849388503885138852388533885438855388563885738858388593886038861388623886338864388653886638867388683886938870388713887238873388743887538876388773887838879388803888138882388833888438885388863888738888388893889038891388923889338894388953889638897388983889938900389013890238903389043890538906389073890838909389103891138912389133891438915389163891738918389193892038921389223892338924389253892638927389283892938930389313893238933389343893538936389373893838939389403894138942389433894438945389463894738948389493895038951389523895338954389553895638957389583895938960389613896238963389643896538966389673896838969389703897138972389733897438975389763897738978389793898038981389823898338984389853898638987389883898938990389913899238993389943899538996389973899838999390003900139002390033900439005390063900739008390093901039011390123901339014390153901639017390183901939020390213902239023390243902539026390273902839029390303903139032390333903439035390363903739038390393904039041390423904339044390453904639047390483904939050390513905239053390543905539056390573905839059390603906139062390633906439065390663906739068390693907039071390723907339074390753907639077390783907939080390813908239083390843908539086390873908839089390903909139092390933909439095390963909739098390993910039101391023910339104391053910639107391083910939110391113911239113391143911539116391173911839119391203912139122391233912439125391263912739128391293913039131391323913339134391353913639137391383913939140391413914239143391443914539146391473914839149391503915139152391533915439155391563915739158391593916039161391623916339164391653916639167391683916939170391713917239173391743917539176391773917839179391803918139182391833918439185391863918739188391893919039191391923919339194391953919639197391983919939200392013920239203392043920539206392073920839209392103921139212392133921439215392163921739218392193922039221392223922339224392253922639227392283922939230392313923239233392343923539236392373923839239392403924139242392433924439245392463924739248392493925039251392523925339254392553925639257392583925939260392613926239263392643926539266392673926839269392703927139272392733927439275392763927739278392793928039281392823928339284392853928639287392883928939290392913929239293392943929539296392973929839299393003930139302393033930439305393063930739308393093931039311393123931339314393153931639317393183931939320393213932239323393243932539326393273932839329393303933139332393333933439335393363933739338393393934039341393423934339344393453934639347393483934939350393513935239353393543935539356393573935839359393603936139362393633936439365393663936739368393693937039371393723937339374393753937639377393783937939380393813938239383393843938539386393873938839389393903939139392393933939439395393963939739398393993940039401394023940339404394053940639407394083940939410394113941239413394143941539416394173941839419394203942139422394233942439425394263942739428394293943039431394323943339434394353943639437394383943939440394413944239443394443944539446394473944839449394503945139452394533945439455394563945739458394593946039461394623946339464394653946639467394683946939470394713947239473394743947539476394773947839479394803948139482394833948439485394863948739488394893949039491394923949339494394953949639497394983949939500395013950239503395043950539506395073950839509395103951139512395133951439515395163951739518395193952039521395223952339524395253952639527395283952939530395313953239533395343953539536395373953839539395403954139542395433954439545395463954739548395493955039551395523955339554395553955639557395583955939560395613956239563395643956539566395673956839569395703957139572395733957439575395763957739578395793958039581395823958339584395853958639587395883958939590395913959239593395943959539596395973959839599396003960139602396033960439605396063960739608396093961039611396123961339614396153961639617396183961939620396213962239623396243962539626396273962839629396303963139632396333963439635396363963739638396393964039641396423964339644396453964639647396483964939650396513965239653396543965539656396573965839659396603966139662396633966439665396663966739668396693967039671396723967339674396753967639677396783967939680396813968239683396843968539686396873968839689396903969139692396933969439695396963969739698396993970039701397023970339704397053970639707397083970939710397113971239713397143971539716397173971839719397203972139722397233972439725397263972739728397293973039731397323973339734397353973639737397383973939740397413974239743397443974539746397473974839749397503975139752397533975439755397563975739758397593976039761397623976339764397653976639767397683976939770397713977239773397743977539776397773977839779397803978139782397833978439785397863978739788397893979039791397923979339794397953979639797397983979939800398013980239803398043980539806398073980839809398103981139812398133981439815398163981739818398193982039821398223982339824398253982639827398283982939830398313983239833398343983539836398373983839839398403984139842398433984439845398463984739848398493985039851398523985339854398553985639857398583985939860398613986239863398643986539866398673986839869398703987139872398733987439875398763987739878398793988039881398823988339884398853988639887398883988939890398913989239893398943989539896398973989839899399003990139902399033990439905399063990739908399093991039911399123991339914399153991639917399183991939920399213992239923399243992539926399273992839929399303993139932399333993439935399363993739938399393994039941399423994339944399453994639947399483994939950399513995239953399543995539956399573995839959399603996139962399633996439965399663996739968399693997039971399723997339974399753997639977399783997939980399813998239983399843998539986399873998839989399903999139992399933999439995399963999739998399994000040001400024000340004400054000640007400084000940010400114001240013400144001540016400174001840019400204002140022400234002440025400264002740028400294003040031400324003340034400354003640037400384003940040400414004240043400444004540046400474004840049400504005140052400534005440055400564005740058400594006040061400624006340064400654006640067400684006940070400714007240073400744007540076400774007840079400804008140082400834008440085400864008740088400894009040091400924009340094400954009640097400984009940100401014010240103401044010540106401074010840109401104011140112401134011440115401164011740118401194012040121401224012340124401254012640127401284012940130401314013240133401344013540136401374013840139401404014140142401434014440145401464014740148401494015040151401524015340154401554015640157401584015940160401614016240163401644016540166401674016840169401704017140172401734017440175401764017740178401794018040181401824018340184401854018640187401884018940190401914019240193401944019540196401974019840199402004020140202402034020440205402064020740208402094021040211402124021340214402154021640217402184021940220402214022240223402244022540226402274022840229402304023140232402334023440235402364023740238402394024040241402424024340244402454024640247402484024940250402514025240253402544025540256402574025840259402604026140262402634026440265402664026740268402694027040271402724027340274402754027640277402784027940280402814028240283402844028540286402874028840289402904029140292402934029440295402964029740298402994030040301403024030340304403054030640307403084030940310403114031240313403144031540316403174031840319403204032140322403234032440325403264032740328403294033040331403324033340334403354033640337403384033940340403414034240343403444034540346403474034840349403504035140352403534035440355403564035740358403594036040361403624036340364403654036640367403684036940370403714037240373403744037540376403774037840379403804038140382403834038440385403864038740388403894039040391403924039340394403954039640397403984039940400404014040240403404044040540406404074040840409404104041140412404134041440415404164041740418404194042040421404224042340424404254042640427404284042940430404314043240433404344043540436404374043840439404404044140442404434044440445404464044740448404494045040451404524045340454404554045640457404584045940460404614046240463404644046540466404674046840469404704047140472404734047440475404764047740478404794048040481404824048340484404854048640487404884048940490404914049240493404944049540496404974049840499405004050140502405034050440505405064050740508405094051040511405124051340514405154051640517405184051940520405214052240523405244052540526405274052840529405304053140532405334053440535405364053740538405394054040541405424054340544405454054640547405484054940550405514055240553405544055540556405574055840559405604056140562405634056440565405664056740568405694057040571405724057340574405754057640577405784057940580405814058240583405844058540586405874058840589405904059140592405934059440595405964059740598405994060040601406024060340604406054060640607406084060940610406114061240613406144061540616406174061840619406204062140622406234062440625406264062740628406294063040631406324063340634406354063640637406384063940640406414064240643406444064540646406474064840649406504065140652406534065440655406564065740658406594066040661406624066340664406654066640667406684066940670406714067240673406744067540676406774067840679406804068140682406834068440685406864068740688406894069040691406924069340694406954069640697406984069940700407014070240703407044070540706407074070840709407104071140712407134071440715407164071740718407194072040721407224072340724407254072640727407284072940730407314073240733407344073540736407374073840739407404074140742407434074440745407464074740748407494075040751407524075340754407554075640757407584075940760407614076240763407644076540766407674076840769407704077140772407734077440775407764077740778407794078040781407824078340784407854078640787407884078940790407914079240793407944079540796407974079840799408004080140802408034080440805408064080740808408094081040811408124081340814408154081640817408184081940820408214082240823408244082540826408274082840829408304083140832408334083440835408364083740838408394084040841408424084340844408454084640847408484084940850408514085240853408544085540856408574085840859408604086140862408634086440865408664086740868408694087040871408724087340874408754087640877408784087940880408814088240883408844088540886408874088840889408904089140892408934089440895408964089740898408994090040901409024090340904409054090640907409084090940910409114091240913409144091540916409174091840919409204092140922409234092440925409264092740928409294093040931409324093340934409354093640937409384093940940409414094240943409444094540946409474094840949409504095140952409534095440955409564095740958409594096040961409624096340964409654096640967409684096940970409714097240973409744097540976409774097840979409804098140982409834098440985409864098740988409894099040991409924099340994409954099640997409984099941000410014100241003410044100541006410074100841009410104101141012410134101441015410164101741018410194102041021410224102341024410254102641027410284102941030410314103241033410344103541036410374103841039410404104141042410434104441045410464104741048410494105041051410524105341054410554105641057410584105941060410614106241063410644106541066410674106841069410704107141072410734107441075410764107741078410794108041081410824108341084410854108641087410884108941090410914109241093410944109541096410974109841099411004110141102411034110441105411064110741108411094111041111411124111341114411154111641117411184111941120411214112241123411244112541126411274112841129411304113141132411334113441135411364113741138411394114041141411424114341144411454114641147411484114941150411514115241153411544115541156411574115841159411604116141162411634116441165411664116741168411694117041171411724117341174411754117641177411784117941180411814118241183411844118541186411874118841189411904119141192411934119441195411964119741198411994120041201412024120341204412054120641207412084120941210412114121241213412144121541216412174121841219412204122141222412234122441225412264122741228412294123041231412324123341234412354123641237412384123941240412414124241243412444124541246412474124841249412504125141252412534125441255412564125741258412594126041261412624126341264412654126641267412684126941270412714127241273412744127541276412774127841279412804128141282412834128441285412864128741288412894129041291412924129341294412954129641297412984129941300413014130241303413044130541306413074130841309413104131141312413134131441315413164131741318413194132041321413224132341324413254132641327413284132941330413314133241333413344133541336413374133841339413404134141342413434134441345413464134741348413494135041351413524135341354413554135641357413584135941360413614136241363413644136541366413674136841369413704137141372413734137441375413764137741378413794138041381413824138341384413854138641387413884138941390413914139241393413944139541396413974139841399414004140141402414034140441405414064140741408414094141041411414124141341414414154141641417414184141941420414214142241423414244142541426414274142841429414304143141432414334143441435414364143741438414394144041441414424144341444414454144641447414484144941450414514145241453414544145541456414574145841459414604146141462414634146441465414664146741468414694147041471414724147341474414754147641477414784147941480414814148241483414844148541486414874148841489414904149141492414934149441495414964149741498414994150041501415024150341504415054150641507415084150941510415114151241513415144151541516415174151841519415204152141522415234152441525415264152741528415294153041531415324153341534415354153641537415384153941540415414154241543415444154541546415474154841549415504155141552415534155441555415564155741558415594156041561415624156341564415654156641567415684156941570415714157241573415744157541576415774157841579415804158141582415834158441585415864158741588415894159041591415924159341594415954159641597415984159941600416014160241603416044160541606416074160841609416104161141612416134161441615416164161741618416194162041621416224162341624416254162641627416284162941630416314163241633416344163541636416374163841639416404164141642416434164441645416464164741648416494165041651416524165341654416554165641657416584165941660416614166241663416644166541666416674166841669416704167141672416734167441675416764167741678416794168041681416824168341684416854168641687416884168941690416914169241693416944169541696416974169841699417004170141702417034170441705417064170741708417094171041711417124171341714417154171641717417184171941720417214172241723417244172541726417274172841729417304173141732417334173441735417364173741738417394174041741417424174341744417454174641747417484174941750417514175241753417544175541756417574175841759417604176141762417634176441765417664176741768417694177041771417724177341774417754177641777417784177941780417814178241783417844178541786417874178841789417904179141792417934179441795417964179741798417994180041801418024180341804418054180641807418084180941810418114181241813418144181541816418174181841819418204182141822418234182441825418264182741828418294183041831418324183341834418354183641837418384183941840418414184241843418444184541846418474184841849418504185141852418534185441855418564185741858418594186041861418624186341864418654186641867418684186941870418714187241873418744187541876418774187841879418804188141882418834188441885418864188741888418894189041891418924189341894418954189641897418984189941900419014190241903419044190541906419074190841909419104191141912419134191441915419164191741918419194192041921419224192341924419254192641927419284192941930419314193241933419344193541936419374193841939419404194141942419434194441945419464194741948419494195041951419524195341954419554195641957419584195941960419614196241963419644196541966419674196841969419704197141972419734197441975419764197741978419794198041981419824198341984419854198641987419884198941990419914199241993419944199541996419974199841999420004200142002420034200442005420064200742008420094201042011420124201342014420154201642017420184201942020420214202242023420244202542026420274202842029420304203142032420334203442035420364203742038420394204042041420424204342044420454204642047420484204942050420514205242053420544205542056420574205842059420604206142062420634206442065420664206742068420694207042071420724207342074420754207642077420784207942080420814208242083420844208542086420874208842089420904209142092420934209442095420964209742098420994210042101421024210342104421054210642107421084210942110421114211242113421144211542116421174211842119421204212142122421234212442125421264212742128421294213042131421324213342134421354213642137421384213942140421414214242143421444214542146421474214842149421504215142152421534215442155421564215742158421594216042161421624216342164421654216642167421684216942170421714217242173421744217542176421774217842179421804218142182421834218442185421864218742188421894219042191421924219342194421954219642197421984219942200422014220242203422044220542206422074220842209422104221142212422134221442215422164221742218422194222042221422224222342224422254222642227422284222942230422314223242233422344223542236422374223842239422404224142242422434224442245422464224742248422494225042251422524225342254422554225642257422584225942260422614226242263422644226542266422674226842269422704227142272422734227442275422764227742278422794228042281422824228342284422854228642287422884228942290422914229242293422944229542296422974229842299423004230142302423034230442305423064230742308423094231042311423124231342314423154231642317423184231942320423214232242323423244232542326423274232842329423304233142332423334233442335423364233742338423394234042341423424234342344423454234642347423484234942350423514235242353423544235542356423574235842359423604236142362423634236442365423664236742368423694237042371423724237342374423754237642377423784237942380423814238242383423844238542386423874238842389423904239142392423934239442395423964239742398423994240042401424024240342404424054240642407424084240942410424114241242413424144241542416424174241842419424204242142422424234242442425424264242742428424294243042431424324243342434424354243642437424384243942440424414244242443424444244542446424474244842449424504245142452424534245442455424564245742458424594246042461424624246342464424654246642467424684246942470424714247242473424744247542476424774247842479424804248142482424834248442485424864248742488424894249042491424924249342494424954249642497424984249942500425014250242503425044250542506425074250842509425104251142512425134251442515425164251742518425194252042521425224252342524425254252642527425284252942530425314253242533425344253542536425374253842539425404254142542425434254442545425464254742548425494255042551425524255342554425554255642557425584255942560425614256242563425644256542566425674256842569425704257142572425734257442575425764257742578425794258042581425824258342584425854258642587425884258942590425914259242593425944259542596425974259842599426004260142602426034260442605426064260742608426094261042611426124261342614426154261642617426184261942620426214262242623426244262542626426274262842629426304263142632426334263442635426364263742638426394264042641426424264342644426454264642647426484264942650426514265242653426544265542656426574265842659426604266142662426634266442665426664266742668426694267042671426724267342674426754267642677426784267942680426814268242683426844268542686426874268842689426904269142692426934269442695426964269742698426994270042701427024270342704427054270642707427084270942710427114271242713427144271542716427174271842719427204272142722427234272442725427264272742728427294273042731427324273342734427354273642737427384273942740427414274242743427444274542746427474274842749427504275142752427534275442755427564275742758427594276042761427624276342764427654276642767427684276942770427714277242773427744277542776427774277842779427804278142782427834278442785427864278742788427894279042791427924279342794427954279642797427984279942800428014280242803428044280542806428074280842809428104281142812428134281442815428164281742818428194282042821428224282342824428254282642827428284282942830428314283242833428344283542836428374283842839428404284142842428434284442845428464284742848428494285042851428524285342854428554285642857428584285942860428614286242863428644286542866428674286842869428704287142872428734287442875428764287742878428794288042881428824288342884428854288642887428884288942890428914289242893428944289542896428974289842899429004290142902429034290442905429064290742908429094291042911429124291342914429154291642917429184291942920429214292242923429244292542926429274292842929429304293142932429334293442935429364293742938429394294042941429424294342944429454294642947429484294942950429514295242953429544295542956429574295842959429604296142962429634296442965429664296742968429694297042971429724297342974429754297642977429784297942980429814298242983429844298542986429874298842989429904299142992429934299442995429964299742998429994300043001430024300343004430054300643007430084300943010430114301243013430144301543016430174301843019430204302143022430234302443025430264302743028430294303043031430324303343034430354303643037430384303943040430414304243043430444304543046430474304843049430504305143052430534305443055430564305743058430594306043061430624306343064430654306643067430684306943070430714307243073430744307543076430774307843079430804308143082430834308443085430864308743088430894309043091430924309343094430954309643097430984309943100431014310243103431044310543106431074310843109431104311143112431134311443115431164311743118431194312043121431224312343124431254312643127431284312943130431314313243133431344313543136431374313843139431404314143142431434314443145431464314743148431494315043151431524315343154431554315643157431584315943160431614316243163431644316543166431674316843169431704317143172431734317443175431764317743178431794318043181431824318343184431854318643187431884318943190431914319243193431944319543196431974319843199432004320143202432034320443205432064320743208432094321043211432124321343214432154321643217432184321943220432214322243223432244322543226432274322843229432304323143232432334323443235432364323743238432394324043241432424324343244432454324643247432484324943250432514325243253432544325543256432574325843259432604326143262432634326443265432664326743268432694327043271432724327343274432754327643277432784327943280432814328243283432844328543286432874328843289432904329143292432934329443295432964329743298432994330043301433024330343304433054330643307433084330943310433114331243313433144331543316433174331843319433204332143322433234332443325433264332743328433294333043331433324333343334433354333643337433384333943340433414334243343433444334543346433474334843349433504335143352433534335443355433564335743358433594336043361433624336343364433654336643367433684336943370433714337243373433744337543376433774337843379433804338143382433834338443385433864338743388433894339043391433924339343394433954339643397433984339943400434014340243403434044340543406434074340843409434104341143412434134341443415434164341743418434194342043421434224342343424434254342643427434284342943430434314343243433434344343543436434374343843439434404344143442434434344443445434464344743448434494345043451434524345343454434554345643457434584345943460434614346243463434644346543466434674346843469434704347143472434734347443475434764347743478434794348043481434824348343484434854348643487434884348943490434914349243493434944349543496434974349843499435004350143502435034350443505435064350743508435094351043511435124351343514435154351643517435184351943520435214352243523435244352543526435274352843529435304353143532435334353443535435364353743538435394354043541435424354343544435454354643547435484354943550435514355243553435544355543556435574355843559435604356143562435634356443565435664356743568435694357043571435724357343574435754357643577435784357943580435814358243583435844358543586435874358843589435904359143592435934359443595435964359743598435994360043601436024360343604436054360643607436084360943610436114361243613436144361543616436174361843619436204362143622436234362443625436264362743628436294363043631436324363343634436354363643637436384363943640436414364243643436444364543646436474364843649436504365143652436534365443655436564365743658436594366043661436624366343664436654366643667436684366943670436714367243673436744367543676436774367843679436804368143682436834368443685436864368743688436894369043691436924369343694436954369643697436984369943700437014370243703437044370543706437074370843709437104371143712437134371443715437164371743718437194372043721437224372343724437254372643727437284372943730437314373243733437344373543736437374373843739437404374143742437434374443745437464374743748437494375043751437524375343754437554375643757437584375943760437614376243763437644376543766437674376843769437704377143772437734377443775437764377743778437794378043781437824378343784437854378643787437884378943790437914379243793437944379543796437974379843799438004380143802438034380443805438064380743808438094381043811438124381343814438154381643817438184381943820438214382243823438244382543826438274382843829438304383143832438334383443835438364383743838438394384043841438424384343844438454384643847438484384943850438514385243853438544385543856438574385843859438604386143862438634386443865438664386743868438694387043871438724387343874438754387643877438784387943880438814388243883438844388543886438874388843889438904389143892438934389443895438964389743898438994390043901439024390343904439054390643907439084390943910439114391243913439144391543916439174391843919439204392143922439234392443925439264392743928439294393043931439324393343934439354393643937439384393943940439414394243943439444394543946439474394843949439504395143952439534395443955439564395743958439594396043961439624396343964439654396643967439684396943970439714397243973439744397543976439774397843979439804398143982439834398443985439864398743988439894399043991439924399343994439954399643997439984399944000440014400244003440044400544006440074400844009440104401144012440134401444015440164401744018440194402044021440224402344024440254402644027440284402944030440314403244033440344403544036440374403844039440404404144042440434404444045440464404744048440494405044051440524405344054440554405644057440584405944060440614406244063440644406544066440674406844069440704407144072440734407444075440764407744078440794408044081440824408344084440854408644087440884408944090440914409244093440944409544096440974409844099441004410144102441034410444105441064410744108441094411044111441124411344114441154411644117441184411944120441214412244123441244412544126441274412844129441304413144132441334413444135441364413744138441394414044141441424414344144441454414644147441484414944150441514415244153441544415544156441574415844159441604416144162441634416444165441664416744168441694417044171441724417344174441754417644177441784417944180441814418244183441844418544186441874418844189441904419144192441934419444195441964419744198441994420044201442024420344204442054420644207442084420944210442114421244213442144421544216442174421844219442204422144222442234422444225442264422744228442294423044231442324423344234442354423644237442384423944240442414424244243442444424544246442474424844249442504425144252442534425444255442564425744258442594426044261442624426344264442654426644267442684426944270442714427244273442744427544276442774427844279442804428144282442834428444285442864428744288442894429044291442924429344294442954429644297442984429944300443014430244303443044430544306443074430844309443104431144312443134431444315443164431744318443194432044321443224432344324443254432644327443284432944330443314433244333443344433544336443374433844339443404434144342443434434444345443464434744348443494435044351443524435344354443554435644357443584435944360443614436244363443644436544366443674436844369443704437144372443734437444375443764437744378443794438044381443824438344384443854438644387443884438944390443914439244393443944439544396443974439844399444004440144402444034440444405444064440744408444094441044411444124441344414444154441644417444184441944420444214442244423444244442544426444274442844429444304443144432444334443444435444364443744438444394444044441444424444344444444454444644447444484444944450444514445244453444544445544456444574445844459444604446144462444634446444465444664446744468444694447044471444724447344474444754447644477444784447944480444814448244483444844448544486444874448844489444904449144492444934449444495444964449744498444994450044501445024450344504445054450644507445084450944510445114451244513445144451544516445174451844519445204452144522445234452444525445264452744528445294453044531445324453344534445354453644537445384453944540445414454244543445444454544546445474454844549445504455144552445534455444555445564455744558445594456044561445624456344564445654456644567445684456944570445714457244573445744457544576445774457844579445804458144582445834458444585445864458744588445894459044591445924459344594445954459644597445984459944600446014460244603446044460544606446074460844609446104461144612446134461444615446164461744618446194462044621446224462344624446254462644627446284462944630446314463244633446344463544636446374463844639446404464144642446434464444645446464464744648446494465044651446524465344654446554465644657446584465944660446614466244663446644466544666446674466844669446704467144672446734467444675446764467744678446794468044681446824468344684446854468644687446884468944690446914469244693446944469544696446974469844699447004470144702447034470444705447064470744708447094471044711447124471344714447154471644717447184471944720447214472244723447244472544726447274472844729447304473144732447334473444735447364473744738447394474044741447424474344744447454474644747447484474944750447514475244753447544475544756447574475844759447604476144762447634476444765447664476744768447694477044771447724477344774447754477644777447784477944780447814478244783447844478544786447874478844789447904479144792447934479444795447964479744798447994480044801448024480344804448054480644807448084480944810448114481244813448144481544816448174481844819448204482144822448234482444825448264482744828448294483044831448324483344834448354483644837448384483944840448414484244843448444484544846448474484844849448504485144852448534485444855448564485744858448594486044861448624486344864448654486644867448684486944870448714487244873448744487544876448774487844879448804488144882448834488444885448864488744888448894489044891448924489344894448954489644897448984489944900449014490244903449044490544906449074490844909449104491144912449134491444915449164491744918449194492044921449224492344924449254492644927449284492944930449314493244933449344493544936449374493844939449404494144942449434494444945449464494744948449494495044951449524495344954449554495644957449584495944960449614496244963449644496544966449674496844969449704497144972449734497444975449764497744978449794498044981449824498344984449854498644987449884498944990449914499244993449944499544996449974499844999450004500145002450034500445005450064500745008450094501045011450124501345014450154501645017450184501945020450214502245023450244502545026450274502845029450304503145032450334503445035450364503745038450394504045041450424504345044450454504645047450484504945050450514505245053450544505545056450574505845059450604506145062450634506445065450664506745068450694507045071450724507345074450754507645077450784507945080450814508245083450844508545086450874508845089450904509145092450934509445095450964509745098450994510045101451024510345104451054510645107451084510945110451114511245113451144511545116451174511845119451204512145122451234512445125451264512745128451294513045131451324513345134451354513645137451384513945140451414514245143451444514545146451474514845149451504515145152451534515445155451564515745158451594516045161451624516345164451654516645167451684516945170451714517245173451744517545176451774517845179451804518145182451834518445185451864518745188451894519045191451924519345194451954519645197451984519945200452014520245203452044520545206452074520845209452104521145212452134521445215452164521745218452194522045221452224522345224452254522645227452284522945230452314523245233452344523545236452374523845239452404524145242452434524445245452464524745248452494525045251452524525345254452554525645257452584525945260452614526245263452644526545266452674526845269452704527145272452734527445275452764527745278452794528045281452824528345284452854528645287452884528945290452914529245293452944529545296452974529845299453004530145302453034530445305453064530745308453094531045311453124531345314453154531645317453184531945320453214532245323453244532545326453274532845329453304533145332453334533445335453364533745338453394534045341453424534345344453454534645347453484534945350453514535245353453544535545356453574535845359453604536145362453634536445365453664536745368453694537045371453724537345374453754537645377453784537945380453814538245383453844538545386453874538845389453904539145392453934539445395453964539745398453994540045401454024540345404454054540645407454084540945410454114541245413454144541545416454174541845419454204542145422454234542445425454264542745428454294543045431454324543345434454354543645437454384543945440454414544245443454444544545446454474544845449454504545145452454534545445455454564545745458454594546045461454624546345464454654546645467454684546945470454714547245473454744547545476454774547845479454804548145482454834548445485454864548745488454894549045491454924549345494454954549645497454984549945500455014550245503455044550545506455074550845509455104551145512455134551445515455164551745518455194552045521455224552345524455254552645527455284552945530455314553245533455344553545536455374553845539455404554145542455434554445545455464554745548455494555045551455524555345554455554555645557455584555945560455614556245563455644556545566455674556845569455704557145572455734557445575455764557745578455794558045581455824558345584455854558645587455884558945590455914559245593455944559545596455974559845599456004560145602456034560445605456064560745608456094561045611456124561345614456154561645617456184561945620456214562245623456244562545626456274562845629456304563145632456334563445635456364563745638456394564045641456424564345644456454564645647456484564945650456514565245653456544565545656456574565845659456604566145662456634566445665456664566745668456694567045671456724567345674456754567645677456784567945680456814568245683456844568545686456874568845689456904569145692456934569445695456964569745698456994570045701457024570345704457054570645707457084570945710457114571245713457144571545716457174571845719457204572145722457234572445725457264572745728457294573045731457324573345734457354573645737457384573945740457414574245743457444574545746457474574845749457504575145752457534575445755457564575745758457594576045761457624576345764457654576645767457684576945770457714577245773457744577545776457774577845779457804578145782457834578445785457864578745788457894579045791457924579345794457954579645797457984579945800458014580245803458044580545806458074580845809458104581145812458134581445815458164581745818458194582045821458224582345824458254582645827458284582945830458314583245833458344583545836458374583845839458404584145842458434584445845458464584745848458494585045851458524585345854458554585645857458584585945860458614586245863458644586545866458674586845869458704587145872458734587445875458764587745878458794588045881458824588345884458854588645887458884588945890458914589245893458944589545896458974589845899459004590145902459034590445905459064590745908459094591045911459124591345914459154591645917459184591945920459214592245923459244592545926459274592845929 | 
							- /**
 
-  * @licstart The following is the entire license notice for the
 
-  * Javascript code in this page
 
-  *
 
-  * Copyright 2020 Mozilla Foundation
 
-  *
 
-  * Licensed under the Apache License, Version 2.0 (the "License");
 
-  * you may not use this file except in compliance with the License.
 
-  * You may obtain a copy of the License at
 
-  *
 
-  *     http://www.apache.org/licenses/LICENSE-2.0
 
-  *
 
-  * Unless required by applicable law or agreed to in writing, software
 
-  * distributed under the License is distributed on an "AS IS" BASIS,
 
-  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-  * See the License for the specific language governing permissions and
 
-  * limitations under the License.
 
-  *
 
-  * @licend The above is the entire license notice for the
 
-  * Javascript code in this page
 
-  */
 
- (function webpackUniversalModuleDefinition(root, factory) {
 
- 	if(typeof exports === 'object' && typeof module === 'object')
 
- 		module.exports = factory();
 
- 	else if(typeof define === 'function' && define.amd)
 
- 		define("pdfjs-dist/build/pdf.worker", [], factory);
 
- 	else if(typeof exports === 'object')
 
- 		exports["pdfjs-dist/build/pdf.worker"] = factory();
 
- 	else
 
- 		root["pdfjs-dist/build/pdf.worker"] = root.pdfjsWorker = factory();
 
- })(this, function() {
 
- return /******/ (function(modules) { // webpackBootstrap
 
- /******/ 	// The module cache
 
- /******/ 	var installedModules = {};
 
- /******/
 
- /******/ 	// The require function
 
- /******/ 	function __w_pdfjs_require__(moduleId) {
 
- /******/
 
- /******/ 		// Check if module is in cache
 
- /******/ 		if(installedModules[moduleId]) {
 
- /******/ 			return installedModules[moduleId].exports;
 
- /******/ 		}
 
- /******/ 		// Create a new module (and put it into the cache)
 
- /******/ 		var module = installedModules[moduleId] = {
 
- /******/ 			i: moduleId,
 
- /******/ 			l: false,
 
- /******/ 			exports: {}
 
- /******/ 		};
 
- /******/
 
- /******/ 		// Execute the module function
 
- /******/ 		modules[moduleId].call(module.exports, module, module.exports, __w_pdfjs_require__);
 
- /******/
 
- /******/ 		// Flag the module as loaded
 
- /******/ 		module.l = true;
 
- /******/
 
- /******/ 		// Return the exports of the module
 
- /******/ 		return module.exports;
 
- /******/ 	}
 
- /******/
 
- /******/
 
- /******/ 	// expose the modules object (__webpack_modules__)
 
- /******/ 	__w_pdfjs_require__.m = modules;
 
- /******/
 
- /******/ 	// expose the module cache
 
- /******/ 	__w_pdfjs_require__.c = installedModules;
 
- /******/
 
- /******/ 	// define getter function for harmony exports
 
- /******/ 	__w_pdfjs_require__.d = function(exports, name, getter) {
 
- /******/ 		if(!__w_pdfjs_require__.o(exports, name)) {
 
- /******/ 			Object.defineProperty(exports, name, { enumerable: true, get: getter });
 
- /******/ 		}
 
- /******/ 	};
 
- /******/
 
- /******/ 	// define __esModule on exports
 
- /******/ 	__w_pdfjs_require__.r = function(exports) {
 
- /******/ 		if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
 
- /******/ 			Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 
- /******/ 		}
 
- /******/ 		Object.defineProperty(exports, '__esModule', { value: true });
 
- /******/ 	};
 
- /******/
 
- /******/ 	// create a fake namespace object
 
- /******/ 	// mode & 1: value is a module id, require it
 
- /******/ 	// mode & 2: merge all properties of value into the ns
 
- /******/ 	// mode & 4: return value when already ns object
 
- /******/ 	// mode & 8|1: behave like require
 
- /******/ 	__w_pdfjs_require__.t = function(value, mode) {
 
- /******/ 		if(mode & 1) value = __w_pdfjs_require__(value);
 
- /******/ 		if(mode & 8) return value;
 
- /******/ 		if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
 
- /******/ 		var ns = Object.create(null);
 
- /******/ 		__w_pdfjs_require__.r(ns);
 
- /******/ 		Object.defineProperty(ns, 'default', { enumerable: true, value: value });
 
- /******/ 		if(mode & 2 && typeof value != 'string') for(var key in value) __w_pdfjs_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
 
- /******/ 		return ns;
 
- /******/ 	};
 
- /******/
 
- /******/ 	// getDefaultExport function for compatibility with non-harmony modules
 
- /******/ 	__w_pdfjs_require__.n = function(module) {
 
- /******/ 		var getter = module && module.__esModule ?
 
- /******/ 			function getDefault() { return module['default']; } :
 
- /******/ 			function getModuleExports() { return module; };
 
- /******/ 		__w_pdfjs_require__.d(getter, 'a', getter);
 
- /******/ 		return getter;
 
- /******/ 	};
 
- /******/
 
- /******/ 	// Object.prototype.hasOwnProperty.call
 
- /******/ 	__w_pdfjs_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
 
- /******/
 
- /******/ 	// __webpack_public_path__
 
- /******/ 	__w_pdfjs_require__.p = "";
 
- /******/
 
- /******/
 
- /******/ 	// Load entry module and return exports
 
- /******/ 	return __w_pdfjs_require__(__w_pdfjs_require__.s = 0);
 
- /******/ })
 
- /************************************************************************/
 
- /******/ ([
 
- /* 0 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- const pdfjsVersion = '2.4.456';
 
- const pdfjsBuild = '228a591c';
 
- const pdfjsCoreWorker = __w_pdfjs_require__(1);
 
- exports.WorkerMessageHandler = pdfjsCoreWorker.WorkerMessageHandler;
 
- /***/ }),
 
- /* 1 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.WorkerMessageHandler = exports.WorkerTask = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _pdf_manager = __w_pdfjs_require__(5);
 
- var _is_node = __w_pdfjs_require__(44);
 
- var _message_handler = __w_pdfjs_require__(45);
 
- var _worker_stream = __w_pdfjs_require__(46);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var WorkerTask = function WorkerTaskClosure() {
 
-   function WorkerTask(name) {
 
-     this.name = name;
 
-     this.terminated = false;
 
-     this._capability = (0, _util.createPromiseCapability)();
 
-   }
 
-   WorkerTask.prototype = {
 
-     get finished() {
 
-       return this._capability.promise;
 
-     },
 
-     finish() {
 
-       this._capability.resolve();
 
-     },
 
-     terminate() {
 
-       this.terminated = true;
 
-     },
 
-     ensureNotTerminated() {
 
-       if (this.terminated) {
 
-         throw new Error("Worker task was terminated");
 
-       }
 
-     }
 
-   };
 
-   return WorkerTask;
 
- }();
 
- exports.WorkerTask = WorkerTask;
 
- var WorkerMessageHandler = {
 
-   setup(handler, port) {
 
-     var testMessageProcessed = false;
 
-     handler.on("test", function wphSetupTest(data) {
 
-       if (testMessageProcessed) {
 
-         return;
 
-       }
 
-       testMessageProcessed = true;
 
-       if (!(data instanceof Uint8Array)) {
 
-         handler.send("test", null);
 
-         return;
 
-       }
 
-       const supportTransfers = data[0] === 255;
 
-       handler.postMessageTransfers = supportTransfers;
 
-       handler.send("test", {
 
-         supportTransfers
 
-       });
 
-     });
 
-     handler.on("configure", function wphConfigure(data) {
 
-       (0, _util.setVerbosityLevel)(data.verbosity);
 
-     });
 
-     handler.on("GetDocRequest", function wphSetupDoc(data) {
 
-       return WorkerMessageHandler.createDocumentHandler(data, port);
 
-     });
 
-   },
 
-   createDocumentHandler(docParams, port) {
 
-     var pdfManager;
 
-     var terminated = false;
 
-     var cancelXHRs = null;
 
-     var WorkerTasks = [];
 
-     const verbosity = (0, _util.getVerbosityLevel)();
 
-     const apiVersion = docParams.apiVersion;
 
-     const workerVersion = '2.4.456';
 
-     if (apiVersion !== workerVersion) {
 
-       throw new Error(`The API version "${apiVersion}" does not match ` + `the Worker version "${workerVersion}".`);
 
-     }
 
-     const enumerableProperties = [];
 
-     for (const property in []) {
 
-       enumerableProperties.push(property);
 
-     }
 
-     if (enumerableProperties.length) {
 
-       throw new Error("The `Array.prototype` contains unexpected enumerable properties: " + enumerableProperties.join(", ") + "; thus breaking e.g. `for...in` iteration of `Array`s.");
 
-     }
 
-     var docId = docParams.docId;
 
-     var docBaseUrl = docParams.docBaseUrl;
 
-     var workerHandlerName = docParams.docId + "_worker";
 
-     var handler = new _message_handler.MessageHandler(workerHandlerName, docId, port);
 
-     handler.postMessageTransfers = docParams.postMessageTransfers;
 
-     function ensureNotTerminated() {
 
-       if (terminated) {
 
-         throw new Error("Worker was terminated");
 
-       }
 
-     }
 
-     function startWorkerTask(task) {
 
-       WorkerTasks.push(task);
 
-     }
 
-     function finishWorkerTask(task) {
 
-       task.finish();
 
-       var i = WorkerTasks.indexOf(task);
 
-       WorkerTasks.splice(i, 1);
 
-     }
 
-     async function loadDocument(recoveryMode) {
 
-       await pdfManager.ensureDoc("checkHeader");
 
-       await pdfManager.ensureDoc("parseStartXRef");
 
-       await pdfManager.ensureDoc("parse", [recoveryMode]);
 
-       if (!recoveryMode) {
 
-         await pdfManager.ensureDoc("checkFirstPage");
 
-       }
 
-       const [numPages, fingerprint] = await Promise.all([pdfManager.ensureDoc("numPages"), pdfManager.ensureDoc("fingerprint")]);
 
-       return {
 
-         numPages,
 
-         fingerprint
 
-       };
 
-     }
 
-     function getPdfManager(data, evaluatorOptions) {
 
-       var pdfManagerCapability = (0, _util.createPromiseCapability)();
 
-       var pdfManager;
 
-       var source = data.source;
 
-       if (source.data) {
 
-         try {
 
-           pdfManager = new _pdf_manager.LocalPdfManager(docId, source.data, source.password, evaluatorOptions, docBaseUrl);
 
-           pdfManagerCapability.resolve(pdfManager);
 
-         } catch (ex) {
 
-           pdfManagerCapability.reject(ex);
 
-         }
 
-         return pdfManagerCapability.promise;
 
-       }
 
-       var pdfStream,
 
-           cachedChunks = [];
 
-       try {
 
-         pdfStream = new _worker_stream.PDFWorkerStream(handler);
 
-       } catch (ex) {
 
-         pdfManagerCapability.reject(ex);
 
-         return pdfManagerCapability.promise;
 
-       }
 
-       var fullRequest = pdfStream.getFullReader();
 
-       fullRequest.headersReady.then(function () {
 
-         if (!fullRequest.isRangeSupported) {
 
-           return;
 
-         }
 
-         var disableAutoFetch = source.disableAutoFetch || fullRequest.isStreamingSupported;
 
-         pdfManager = new _pdf_manager.NetworkPdfManager(docId, pdfStream, {
 
-           msgHandler: handler,
 
-           password: source.password,
 
-           length: fullRequest.contentLength,
 
-           disableAutoFetch,
 
-           rangeChunkSize: source.rangeChunkSize
 
-         }, evaluatorOptions, docBaseUrl);
 
-         for (let i = 0; i < cachedChunks.length; i++) {
 
-           pdfManager.sendProgressiveData(cachedChunks[i]);
 
-         }
 
-         cachedChunks = [];
 
-         pdfManagerCapability.resolve(pdfManager);
 
-         cancelXHRs = null;
 
-       }).catch(function (reason) {
 
-         pdfManagerCapability.reject(reason);
 
-         cancelXHRs = null;
 
-       });
 
-       var loaded = 0;
 
-       var flushChunks = function () {
 
-         var pdfFile = (0, _util.arraysToBytes)(cachedChunks);
 
-         if (source.length && pdfFile.length !== source.length) {
 
-           (0, _util.warn)("reported HTTP length is different from actual");
 
-         }
 
-         try {
 
-           pdfManager = new _pdf_manager.LocalPdfManager(docId, pdfFile, source.password, evaluatorOptions, docBaseUrl);
 
-           pdfManagerCapability.resolve(pdfManager);
 
-         } catch (ex) {
 
-           pdfManagerCapability.reject(ex);
 
-         }
 
-         cachedChunks = [];
 
-       };
 
-       var readPromise = new Promise(function (resolve, reject) {
 
-         var readChunk = function (chunk) {
 
-           try {
 
-             ensureNotTerminated();
 
-             if (chunk.done) {
 
-               if (!pdfManager) {
 
-                 flushChunks();
 
-               }
 
-               cancelXHRs = null;
 
-               return;
 
-             }
 
-             var data = chunk.value;
 
-             loaded += (0, _util.arrayByteLength)(data);
 
-             if (!fullRequest.isStreamingSupported) {
 
-               handler.send("DocProgress", {
 
-                 loaded,
 
-                 total: Math.max(loaded, fullRequest.contentLength || 0)
 
-               });
 
-             }
 
-             if (pdfManager) {
 
-               pdfManager.sendProgressiveData(data);
 
-             } else {
 
-               cachedChunks.push(data);
 
-             }
 
-             fullRequest.read().then(readChunk, reject);
 
-           } catch (e) {
 
-             reject(e);
 
-           }
 
-         };
 
-         fullRequest.read().then(readChunk, reject);
 
-       });
 
-       readPromise.catch(function (e) {
 
-         pdfManagerCapability.reject(e);
 
-         cancelXHRs = null;
 
-       });
 
-       cancelXHRs = function (reason) {
 
-         pdfStream.cancelAllRequests(reason);
 
-       };
 
-       return pdfManagerCapability.promise;
 
-     }
 
-     function setupDoc(data) {
 
-       function onSuccess(doc) {
 
-         ensureNotTerminated();
 
-         handler.send("GetDoc", {
 
-           pdfInfo: doc
 
-         });
 
-       }
 
-       function onFailure(ex) {
 
-         ensureNotTerminated();
 
-         if (ex instanceof _util.PasswordException) {
 
-           var task = new WorkerTask(`PasswordException: response ${ex.code}`);
 
-           startWorkerTask(task);
 
-           handler.sendWithPromise("PasswordRequest", ex).then(function (data) {
 
-             finishWorkerTask(task);
 
-             pdfManager.updatePassword(data.password);
 
-             pdfManagerReady();
 
-           }).catch(function () {
 
-             finishWorkerTask(task);
 
-             handler.send("DocException", ex);
 
-           });
 
-         } else if (ex instanceof _util.InvalidPDFException || ex instanceof _util.MissingPDFException || ex instanceof _util.UnexpectedResponseException || ex instanceof _util.UnknownErrorException) {
 
-           handler.send("DocException", ex);
 
-         } else {
 
-           handler.send("DocException", new _util.UnknownErrorException(ex.message, ex.toString()));
 
-         }
 
-       }
 
-       function pdfManagerReady() {
 
-         ensureNotTerminated();
 
-         loadDocument(false).then(onSuccess, function loadFailure(ex) {
 
-           ensureNotTerminated();
 
-           if (!(ex instanceof _core_utils.XRefParseException)) {
 
-             onFailure(ex);
 
-             return;
 
-           }
 
-           pdfManager.requestLoadedStream();
 
-           pdfManager.onLoadedStream().then(function () {
 
-             ensureNotTerminated();
 
-             loadDocument(true).then(onSuccess, onFailure);
 
-           });
 
-         }, onFailure);
 
-       }
 
-       ensureNotTerminated();
 
-       var evaluatorOptions = {
 
-         forceDataSchema: data.disableCreateObjectURL,
 
-         maxImageSize: data.maxImageSize,
 
-         disableFontFace: data.disableFontFace,
 
-         nativeImageDecoderSupport: data.nativeImageDecoderSupport,
 
-         ignoreErrors: data.ignoreErrors,
 
-         isEvalSupported: data.isEvalSupported
 
-       };
 
-       getPdfManager(data, evaluatorOptions).then(function (newPdfManager) {
 
-         if (terminated) {
 
-           newPdfManager.terminate(new _util.AbortException("Worker was terminated."));
 
-           throw new Error("Worker was terminated");
 
-         }
 
-         pdfManager = newPdfManager;
 
-         pdfManager.onLoadedStream().then(function (stream) {
 
-           handler.send("DataLoaded", {
 
-             length: stream.bytes.byteLength
 
-           });
 
-         });
 
-       }).then(pdfManagerReady, onFailure);
 
-     }
 
-     handler.on("GetPage", function wphSetupGetPage(data) {
 
-       return pdfManager.getPage(data.pageIndex).then(function (page) {
 
-         return Promise.all([pdfManager.ensure(page, "rotate"), pdfManager.ensure(page, "ref"), pdfManager.ensure(page, "userUnit"), pdfManager.ensure(page, "view")]).then(function ([rotate, ref, userUnit, view]) {
 
-           return {
 
-             rotate,
 
-             ref,
 
-             userUnit,
 
-             view
 
-           };
 
-         });
 
-       });
 
-     });
 
-     handler.on("GetPageIndex", function wphSetupGetPageIndex(data) {
 
-       var ref = _primitives.Ref.get(data.ref.num, data.ref.gen);
 
-       var catalog = pdfManager.pdfDocument.catalog;
 
-       return catalog.getPageIndex(ref);
 
-     });
 
-     handler.on("GetDestinations", function wphSetupGetDestinations(data) {
 
-       return pdfManager.ensureCatalog("destinations");
 
-     });
 
-     handler.on("GetDestination", function wphSetupGetDestination(data) {
 
-       return pdfManager.ensureCatalog("getDestination", [data.id]);
 
-     });
 
-     handler.on("GetPageLabels", function wphSetupGetPageLabels(data) {
 
-       return pdfManager.ensureCatalog("pageLabels");
 
-     });
 
-     handler.on("GetPageLayout", function wphSetupGetPageLayout(data) {
 
-       return pdfManager.ensureCatalog("pageLayout");
 
-     });
 
-     handler.on("GetPageMode", function wphSetupGetPageMode(data) {
 
-       return pdfManager.ensureCatalog("pageMode");
 
-     });
 
-     handler.on("GetViewerPreferences", function (data) {
 
-       return pdfManager.ensureCatalog("viewerPreferences");
 
-     });
 
-     handler.on("GetOpenAction", function (data) {
 
-       return pdfManager.ensureCatalog("openAction");
 
-     });
 
-     handler.on("GetAttachments", function wphSetupGetAttachments(data) {
 
-       return pdfManager.ensureCatalog("attachments");
 
-     });
 
-     handler.on("GetJavaScript", function wphSetupGetJavaScript(data) {
 
-       return pdfManager.ensureCatalog("javaScript");
 
-     });
 
-     handler.on("GetOutline", function wphSetupGetOutline(data) {
 
-       return pdfManager.ensureCatalog("documentOutline");
 
-     });
 
-     handler.on("GetPermissions", function (data) {
 
-       return pdfManager.ensureCatalog("permissions");
 
-     });
 
-     handler.on("GetMetadata", function wphSetupGetMetadata(data) {
 
-       return Promise.all([pdfManager.ensureDoc("documentInfo"), pdfManager.ensureCatalog("metadata")]);
 
-     });
 
-     handler.on("GetData", function wphSetupGetData(data) {
 
-       pdfManager.requestLoadedStream();
 
-       return pdfManager.onLoadedStream().then(function (stream) {
 
-         return stream.bytes;
 
-       });
 
-     });
 
-     handler.on("GetStats", function wphSetupGetStats(data) {
 
-       return pdfManager.pdfDocument.xref.stats;
 
-     });
 
-     handler.on("GetAnnotations", function ({
 
-       pageIndex,
 
-       intent
 
-     }) {
 
-       return pdfManager.getPage(pageIndex).then(function (page) {
 
-         return page.getAnnotationsData(intent);
 
-       });
 
-     });
 
-     handler.on("GetOperatorList", function wphSetupRenderPage(data, sink) {
 
-       var pageIndex = data.pageIndex;
 
-       pdfManager.getPage(pageIndex).then(function (page) {
 
-         var task = new WorkerTask(`GetOperatorList: page ${pageIndex}`);
 
-         startWorkerTask(task);
 
-         const start = verbosity >= _util.VerbosityLevel.INFOS ? Date.now() : 0;
 
-         page.getOperatorList({
 
-           handler,
 
-           sink,
 
-           task,
 
-           intent: data.intent,
 
-           renderInteractiveForms: data.renderInteractiveForms
 
-         }).then(function (operatorListInfo) {
 
-           finishWorkerTask(task);
 
-           if (start) {
 
-             (0, _util.info)(`page=${pageIndex + 1} - getOperatorList: time=` + `${Date.now() - start}ms, len=${operatorListInfo.length}`);
 
-           }
 
-           sink.close();
 
-         }, function (reason) {
 
-           finishWorkerTask(task);
 
-           if (task.terminated) {
 
-             return;
 
-           }
 
-           handler.send("UnsupportedFeature", {
 
-             featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-           });
 
-           sink.error(reason);
 
-         });
 
-       });
 
-     }, this);
 
-     handler.on("GetTextContent", function wphExtractText(data, sink) {
 
-       var pageIndex = data.pageIndex;
 
-       sink.onPull = function (desiredSize) {};
 
-       sink.onCancel = function (reason) {};
 
-       pdfManager.getPage(pageIndex).then(function (page) {
 
-         var task = new WorkerTask("GetTextContent: page " + pageIndex);
 
-         startWorkerTask(task);
 
-         const start = verbosity >= _util.VerbosityLevel.INFOS ? Date.now() : 0;
 
-         page.extractTextContent({
 
-           handler,
 
-           task,
 
-           sink,
 
-           normalizeWhitespace: data.normalizeWhitespace,
 
-           combineTextItems: data.combineTextItems
 
-         }).then(function () {
 
-           finishWorkerTask(task);
 
-           if (start) {
 
-             (0, _util.info)(`page=${pageIndex + 1} - getTextContent: time=` + `${Date.now() - start}ms`);
 
-           }
 
-           sink.close();
 
-         }, function (reason) {
 
-           finishWorkerTask(task);
 
-           if (task.terminated) {
 
-             return;
 
-           }
 
-           sink.error(reason);
 
-         });
 
-       });
 
-     });
 
-     handler.on("FontFallback", function (data) {
 
-       return pdfManager.fontFallback(data.id, handler);
 
-     });
 
-     handler.on("Cleanup", function wphCleanup(data) {
 
-       return pdfManager.cleanup();
 
-     });
 
-     handler.on("Terminate", function wphTerminate(data) {
 
-       terminated = true;
 
-       const waitOn = [];
 
-       if (pdfManager) {
 
-         pdfManager.terminate(new _util.AbortException("Worker was terminated."));
 
-         const cleanupPromise = pdfManager.cleanup();
 
-         waitOn.push(cleanupPromise);
 
-         pdfManager = null;
 
-       } else {
 
-         (0, _primitives.clearPrimitiveCaches)();
 
-       }
 
-       if (cancelXHRs) {
 
-         cancelXHRs(new _util.AbortException("Worker was terminated."));
 
-       }
 
-       WorkerTasks.forEach(function (task) {
 
-         waitOn.push(task.finished);
 
-         task.terminate();
 
-       });
 
-       return Promise.all(waitOn).then(function () {
 
-         handler.destroy();
 
-         handler = null;
 
-       });
 
-     });
 
-     handler.on("Ready", function wphReady(data) {
 
-       setupDoc(docParams);
 
-       docParams = null;
 
-     });
 
-     return workerHandlerName;
 
-   },
 
-   initializeFromPort(port) {
 
-     var handler = new _message_handler.MessageHandler("worker", "main", port);
 
-     WorkerMessageHandler.setup(handler, port);
 
-     handler.send("ready", null);
 
-   }
 
- };
 
- exports.WorkerMessageHandler = WorkerMessageHandler;
 
- function isMessagePort(maybePort) {
 
-   return typeof maybePort.postMessage === "function" && "onmessage" in maybePort;
 
- }
 
- if (typeof window === "undefined" && !_is_node.isNodeJS && typeof self !== "undefined" && isMessagePort(self)) {
 
-   WorkerMessageHandler.initializeFromPort(self);
 
- }
 
- /***/ }),
 
- /* 2 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.arrayByteLength = arrayByteLength;
 
- exports.arraysToBytes = arraysToBytes;
 
- exports.assert = assert;
 
- exports.bytesToString = bytesToString;
 
- exports.createPromiseCapability = createPromiseCapability;
 
- exports.getVerbosityLevel = getVerbosityLevel;
 
- exports.info = info;
 
- exports.isArrayBuffer = isArrayBuffer;
 
- exports.isArrayEqual = isArrayEqual;
 
- exports.isBool = isBool;
 
- exports.isEmptyObj = isEmptyObj;
 
- exports.isNum = isNum;
 
- exports.isString = isString;
 
- exports.isSameOrigin = isSameOrigin;
 
- exports.createValidAbsoluteUrl = createValidAbsoluteUrl;
 
- exports.removeNullCharacters = removeNullCharacters;
 
- exports.setVerbosityLevel = setVerbosityLevel;
 
- exports.shadow = shadow;
 
- exports.string32 = string32;
 
- exports.stringToBytes = stringToBytes;
 
- exports.stringToPDFString = stringToPDFString;
 
- exports.stringToUTF8String = stringToUTF8String;
 
- exports.utf8StringToString = utf8StringToString;
 
- exports.warn = warn;
 
- exports.unreachable = unreachable;
 
- exports.IsEvalSupportedCached = exports.IsLittleEndianCached = exports.createObjectURL = exports.FormatError = exports.Util = exports.UnknownErrorException = exports.UnexpectedResponseException = exports.TextRenderingMode = exports.StreamType = exports.PermissionFlag = exports.PasswordResponses = exports.PasswordException = exports.NativeImageDecoding = exports.MissingPDFException = exports.InvalidPDFException = exports.AbortException = exports.CMapCompressionType = exports.ImageKind = exports.FontType = exports.AnnotationType = exports.AnnotationStateModelType = exports.AnnotationReviewState = exports.AnnotationReplyType = exports.AnnotationMarkedState = exports.AnnotationFlag = exports.AnnotationFieldFlag = exports.AnnotationBorderStyleType = exports.UNSUPPORTED_FEATURES = exports.VerbosityLevel = exports.OPS = exports.IDENTITY_MATRIX = exports.FONT_IDENTITY_MATRIX = exports.BaseException = void 0;
 
- __w_pdfjs_require__(3);
 
- const IDENTITY_MATRIX = [1, 0, 0, 1, 0, 0];
 
- exports.IDENTITY_MATRIX = IDENTITY_MATRIX;
 
- const FONT_IDENTITY_MATRIX = [0.001, 0, 0, 0.001, 0, 0];
 
- exports.FONT_IDENTITY_MATRIX = FONT_IDENTITY_MATRIX;
 
- const NativeImageDecoding = {
 
-   NONE: "none",
 
-   DECODE: "decode",
 
-   DISPLAY: "display"
 
- };
 
- exports.NativeImageDecoding = NativeImageDecoding;
 
- const PermissionFlag = {
 
-   PRINT: 0x04,
 
-   MODIFY_CONTENTS: 0x08,
 
-   COPY: 0x10,
 
-   MODIFY_ANNOTATIONS: 0x20,
 
-   FILL_INTERACTIVE_FORMS: 0x100,
 
-   COPY_FOR_ACCESSIBILITY: 0x200,
 
-   ASSEMBLE: 0x400,
 
-   PRINT_HIGH_QUALITY: 0x800
 
- };
 
- exports.PermissionFlag = PermissionFlag;
 
- const TextRenderingMode = {
 
-   FILL: 0,
 
-   STROKE: 1,
 
-   FILL_STROKE: 2,
 
-   INVISIBLE: 3,
 
-   FILL_ADD_TO_PATH: 4,
 
-   STROKE_ADD_TO_PATH: 5,
 
-   FILL_STROKE_ADD_TO_PATH: 6,
 
-   ADD_TO_PATH: 7,
 
-   FILL_STROKE_MASK: 3,
 
-   ADD_TO_PATH_FLAG: 4
 
- };
 
- exports.TextRenderingMode = TextRenderingMode;
 
- const ImageKind = {
 
-   GRAYSCALE_1BPP: 1,
 
-   RGB_24BPP: 2,
 
-   RGBA_32BPP: 3
 
- };
 
- exports.ImageKind = ImageKind;
 
- const AnnotationType = {
 
-   TEXT: 1,
 
-   LINK: 2,
 
-   FREETEXT: 3,
 
-   LINE: 4,
 
-   SQUARE: 5,
 
-   CIRCLE: 6,
 
-   POLYGON: 7,
 
-   POLYLINE: 8,
 
-   HIGHLIGHT: 9,
 
-   UNDERLINE: 10,
 
-   SQUIGGLY: 11,
 
-   STRIKEOUT: 12,
 
-   STAMP: 13,
 
-   CARET: 14,
 
-   INK: 15,
 
-   POPUP: 16,
 
-   FILEATTACHMENT: 17,
 
-   SOUND: 18,
 
-   MOVIE: 19,
 
-   WIDGET: 20,
 
-   SCREEN: 21,
 
-   PRINTERMARK: 22,
 
-   TRAPNET: 23,
 
-   WATERMARK: 24,
 
-   THREED: 25,
 
-   REDACT: 26
 
- };
 
- exports.AnnotationType = AnnotationType;
 
- const AnnotationStateModelType = {
 
-   MARKED: "Marked",
 
-   REVIEW: "Review"
 
- };
 
- exports.AnnotationStateModelType = AnnotationStateModelType;
 
- const AnnotationMarkedState = {
 
-   MARKED: "Marked",
 
-   UNMARKED: "Unmarked"
 
- };
 
- exports.AnnotationMarkedState = AnnotationMarkedState;
 
- const AnnotationReviewState = {
 
-   ACCEPTED: "Accepted",
 
-   REJECTED: "Rejected",
 
-   CANCELLED: "Cancelled",
 
-   COMPLETED: "Completed",
 
-   NONE: "None"
 
- };
 
- exports.AnnotationReviewState = AnnotationReviewState;
 
- const AnnotationReplyType = {
 
-   GROUP: "Group",
 
-   REPLY: "R"
 
- };
 
- exports.AnnotationReplyType = AnnotationReplyType;
 
- const AnnotationFlag = {
 
-   INVISIBLE: 0x01,
 
-   HIDDEN: 0x02,
 
-   PRINT: 0x04,
 
-   NOZOOM: 0x08,
 
-   NOROTATE: 0x10,
 
-   NOVIEW: 0x20,
 
-   READONLY: 0x40,
 
-   LOCKED: 0x80,
 
-   TOGGLENOVIEW: 0x100,
 
-   LOCKEDCONTENTS: 0x200
 
- };
 
- exports.AnnotationFlag = AnnotationFlag;
 
- const AnnotationFieldFlag = {
 
-   READONLY: 0x0000001,
 
-   REQUIRED: 0x0000002,
 
-   NOEXPORT: 0x0000004,
 
-   MULTILINE: 0x0001000,
 
-   PASSWORD: 0x0002000,
 
-   NOTOGGLETOOFF: 0x0004000,
 
-   RADIO: 0x0008000,
 
-   PUSHBUTTON: 0x0010000,
 
-   COMBO: 0x0020000,
 
-   EDIT: 0x0040000,
 
-   SORT: 0x0080000,
 
-   FILESELECT: 0x0100000,
 
-   MULTISELECT: 0x0200000,
 
-   DONOTSPELLCHECK: 0x0400000,
 
-   DONOTSCROLL: 0x0800000,
 
-   COMB: 0x1000000,
 
-   RICHTEXT: 0x2000000,
 
-   RADIOSINUNISON: 0x2000000,
 
-   COMMITONSELCHANGE: 0x4000000
 
- };
 
- exports.AnnotationFieldFlag = AnnotationFieldFlag;
 
- const AnnotationBorderStyleType = {
 
-   SOLID: 1,
 
-   DASHED: 2,
 
-   BEVELED: 3,
 
-   INSET: 4,
 
-   UNDERLINE: 5
 
- };
 
- exports.AnnotationBorderStyleType = AnnotationBorderStyleType;
 
- const StreamType = {
 
-   UNKNOWN: "UNKNOWN",
 
-   FLATE: "FLATE",
 
-   LZW: "LZW",
 
-   DCT: "DCT",
 
-   JPX: "JPX",
 
-   JBIG: "JBIG",
 
-   A85: "A85",
 
-   AHX: "AHX",
 
-   CCF: "CCF",
 
-   RLX: "RLX"
 
- };
 
- exports.StreamType = StreamType;
 
- const FontType = {
 
-   UNKNOWN: "UNKNOWN",
 
-   TYPE1: "TYPE1",
 
-   TYPE1C: "TYPE1C",
 
-   CIDFONTTYPE0: "CIDFONTTYPE0",
 
-   CIDFONTTYPE0C: "CIDFONTTYPE0C",
 
-   TRUETYPE: "TRUETYPE",
 
-   CIDFONTTYPE2: "CIDFONTTYPE2",
 
-   TYPE3: "TYPE3",
 
-   OPENTYPE: "OPENTYPE",
 
-   TYPE0: "TYPE0",
 
-   MMTYPE1: "MMTYPE1"
 
- };
 
- exports.FontType = FontType;
 
- const VerbosityLevel = {
 
-   ERRORS: 0,
 
-   WARNINGS: 1,
 
-   INFOS: 5
 
- };
 
- exports.VerbosityLevel = VerbosityLevel;
 
- const CMapCompressionType = {
 
-   NONE: 0,
 
-   BINARY: 1,
 
-   STREAM: 2
 
- };
 
- exports.CMapCompressionType = CMapCompressionType;
 
- const OPS = {
 
-   dependency: 1,
 
-   setLineWidth: 2,
 
-   setLineCap: 3,
 
-   setLineJoin: 4,
 
-   setMiterLimit: 5,
 
-   setDash: 6,
 
-   setRenderingIntent: 7,
 
-   setFlatness: 8,
 
-   setGState: 9,
 
-   save: 10,
 
-   restore: 11,
 
-   transform: 12,
 
-   moveTo: 13,
 
-   lineTo: 14,
 
-   curveTo: 15,
 
-   curveTo2: 16,
 
-   curveTo3: 17,
 
-   closePath: 18,
 
-   rectangle: 19,
 
-   stroke: 20,
 
-   closeStroke: 21,
 
-   fill: 22,
 
-   eoFill: 23,
 
-   fillStroke: 24,
 
-   eoFillStroke: 25,
 
-   closeFillStroke: 26,
 
-   closeEOFillStroke: 27,
 
-   endPath: 28,
 
-   clip: 29,
 
-   eoClip: 30,
 
-   beginText: 31,
 
-   endText: 32,
 
-   setCharSpacing: 33,
 
-   setWordSpacing: 34,
 
-   setHScale: 35,
 
-   setLeading: 36,
 
-   setFont: 37,
 
-   setTextRenderingMode: 38,
 
-   setTextRise: 39,
 
-   moveText: 40,
 
-   setLeadingMoveText: 41,
 
-   setTextMatrix: 42,
 
-   nextLine: 43,
 
-   showText: 44,
 
-   showSpacedText: 45,
 
-   nextLineShowText: 46,
 
-   nextLineSetSpacingShowText: 47,
 
-   setCharWidth: 48,
 
-   setCharWidthAndBounds: 49,
 
-   setStrokeColorSpace: 50,
 
-   setFillColorSpace: 51,
 
-   setStrokeColor: 52,
 
-   setStrokeColorN: 53,
 
-   setFillColor: 54,
 
-   setFillColorN: 55,
 
-   setStrokeGray: 56,
 
-   setFillGray: 57,
 
-   setStrokeRGBColor: 58,
 
-   setFillRGBColor: 59,
 
-   setStrokeCMYKColor: 60,
 
-   setFillCMYKColor: 61,
 
-   shadingFill: 62,
 
-   beginInlineImage: 63,
 
-   beginImageData: 64,
 
-   endInlineImage: 65,
 
-   paintXObject: 66,
 
-   markPoint: 67,
 
-   markPointProps: 68,
 
-   beginMarkedContent: 69,
 
-   beginMarkedContentProps: 70,
 
-   endMarkedContent: 71,
 
-   beginCompat: 72,
 
-   endCompat: 73,
 
-   paintFormXObjectBegin: 74,
 
-   paintFormXObjectEnd: 75,
 
-   beginGroup: 76,
 
-   endGroup: 77,
 
-   beginAnnotations: 78,
 
-   endAnnotations: 79,
 
-   beginAnnotation: 80,
 
-   endAnnotation: 81,
 
-   paintJpegXObject: 82,
 
-   paintImageMaskXObject: 83,
 
-   paintImageMaskXObjectGroup: 84,
 
-   paintImageXObject: 85,
 
-   paintInlineImageXObject: 86,
 
-   paintInlineImageXObjectGroup: 87,
 
-   paintImageXObjectRepeat: 88,
 
-   paintImageMaskXObjectRepeat: 89,
 
-   paintSolidColorImageMask: 90,
 
-   constructPath: 91
 
- };
 
- exports.OPS = OPS;
 
- const UNSUPPORTED_FEATURES = {
 
-   unknown: "unknown",
 
-   forms: "forms",
 
-   javaScript: "javaScript",
 
-   smask: "smask",
 
-   shadingPattern: "shadingPattern",
 
-   font: "font"
 
- };
 
- exports.UNSUPPORTED_FEATURES = UNSUPPORTED_FEATURES;
 
- const PasswordResponses = {
 
-   NEED_PASSWORD: 1,
 
-   INCORRECT_PASSWORD: 2
 
- };
 
- exports.PasswordResponses = PasswordResponses;
 
- let verbosity = VerbosityLevel.WARNINGS;
 
- function setVerbosityLevel(level) {
 
-   if (Number.isInteger(level)) {
 
-     verbosity = level;
 
-   }
 
- }
 
- function getVerbosityLevel() {
 
-   return verbosity;
 
- }
 
- function info(msg) {
 
-   if (verbosity >= VerbosityLevel.INFOS) {
 
-     console.log(`Info: ${msg}`);
 
-   }
 
- }
 
- function warn(msg) {
 
-   if (verbosity >= VerbosityLevel.WARNINGS) {
 
-     console.log(`Warning: ${msg}`);
 
-   }
 
- }
 
- function unreachable(msg) {
 
-   throw new Error(msg);
 
- }
 
- function assert(cond, msg) {
 
-   if (!cond) {
 
-     unreachable(msg);
 
-   }
 
- }
 
- function isSameOrigin(baseUrl, otherUrl) {
 
-   let base;
 
-   try {
 
-     base = new URL(baseUrl);
 
-     if (!base.origin || base.origin === "null") {
 
-       return false;
 
-     }
 
-   } catch (e) {
 
-     return false;
 
-   }
 
-   const other = new URL(otherUrl, base);
 
-   return base.origin === other.origin;
 
- }
 
- function _isValidProtocol(url) {
 
-   if (!url) {
 
-     return false;
 
-   }
 
-   switch (url.protocol) {
 
-     case "http:":
 
-     case "https:":
 
-     case "ftp:":
 
-     case "mailto:":
 
-     case "tel:":
 
-       return true;
 
-     default:
 
-       return false;
 
-   }
 
- }
 
- function createValidAbsoluteUrl(url, baseUrl) {
 
-   if (!url) {
 
-     return null;
 
-   }
 
-   try {
 
-     const absoluteUrl = baseUrl ? new URL(url, baseUrl) : new URL(url);
 
-     if (_isValidProtocol(absoluteUrl)) {
 
-       return absoluteUrl;
 
-     }
 
-   } catch (ex) {}
 
-   return null;
 
- }
 
- function shadow(obj, prop, value) {
 
-   Object.defineProperty(obj, prop, {
 
-     value,
 
-     enumerable: true,
 
-     configurable: true,
 
-     writable: false
 
-   });
 
-   return value;
 
- }
 
- const BaseException = function BaseExceptionClosure() {
 
-   function BaseException(message) {
 
-     if (this.constructor === BaseException) {
 
-       unreachable("Cannot initialize BaseException.");
 
-     }
 
-     this.message = message;
 
-     this.name = this.constructor.name;
 
-   }
 
-   BaseException.prototype = new Error();
 
-   BaseException.constructor = BaseException;
 
-   return BaseException;
 
- }();
 
- exports.BaseException = BaseException;
 
- class PasswordException extends BaseException {
 
-   constructor(msg, code) {
 
-     super(msg);
 
-     this.code = code;
 
-   }
 
- }
 
- exports.PasswordException = PasswordException;
 
- class UnknownErrorException extends BaseException {
 
-   constructor(msg, details) {
 
-     super(msg);
 
-     this.details = details;
 
-   }
 
- }
 
- exports.UnknownErrorException = UnknownErrorException;
 
- class InvalidPDFException extends BaseException {}
 
- exports.InvalidPDFException = InvalidPDFException;
 
- class MissingPDFException extends BaseException {}
 
- exports.MissingPDFException = MissingPDFException;
 
- class UnexpectedResponseException extends BaseException {
 
-   constructor(msg, status) {
 
-     super(msg);
 
-     this.status = status;
 
-   }
 
- }
 
- exports.UnexpectedResponseException = UnexpectedResponseException;
 
- class FormatError extends BaseException {}
 
- exports.FormatError = FormatError;
 
- class AbortException extends BaseException {}
 
- exports.AbortException = AbortException;
 
- const NullCharactersRegExp = /\x00/g;
 
- function removeNullCharacters(str) {
 
-   if (typeof str !== "string") {
 
-     warn("The argument for removeNullCharacters must be a string.");
 
-     return str;
 
-   }
 
-   return str.replace(NullCharactersRegExp, "");
 
- }
 
- function bytesToString(bytes) {
 
-   assert(bytes !== null && typeof bytes === "object" && bytes.length !== undefined, "Invalid argument for bytesToString");
 
-   const length = bytes.length;
 
-   const MAX_ARGUMENT_COUNT = 8192;
 
-   if (length < MAX_ARGUMENT_COUNT) {
 
-     return String.fromCharCode.apply(null, bytes);
 
-   }
 
-   const strBuf = [];
 
-   for (let i = 0; i < length; i += MAX_ARGUMENT_COUNT) {
 
-     const chunkEnd = Math.min(i + MAX_ARGUMENT_COUNT, length);
 
-     const chunk = bytes.subarray(i, chunkEnd);
 
-     strBuf.push(String.fromCharCode.apply(null, chunk));
 
-   }
 
-   return strBuf.join("");
 
- }
 
- function stringToBytes(str) {
 
-   assert(typeof str === "string", "Invalid argument for stringToBytes");
 
-   const length = str.length;
 
-   const bytes = new Uint8Array(length);
 
-   for (let i = 0; i < length; ++i) {
 
-     bytes[i] = str.charCodeAt(i) & 0xff;
 
-   }
 
-   return bytes;
 
- }
 
- function arrayByteLength(arr) {
 
-   if (arr.length !== undefined) {
 
-     return arr.length;
 
-   }
 
-   assert(arr.byteLength !== undefined);
 
-   return arr.byteLength;
 
- }
 
- function arraysToBytes(arr) {
 
-   const length = arr.length;
 
-   if (length === 1 && arr[0] instanceof Uint8Array) {
 
-     return arr[0];
 
-   }
 
-   let resultLength = 0;
 
-   for (let i = 0; i < length; i++) {
 
-     resultLength += arrayByteLength(arr[i]);
 
-   }
 
-   let pos = 0;
 
-   const data = new Uint8Array(resultLength);
 
-   for (let i = 0; i < length; i++) {
 
-     let item = arr[i];
 
-     if (!(item instanceof Uint8Array)) {
 
-       if (typeof item === "string") {
 
-         item = stringToBytes(item);
 
-       } else {
 
-         item = new Uint8Array(item);
 
-       }
 
-     }
 
-     const itemLength = item.byteLength;
 
-     data.set(item, pos);
 
-     pos += itemLength;
 
-   }
 
-   return data;
 
- }
 
- function string32(value) {
 
-   return String.fromCharCode(value >> 24 & 0xff, value >> 16 & 0xff, value >> 8 & 0xff, value & 0xff);
 
- }
 
- function isLittleEndian() {
 
-   const buffer8 = new Uint8Array(4);
 
-   buffer8[0] = 1;
 
-   const view32 = new Uint32Array(buffer8.buffer, 0, 1);
 
-   return view32[0] === 1;
 
- }
 
- const IsLittleEndianCached = {
 
-   get value() {
 
-     return shadow(this, "value", isLittleEndian());
 
-   }
 
- };
 
- exports.IsLittleEndianCached = IsLittleEndianCached;
 
- function isEvalSupported() {
 
-   try {
 
-     new Function("");
 
-     return true;
 
-   } catch (e) {
 
-     return false;
 
-   }
 
- }
 
- const IsEvalSupportedCached = {
 
-   get value() {
 
-     return shadow(this, "value", isEvalSupported());
 
-   }
 
- };
 
- exports.IsEvalSupportedCached = IsEvalSupportedCached;
 
- const rgbBuf = ["rgb(", 0, ",", 0, ",", 0, ")"];
 
- class Util {
 
-   static makeCssRgb(r, g, b) {
 
-     rgbBuf[1] = r;
 
-     rgbBuf[3] = g;
 
-     rgbBuf[5] = b;
 
-     return rgbBuf.join("");
 
-   }
 
-   static transform(m1, m2) {
 
-     return [m1[0] * m2[0] + m1[2] * m2[1], m1[1] * m2[0] + m1[3] * m2[1], m1[0] * m2[2] + m1[2] * m2[3], m1[1] * m2[2] + m1[3] * m2[3], m1[0] * m2[4] + m1[2] * m2[5] + m1[4], m1[1] * m2[4] + m1[3] * m2[5] + m1[5]];
 
-   }
 
-   static applyTransform(p, m) {
 
-     const xt = p[0] * m[0] + p[1] * m[2] + m[4];
 
-     const yt = p[0] * m[1] + p[1] * m[3] + m[5];
 
-     return [xt, yt];
 
-   }
 
-   static applyInverseTransform(p, m) {
 
-     const d = m[0] * m[3] - m[1] * m[2];
 
-     const xt = (p[0] * m[3] - p[1] * m[2] + m[2] * m[5] - m[4] * m[3]) / d;
 
-     const yt = (-p[0] * m[1] + p[1] * m[0] + m[4] * m[1] - m[5] * m[0]) / d;
 
-     return [xt, yt];
 
-   }
 
-   static getAxialAlignedBoundingBox(r, m) {
 
-     const p1 = Util.applyTransform(r, m);
 
-     const p2 = Util.applyTransform(r.slice(2, 4), m);
 
-     const p3 = Util.applyTransform([r[0], r[3]], m);
 
-     const p4 = Util.applyTransform([r[2], r[1]], m);
 
-     return [Math.min(p1[0], p2[0], p3[0], p4[0]), Math.min(p1[1], p2[1], p3[1], p4[1]), Math.max(p1[0], p2[0], p3[0], p4[0]), Math.max(p1[1], p2[1], p3[1], p4[1])];
 
-   }
 
-   static inverseTransform(m) {
 
-     const d = m[0] * m[3] - m[1] * m[2];
 
-     return [m[3] / d, -m[1] / d, -m[2] / d, m[0] / d, (m[2] * m[5] - m[4] * m[3]) / d, (m[4] * m[1] - m[5] * m[0]) / d];
 
-   }
 
-   static apply3dTransform(m, v) {
 
-     return [m[0] * v[0] + m[1] * v[1] + m[2] * v[2], m[3] * v[0] + m[4] * v[1] + m[5] * v[2], m[6] * v[0] + m[7] * v[1] + m[8] * v[2]];
 
-   }
 
-   static singularValueDecompose2dScale(m) {
 
-     const transpose = [m[0], m[2], m[1], m[3]];
 
-     const a = m[0] * transpose[0] + m[1] * transpose[2];
 
-     const b = m[0] * transpose[1] + m[1] * transpose[3];
 
-     const c = m[2] * transpose[0] + m[3] * transpose[2];
 
-     const d = m[2] * transpose[1] + m[3] * transpose[3];
 
-     const first = (a + d) / 2;
 
-     const second = Math.sqrt((a + d) * (a + d) - 4 * (a * d - c * b)) / 2;
 
-     const sx = first + second || 1;
 
-     const sy = first - second || 1;
 
-     return [Math.sqrt(sx), Math.sqrt(sy)];
 
-   }
 
-   static normalizeRect(rect) {
 
-     const r = rect.slice(0);
 
-     if (rect[0] > rect[2]) {
 
-       r[0] = rect[2];
 
-       r[2] = rect[0];
 
-     }
 
-     if (rect[1] > rect[3]) {
 
-       r[1] = rect[3];
 
-       r[3] = rect[1];
 
-     }
 
-     return r;
 
-   }
 
-   static intersect(rect1, rect2) {
 
-     function compare(a, b) {
 
-       return a - b;
 
-     }
 
-     const orderedX = [rect1[0], rect1[2], rect2[0], rect2[2]].sort(compare);
 
-     const orderedY = [rect1[1], rect1[3], rect2[1], rect2[3]].sort(compare);
 
-     const result = [];
 
-     rect1 = Util.normalizeRect(rect1);
 
-     rect2 = Util.normalizeRect(rect2);
 
-     if (orderedX[0] === rect1[0] && orderedX[1] === rect2[0] || orderedX[0] === rect2[0] && orderedX[1] === rect1[0]) {
 
-       result[0] = orderedX[1];
 
-       result[2] = orderedX[2];
 
-     } else {
 
-       return null;
 
-     }
 
-     if (orderedY[0] === rect1[1] && orderedY[1] === rect2[1] || orderedY[0] === rect2[1] && orderedY[1] === rect1[1]) {
 
-       result[1] = orderedY[1];
 
-       result[3] = orderedY[2];
 
-     } else {
 
-       return null;
 
-     }
 
-     return result;
 
-   }
 
- }
 
- exports.Util = Util;
 
- const PDFStringTranslateTable = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x2D8, 0x2C7, 0x2C6, 0x2D9, 0x2DD, 0x2DB, 0x2DA, 0x2DC, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x2022, 0x2020, 0x2021, 0x2026, 0x2014, 0x2013, 0x192, 0x2044, 0x2039, 0x203A, 0x2212, 0x2030, 0x201E, 0x201C, 0x201D, 0x2018, 0x2019, 0x201A, 0x2122, 0xFB01, 0xFB02, 0x141, 0x152, 0x160, 0x178, 0x17D, 0x131, 0x142, 0x153, 0x161, 0x17E, 0, 0x20AC];
 
- function stringToPDFString(str) {
 
-   const length = str.length,
 
-         strBuf = [];
 
-   if (str[0] === "\xFE" && str[1] === "\xFF") {
 
-     for (let i = 2; i < length; i += 2) {
 
-       strBuf.push(String.fromCharCode(str.charCodeAt(i) << 8 | str.charCodeAt(i + 1)));
 
-     }
 
-   } else if (str[0] === "\xFF" && str[1] === "\xFE") {
 
-     for (let i = 2; i < length; i += 2) {
 
-       strBuf.push(String.fromCharCode(str.charCodeAt(i + 1) << 8 | str.charCodeAt(i)));
 
-     }
 
-   } else {
 
-     for (let i = 0; i < length; ++i) {
 
-       const code = PDFStringTranslateTable[str.charCodeAt(i)];
 
-       strBuf.push(code ? String.fromCharCode(code) : str.charAt(i));
 
-     }
 
-   }
 
-   return strBuf.join("");
 
- }
 
- function stringToUTF8String(str) {
 
-   return decodeURIComponent(escape(str));
 
- }
 
- function utf8StringToString(str) {
 
-   return unescape(encodeURIComponent(str));
 
- }
 
- function isEmptyObj(obj) {
 
-   for (const key in obj) {
 
-     return false;
 
-   }
 
-   return true;
 
- }
 
- function isBool(v) {
 
-   return typeof v === "boolean";
 
- }
 
- function isNum(v) {
 
-   return typeof v === "number";
 
- }
 
- function isString(v) {
 
-   return typeof v === "string";
 
- }
 
- function isArrayBuffer(v) {
 
-   return typeof v === "object" && v !== null && v.byteLength !== undefined;
 
- }
 
- function isArrayEqual(arr1, arr2) {
 
-   if (arr1.length !== arr2.length) {
 
-     return false;
 
-   }
 
-   return arr1.every(function (element, index) {
 
-     return element === arr2[index];
 
-   });
 
- }
 
- function createPromiseCapability() {
 
-   const capability = Object.create(null);
 
-   let isSettled = false;
 
-   Object.defineProperty(capability, "settled", {
 
-     get() {
 
-       return isSettled;
 
-     }
 
-   });
 
-   capability.promise = new Promise(function (resolve, reject) {
 
-     capability.resolve = function (data) {
 
-       isSettled = true;
 
-       resolve(data);
 
-     };
 
-     capability.reject = function (reason) {
 
-       isSettled = true;
 
-       reject(reason);
 
-     };
 
-   });
 
-   return capability;
 
- }
 
- const createObjectURL = function createObjectURLClosure() {
 
-   const digits = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
 
-   return function createObjectURL(data, contentType, forceDataSchema = false) {
 
-     if (!forceDataSchema && URL.createObjectURL) {
 
-       const blob = new Blob([data], {
 
-         type: contentType
 
-       });
 
-       return URL.createObjectURL(blob);
 
-     }
 
-     let buffer = `data:${contentType};base64,`;
 
-     for (let i = 0, ii = data.length; i < ii; i += 3) {
 
-       const b1 = data[i] & 0xff;
 
-       const b2 = data[i + 1] & 0xff;
 
-       const b3 = data[i + 2] & 0xff;
 
-       const d1 = b1 >> 2,
 
-             d2 = (b1 & 3) << 4 | b2 >> 4;
 
-       const d3 = i + 1 < ii ? (b2 & 0xf) << 2 | b3 >> 6 : 64;
 
-       const d4 = i + 2 < ii ? b3 & 0x3f : 64;
 
-       buffer += digits[d1] + digits[d2] + digits[d3] + digits[d4];
 
-     }
 
-     return buffer;
 
-   };
 
- }();
 
- exports.createObjectURL = createObjectURL;
 
- /***/ }),
 
- /* 3 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- ;
 
- /***/ }),
 
- /* 4 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.clearPrimitiveCaches = clearPrimitiveCaches;
 
- exports.isEOF = isEOF;
 
- exports.isCmd = isCmd;
 
- exports.isDict = isDict;
 
- exports.isName = isName;
 
- exports.isRef = isRef;
 
- exports.isRefsEqual = isRefsEqual;
 
- exports.isStream = isStream;
 
- exports.RefSetCache = exports.RefSet = exports.Ref = exports.Name = exports.Dict = exports.Cmd = exports.EOF = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var EOF = {};
 
- exports.EOF = EOF;
 
- var Name = function NameClosure() {
 
-   let nameCache = Object.create(null);
 
-   function Name(name) {
 
-     this.name = name;
 
-   }
 
-   Name.prototype = {};
 
-   Name.get = function Name_get(name) {
 
-     var nameValue = nameCache[name];
 
-     return nameValue ? nameValue : nameCache[name] = new Name(name);
 
-   };
 
-   Name._clearCache = function () {
 
-     nameCache = Object.create(null);
 
-   };
 
-   return Name;
 
- }();
 
- exports.Name = Name;
 
- var Cmd = function CmdClosure() {
 
-   let cmdCache = Object.create(null);
 
-   function Cmd(cmd) {
 
-     this.cmd = cmd;
 
-   }
 
-   Cmd.prototype = {};
 
-   Cmd.get = function Cmd_get(cmd) {
 
-     var cmdValue = cmdCache[cmd];
 
-     return cmdValue ? cmdValue : cmdCache[cmd] = new Cmd(cmd);
 
-   };
 
-   Cmd._clearCache = function () {
 
-     cmdCache = Object.create(null);
 
-   };
 
-   return Cmd;
 
- }();
 
- exports.Cmd = Cmd;
 
- var Dict = function DictClosure() {
 
-   var nonSerializable = function nonSerializableClosure() {
 
-     return nonSerializable;
 
-   };
 
-   function Dict(xref) {
 
-     this._map = Object.create(null);
 
-     this.xref = xref;
 
-     this.objId = null;
 
-     this.suppressEncryption = false;
 
-     this.__nonSerializable__ = nonSerializable;
 
-   }
 
-   Dict.prototype = {
 
-     assignXref: function Dict_assignXref(newXref) {
 
-       this.xref = newXref;
 
-     },
 
-     get(key1, key2, key3) {
 
-       let value = this._map[key1];
 
-       if (value === undefined && key2 !== undefined) {
 
-         value = this._map[key2];
 
-         if (value === undefined && key3 !== undefined) {
 
-           value = this._map[key3];
 
-         }
 
-       }
 
-       if (value instanceof Ref && this.xref) {
 
-         return this.xref.fetch(value, this.suppressEncryption);
 
-       }
 
-       return value;
 
-     },
 
-     async getAsync(key1, key2, key3) {
 
-       let value = this._map[key1];
 
-       if (value === undefined && key2 !== undefined) {
 
-         value = this._map[key2];
 
-         if (value === undefined && key3 !== undefined) {
 
-           value = this._map[key3];
 
-         }
 
-       }
 
-       if (value instanceof Ref && this.xref) {
 
-         return this.xref.fetchAsync(value, this.suppressEncryption);
 
-       }
 
-       return value;
 
-     },
 
-     getArray(key1, key2, key3) {
 
-       let value = this.get(key1, key2, key3);
 
-       if (!Array.isArray(value) || !this.xref) {
 
-         return value;
 
-       }
 
-       value = value.slice();
 
-       for (let i = 0, ii = value.length; i < ii; i++) {
 
-         if (!(value[i] instanceof Ref)) {
 
-           continue;
 
-         }
 
-         value[i] = this.xref.fetch(value[i], this.suppressEncryption);
 
-       }
 
-       return value;
 
-     },
 
-     getRaw: function Dict_getRaw(key) {
 
-       return this._map[key];
 
-     },
 
-     getKeys: function Dict_getKeys() {
 
-       return Object.keys(this._map);
 
-     },
 
-     set: function Dict_set(key, value) {
 
-       this._map[key] = value;
 
-     },
 
-     has: function Dict_has(key) {
 
-       return this._map[key] !== undefined;
 
-     },
 
-     forEach: function Dict_forEach(callback) {
 
-       for (var key in this._map) {
 
-         callback(key, this.get(key));
 
-       }
 
-     }
 
-   };
 
-   Dict.empty = new Dict(null);
 
-   Dict.merge = function (xref, dictArray) {
 
-     const mergedDict = new Dict(xref);
 
-     for (let i = 0, ii = dictArray.length; i < ii; i++) {
 
-       const dict = dictArray[i];
 
-       if (!isDict(dict)) {
 
-         continue;
 
-       }
 
-       for (const keyName in dict._map) {
 
-         if (mergedDict._map[keyName] !== undefined) {
 
-           continue;
 
-         }
 
-         mergedDict._map[keyName] = dict._map[keyName];
 
-       }
 
-     }
 
-     return mergedDict;
 
-   };
 
-   return Dict;
 
- }();
 
- exports.Dict = Dict;
 
- var Ref = function RefClosure() {
 
-   let refCache = Object.create(null);
 
-   function Ref(num, gen) {
 
-     this.num = num;
 
-     this.gen = gen;
 
-   }
 
-   Ref.prototype = {
 
-     toString: function Ref_toString() {
 
-       if (this.gen === 0) {
 
-         return `${this.num}R`;
 
-       }
 
-       return `${this.num}R${this.gen}`;
 
-     }
 
-   };
 
-   Ref.get = function (num, gen) {
 
-     const key = gen === 0 ? `${num}R` : `${num}R${gen}`;
 
-     const refValue = refCache[key];
 
-     return refValue ? refValue : refCache[key] = new Ref(num, gen);
 
-   };
 
-   Ref._clearCache = function () {
 
-     refCache = Object.create(null);
 
-   };
 
-   return Ref;
 
- }();
 
- exports.Ref = Ref;
 
- var RefSet = function RefSetClosure() {
 
-   function RefSet() {
 
-     this.dict = Object.create(null);
 
-   }
 
-   RefSet.prototype = {
 
-     has: function RefSet_has(ref) {
 
-       return ref.toString() in this.dict;
 
-     },
 
-     put: function RefSet_put(ref) {
 
-       this.dict[ref.toString()] = true;
 
-     },
 
-     remove: function RefSet_remove(ref) {
 
-       delete this.dict[ref.toString()];
 
-     }
 
-   };
 
-   return RefSet;
 
- }();
 
- exports.RefSet = RefSet;
 
- var RefSetCache = function RefSetCacheClosure() {
 
-   function RefSetCache() {
 
-     this.dict = Object.create(null);
 
-   }
 
-   RefSetCache.prototype = {
 
-     get: function RefSetCache_get(ref) {
 
-       return this.dict[ref.toString()];
 
-     },
 
-     has: function RefSetCache_has(ref) {
 
-       return ref.toString() in this.dict;
 
-     },
 
-     put: function RefSetCache_put(ref, obj) {
 
-       this.dict[ref.toString()] = obj;
 
-     },
 
-     putAlias: function RefSetCache_putAlias(ref, aliasRef) {
 
-       this.dict[ref.toString()] = this.get(aliasRef);
 
-     },
 
-     forEach: function RefSetCache_forEach(callback) {
 
-       for (const i in this.dict) {
 
-         callback(this.dict[i]);
 
-       }
 
-     },
 
-     clear: function RefSetCache_clear() {
 
-       this.dict = Object.create(null);
 
-     }
 
-   };
 
-   return RefSetCache;
 
- }();
 
- exports.RefSetCache = RefSetCache;
 
- function isEOF(v) {
 
-   return v === EOF;
 
- }
 
- function isName(v, name) {
 
-   return v instanceof Name && (name === undefined || v.name === name);
 
- }
 
- function isCmd(v, cmd) {
 
-   return v instanceof Cmd && (cmd === undefined || v.cmd === cmd);
 
- }
 
- function isDict(v, type) {
 
-   return v instanceof Dict && (type === undefined || isName(v.get("Type"), type));
 
- }
 
- function isRef(v) {
 
-   return v instanceof Ref;
 
- }
 
- function isRefsEqual(v1, v2) {
 
-   return v1.num === v2.num && v1.gen === v2.gen;
 
- }
 
- function isStream(v) {
 
-   return typeof v === "object" && v !== null && v.getBytes !== undefined;
 
- }
 
- function clearPrimitiveCaches() {
 
-   Cmd._clearCache();
 
-   Name._clearCache();
 
-   Ref._clearCache();
 
- }
 
- /***/ }),
 
- /* 5 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.NetworkPdfManager = exports.LocalPdfManager = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _chunked_stream = __w_pdfjs_require__(6);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _document = __w_pdfjs_require__(8);
 
- var _stream = __w_pdfjs_require__(11);
 
- class BasePdfManager {
 
-   constructor() {
 
-     if (this.constructor === BasePdfManager) {
 
-       (0, _util.unreachable)("Cannot initialize BasePdfManager.");
 
-     }
 
-   }
 
-   get docId() {
 
-     return this._docId;
 
-   }
 
-   get password() {
 
-     return this._password;
 
-   }
 
-   get docBaseUrl() {
 
-     let docBaseUrl = null;
 
-     if (this._docBaseUrl) {
 
-       const absoluteUrl = (0, _util.createValidAbsoluteUrl)(this._docBaseUrl);
 
-       if (absoluteUrl) {
 
-         docBaseUrl = absoluteUrl.href;
 
-       } else {
 
-         (0, _util.warn)(`Invalid absolute docBaseUrl: "${this._docBaseUrl}".`);
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "docBaseUrl", docBaseUrl);
 
-   }
 
-   onLoadedStream() {
 
-     (0, _util.unreachable)("Abstract method `onLoadedStream` called");
 
-   }
 
-   ensureDoc(prop, args) {
 
-     return this.ensure(this.pdfDocument, prop, args);
 
-   }
 
-   ensureXRef(prop, args) {
 
-     return this.ensure(this.pdfDocument.xref, prop, args);
 
-   }
 
-   ensureCatalog(prop, args) {
 
-     return this.ensure(this.pdfDocument.catalog, prop, args);
 
-   }
 
-   getPage(pageIndex) {
 
-     return this.pdfDocument.getPage(pageIndex);
 
-   }
 
-   fontFallback(id, handler) {
 
-     return this.pdfDocument.fontFallback(id, handler);
 
-   }
 
-   cleanup() {
 
-     return this.pdfDocument.cleanup();
 
-   }
 
-   async ensure(obj, prop, args) {
 
-     (0, _util.unreachable)("Abstract method `ensure` called");
 
-   }
 
-   requestRange(begin, end) {
 
-     (0, _util.unreachable)("Abstract method `requestRange` called");
 
-   }
 
-   requestLoadedStream() {
 
-     (0, _util.unreachable)("Abstract method `requestLoadedStream` called");
 
-   }
 
-   sendProgressiveData(chunk) {
 
-     (0, _util.unreachable)("Abstract method `sendProgressiveData` called");
 
-   }
 
-   updatePassword(password) {
 
-     this._password = password;
 
-   }
 
-   terminate(reason) {
 
-     (0, _util.unreachable)("Abstract method `terminate` called");
 
-   }
 
- }
 
- class LocalPdfManager extends BasePdfManager {
 
-   constructor(docId, data, password, evaluatorOptions, docBaseUrl) {
 
-     super();
 
-     this._docId = docId;
 
-     this._password = password;
 
-     this._docBaseUrl = docBaseUrl;
 
-     this.evaluatorOptions = evaluatorOptions;
 
-     const stream = new _stream.Stream(data);
 
-     this.pdfDocument = new _document.PDFDocument(this, stream);
 
-     this._loadedStreamPromise = Promise.resolve(stream);
 
-   }
 
-   async ensure(obj, prop, args) {
 
-     const value = obj[prop];
 
-     if (typeof value === "function") {
 
-       return value.apply(obj, args);
 
-     }
 
-     return value;
 
-   }
 
-   requestRange(begin, end) {
 
-     return Promise.resolve();
 
-   }
 
-   requestLoadedStream() {}
 
-   onLoadedStream() {
 
-     return this._loadedStreamPromise;
 
-   }
 
-   terminate(reason) {}
 
- }
 
- exports.LocalPdfManager = LocalPdfManager;
 
- class NetworkPdfManager extends BasePdfManager {
 
-   constructor(docId, pdfNetworkStream, args, evaluatorOptions, docBaseUrl) {
 
-     super();
 
-     this._docId = docId;
 
-     this._password = args.password;
 
-     this._docBaseUrl = docBaseUrl;
 
-     this.msgHandler = args.msgHandler;
 
-     this.evaluatorOptions = evaluatorOptions;
 
-     this.streamManager = new _chunked_stream.ChunkedStreamManager(pdfNetworkStream, {
 
-       msgHandler: args.msgHandler,
 
-       length: args.length,
 
-       disableAutoFetch: args.disableAutoFetch,
 
-       rangeChunkSize: args.rangeChunkSize
 
-     });
 
-     this.pdfDocument = new _document.PDFDocument(this, this.streamManager.getStream());
 
-   }
 
-   async ensure(obj, prop, args) {
 
-     try {
 
-       const value = obj[prop];
 
-       if (typeof value === "function") {
 
-         return value.apply(obj, args);
 
-       }
 
-       return value;
 
-     } catch (ex) {
 
-       if (!(ex instanceof _core_utils.MissingDataException)) {
 
-         throw ex;
 
-       }
 
-       await this.requestRange(ex.begin, ex.end);
 
-       return this.ensure(obj, prop, args);
 
-     }
 
-   }
 
-   requestRange(begin, end) {
 
-     return this.streamManager.requestRange(begin, end);
 
-   }
 
-   requestLoadedStream() {
 
-     this.streamManager.requestAllChunks();
 
-   }
 
-   sendProgressiveData(chunk) {
 
-     this.streamManager.onReceiveData({
 
-       chunk
 
-     });
 
-   }
 
-   onLoadedStream() {
 
-     return this.streamManager.onLoadedStream();
 
-   }
 
-   terminate(reason) {
 
-     this.streamManager.abort(reason);
 
-   }
 
- }
 
- exports.NetworkPdfManager = NetworkPdfManager;
 
- /***/ }),
 
- /* 6 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.ChunkedStreamManager = exports.ChunkedStream = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- class ChunkedStream {
 
-   constructor(length, chunkSize, manager) {
 
-     this.bytes = new Uint8Array(length);
 
-     this.start = 0;
 
-     this.pos = 0;
 
-     this.end = length;
 
-     this.chunkSize = chunkSize;
 
-     this.loadedChunks = [];
 
-     this.numChunksLoaded = 0;
 
-     this.numChunks = Math.ceil(length / chunkSize);
 
-     this.manager = manager;
 
-     this.progressiveDataLength = 0;
 
-     this.lastSuccessfulEnsureByteChunk = -1;
 
-   }
 
-   getMissingChunks() {
 
-     const chunks = [];
 
-     for (let chunk = 0, n = this.numChunks; chunk < n; ++chunk) {
 
-       if (!this.loadedChunks[chunk]) {
 
-         chunks.push(chunk);
 
-       }
 
-     }
 
-     return chunks;
 
-   }
 
-   getBaseStreams() {
 
-     return [this];
 
-   }
 
-   allChunksLoaded() {
 
-     return this.numChunksLoaded === this.numChunks;
 
-   }
 
-   onReceiveData(begin, chunk) {
 
-     const chunkSize = this.chunkSize;
 
-     if (begin % chunkSize !== 0) {
 
-       throw new Error(`Bad begin offset: ${begin}`);
 
-     }
 
-     const end = begin + chunk.byteLength;
 
-     if (end % chunkSize !== 0 && end !== this.bytes.length) {
 
-       throw new Error(`Bad end offset: ${end}`);
 
-     }
 
-     this.bytes.set(new Uint8Array(chunk), begin);
 
-     const beginChunk = Math.floor(begin / chunkSize);
 
-     const endChunk = Math.floor((end - 1) / chunkSize) + 1;
 
-     for (let curChunk = beginChunk; curChunk < endChunk; ++curChunk) {
 
-       if (!this.loadedChunks[curChunk]) {
 
-         this.loadedChunks[curChunk] = true;
 
-         ++this.numChunksLoaded;
 
-       }
 
-     }
 
-   }
 
-   onReceiveProgressiveData(data) {
 
-     let position = this.progressiveDataLength;
 
-     const beginChunk = Math.floor(position / this.chunkSize);
 
-     this.bytes.set(new Uint8Array(data), position);
 
-     position += data.byteLength;
 
-     this.progressiveDataLength = position;
 
-     const endChunk = position >= this.end ? this.numChunks : Math.floor(position / this.chunkSize);
 
-     for (let curChunk = beginChunk; curChunk < endChunk; ++curChunk) {
 
-       if (!this.loadedChunks[curChunk]) {
 
-         this.loadedChunks[curChunk] = true;
 
-         ++this.numChunksLoaded;
 
-       }
 
-     }
 
-   }
 
-   ensureByte(pos) {
 
-     if (pos < this.progressiveDataLength) {
 
-       return;
 
-     }
 
-     const chunk = Math.floor(pos / this.chunkSize);
 
-     if (chunk === this.lastSuccessfulEnsureByteChunk) {
 
-       return;
 
-     }
 
-     if (!this.loadedChunks[chunk]) {
 
-       throw new _core_utils.MissingDataException(pos, pos + 1);
 
-     }
 
-     this.lastSuccessfulEnsureByteChunk = chunk;
 
-   }
 
-   ensureRange(begin, end) {
 
-     if (begin >= end) {
 
-       return;
 
-     }
 
-     if (end <= this.progressiveDataLength) {
 
-       return;
 
-     }
 
-     const chunkSize = this.chunkSize;
 
-     const beginChunk = Math.floor(begin / chunkSize);
 
-     const endChunk = Math.floor((end - 1) / chunkSize) + 1;
 
-     for (let chunk = beginChunk; chunk < endChunk; ++chunk) {
 
-       if (!this.loadedChunks[chunk]) {
 
-         throw new _core_utils.MissingDataException(begin, end);
 
-       }
 
-     }
 
-   }
 
-   nextEmptyChunk(beginChunk) {
 
-     const numChunks = this.numChunks;
 
-     for (let i = 0; i < numChunks; ++i) {
 
-       const chunk = (beginChunk + i) % numChunks;
 
-       if (!this.loadedChunks[chunk]) {
 
-         return chunk;
 
-       }
 
-     }
 
-     return null;
 
-   }
 
-   hasChunk(chunk) {
 
-     return !!this.loadedChunks[chunk];
 
-   }
 
-   get length() {
 
-     return this.end - this.start;
 
-   }
 
-   get isEmpty() {
 
-     return this.length === 0;
 
-   }
 
-   getByte() {
 
-     const pos = this.pos;
 
-     if (pos >= this.end) {
 
-       return -1;
 
-     }
 
-     if (pos >= this.progressiveDataLength) {
 
-       this.ensureByte(pos);
 
-     }
 
-     return this.bytes[this.pos++];
 
-   }
 
-   getUint16() {
 
-     const b0 = this.getByte();
 
-     const b1 = this.getByte();
 
-     if (b0 === -1 || b1 === -1) {
 
-       return -1;
 
-     }
 
-     return (b0 << 8) + b1;
 
-   }
 
-   getInt32() {
 
-     const b0 = this.getByte();
 
-     const b1 = this.getByte();
 
-     const b2 = this.getByte();
 
-     const b3 = this.getByte();
 
-     return (b0 << 24) + (b1 << 16) + (b2 << 8) + b3;
 
-   }
 
-   getBytes(length, forceClamped = false) {
 
-     const bytes = this.bytes;
 
-     const pos = this.pos;
 
-     const strEnd = this.end;
 
-     if (!length) {
 
-       if (strEnd > this.progressiveDataLength) {
 
-         this.ensureRange(pos, strEnd);
 
-       }
 
-       const subarray = bytes.subarray(pos, strEnd);
 
-       return forceClamped ? new Uint8ClampedArray(subarray) : subarray;
 
-     }
 
-     let end = pos + length;
 
-     if (end > strEnd) {
 
-       end = strEnd;
 
-     }
 
-     if (end > this.progressiveDataLength) {
 
-       this.ensureRange(pos, end);
 
-     }
 
-     this.pos = end;
 
-     const subarray = bytes.subarray(pos, end);
 
-     return forceClamped ? new Uint8ClampedArray(subarray) : subarray;
 
-   }
 
-   peekByte() {
 
-     const peekedByte = this.getByte();
 
-     if (peekedByte !== -1) {
 
-       this.pos--;
 
-     }
 
-     return peekedByte;
 
-   }
 
-   peekBytes(length, forceClamped = false) {
 
-     const bytes = this.getBytes(length, forceClamped);
 
-     this.pos -= bytes.length;
 
-     return bytes;
 
-   }
 
-   getByteRange(begin, end) {
 
-     if (begin < 0) {
 
-       begin = 0;
 
-     }
 
-     if (end > this.end) {
 
-       end = this.end;
 
-     }
 
-     if (end > this.progressiveDataLength) {
 
-       this.ensureRange(begin, end);
 
-     }
 
-     return this.bytes.subarray(begin, end);
 
-   }
 
-   skip(n) {
 
-     if (!n) {
 
-       n = 1;
 
-     }
 
-     this.pos += n;
 
-   }
 
-   reset() {
 
-     this.pos = this.start;
 
-   }
 
-   moveStart() {
 
-     this.start = this.pos;
 
-   }
 
-   makeSubStream(start, length, dict) {
 
-     if (length) {
 
-       if (start + length > this.progressiveDataLength) {
 
-         this.ensureRange(start, start + length);
 
-       }
 
-     } else {
 
-       if (start >= this.progressiveDataLength) {
 
-         this.ensureByte(start);
 
-       }
 
-     }
 
-     function ChunkedStreamSubstream() {}
 
-     ChunkedStreamSubstream.prototype = Object.create(this);
 
-     ChunkedStreamSubstream.prototype.getMissingChunks = function () {
 
-       const chunkSize = this.chunkSize;
 
-       const beginChunk = Math.floor(this.start / chunkSize);
 
-       const endChunk = Math.floor((this.end - 1) / chunkSize) + 1;
 
-       const missingChunks = [];
 
-       for (let chunk = beginChunk; chunk < endChunk; ++chunk) {
 
-         if (!this.loadedChunks[chunk]) {
 
-           missingChunks.push(chunk);
 
-         }
 
-       }
 
-       return missingChunks;
 
-     };
 
-     ChunkedStreamSubstream.prototype.allChunksLoaded = function () {
 
-       if (this.numChunksLoaded === this.numChunks) {
 
-         return true;
 
-       }
 
-       return this.getMissingChunks().length === 0;
 
-     };
 
-     const subStream = new ChunkedStreamSubstream();
 
-     subStream.pos = subStream.start = start;
 
-     subStream.end = start + length || this.end;
 
-     subStream.dict = dict;
 
-     return subStream;
 
-   }
 
- }
 
- exports.ChunkedStream = ChunkedStream;
 
- class ChunkedStreamManager {
 
-   constructor(pdfNetworkStream, args) {
 
-     this.length = args.length;
 
-     this.chunkSize = args.rangeChunkSize;
 
-     this.stream = new ChunkedStream(this.length, this.chunkSize, this);
 
-     this.pdfNetworkStream = pdfNetworkStream;
 
-     this.disableAutoFetch = args.disableAutoFetch;
 
-     this.msgHandler = args.msgHandler;
 
-     this.currRequestId = 0;
 
-     this.chunksNeededByRequest = Object.create(null);
 
-     this.requestsByChunk = Object.create(null);
 
-     this.promisesByRequest = Object.create(null);
 
-     this.progressiveDataLength = 0;
 
-     this.aborted = false;
 
-     this._loadedStreamCapability = (0, _util.createPromiseCapability)();
 
-   }
 
-   onLoadedStream() {
 
-     return this._loadedStreamCapability.promise;
 
-   }
 
-   sendRequest(begin, end) {
 
-     const rangeReader = this.pdfNetworkStream.getRangeReader(begin, end);
 
-     if (!rangeReader.isStreamingSupported) {
 
-       rangeReader.onProgress = this.onProgress.bind(this);
 
-     }
 
-     let chunks = [],
 
-         loaded = 0;
 
-     const promise = new Promise((resolve, reject) => {
 
-       const readChunk = chunk => {
 
-         try {
 
-           if (!chunk.done) {
 
-             const data = chunk.value;
 
-             chunks.push(data);
 
-             loaded += (0, _util.arrayByteLength)(data);
 
-             if (rangeReader.isStreamingSupported) {
 
-               this.onProgress({
 
-                 loaded
 
-               });
 
-             }
 
-             rangeReader.read().then(readChunk, reject);
 
-             return;
 
-           }
 
-           const chunkData = (0, _util.arraysToBytes)(chunks);
 
-           chunks = null;
 
-           resolve(chunkData);
 
-         } catch (e) {
 
-           reject(e);
 
-         }
 
-       };
 
-       rangeReader.read().then(readChunk, reject);
 
-     });
 
-     promise.then(data => {
 
-       if (this.aborted) {
 
-         return;
 
-       }
 
-       this.onReceiveData({
 
-         chunk: data,
 
-         begin
 
-       });
 
-     });
 
-   }
 
-   requestAllChunks() {
 
-     const missingChunks = this.stream.getMissingChunks();
 
-     this._requestChunks(missingChunks);
 
-     return this._loadedStreamCapability.promise;
 
-   }
 
-   _requestChunks(chunks) {
 
-     const requestId = this.currRequestId++;
 
-     const chunksNeeded = Object.create(null);
 
-     this.chunksNeededByRequest[requestId] = chunksNeeded;
 
-     for (const chunk of chunks) {
 
-       if (!this.stream.hasChunk(chunk)) {
 
-         chunksNeeded[chunk] = true;
 
-       }
 
-     }
 
-     if ((0, _util.isEmptyObj)(chunksNeeded)) {
 
-       return Promise.resolve();
 
-     }
 
-     const capability = (0, _util.createPromiseCapability)();
 
-     this.promisesByRequest[requestId] = capability;
 
-     const chunksToRequest = [];
 
-     for (let chunk in chunksNeeded) {
 
-       chunk = chunk | 0;
 
-       if (!(chunk in this.requestsByChunk)) {
 
-         this.requestsByChunk[chunk] = [];
 
-         chunksToRequest.push(chunk);
 
-       }
 
-       this.requestsByChunk[chunk].push(requestId);
 
-     }
 
-     if (!chunksToRequest.length) {
 
-       return capability.promise;
 
-     }
 
-     const groupedChunksToRequest = this.groupChunks(chunksToRequest);
 
-     for (const groupedChunk of groupedChunksToRequest) {
 
-       const begin = groupedChunk.beginChunk * this.chunkSize;
 
-       const end = Math.min(groupedChunk.endChunk * this.chunkSize, this.length);
 
-       this.sendRequest(begin, end);
 
-     }
 
-     return capability.promise;
 
-   }
 
-   getStream() {
 
-     return this.stream;
 
-   }
 
-   requestRange(begin, end) {
 
-     end = Math.min(end, this.length);
 
-     const beginChunk = this.getBeginChunk(begin);
 
-     const endChunk = this.getEndChunk(end);
 
-     const chunks = [];
 
-     for (let chunk = beginChunk; chunk < endChunk; ++chunk) {
 
-       chunks.push(chunk);
 
-     }
 
-     return this._requestChunks(chunks);
 
-   }
 
-   requestRanges(ranges = []) {
 
-     const chunksToRequest = [];
 
-     for (const range of ranges) {
 
-       const beginChunk = this.getBeginChunk(range.begin);
 
-       const endChunk = this.getEndChunk(range.end);
 
-       for (let chunk = beginChunk; chunk < endChunk; ++chunk) {
 
-         if (!chunksToRequest.includes(chunk)) {
 
-           chunksToRequest.push(chunk);
 
-         }
 
-       }
 
-     }
 
-     chunksToRequest.sort(function (a, b) {
 
-       return a - b;
 
-     });
 
-     return this._requestChunks(chunksToRequest);
 
-   }
 
-   groupChunks(chunks) {
 
-     const groupedChunks = [];
 
-     let beginChunk = -1;
 
-     let prevChunk = -1;
 
-     for (let i = 0, ii = chunks.length; i < ii; ++i) {
 
-       const chunk = chunks[i];
 
-       if (beginChunk < 0) {
 
-         beginChunk = chunk;
 
-       }
 
-       if (prevChunk >= 0 && prevChunk + 1 !== chunk) {
 
-         groupedChunks.push({
 
-           beginChunk,
 
-           endChunk: prevChunk + 1
 
-         });
 
-         beginChunk = chunk;
 
-       }
 
-       if (i + 1 === chunks.length) {
 
-         groupedChunks.push({
 
-           beginChunk,
 
-           endChunk: chunk + 1
 
-         });
 
-       }
 
-       prevChunk = chunk;
 
-     }
 
-     return groupedChunks;
 
-   }
 
-   onProgress(args) {
 
-     this.msgHandler.send("DocProgress", {
 
-       loaded: this.stream.numChunksLoaded * this.chunkSize + args.loaded,
 
-       total: this.length
 
-     });
 
-   }
 
-   onReceiveData(args) {
 
-     const chunk = args.chunk;
 
-     const isProgressive = args.begin === undefined;
 
-     const begin = isProgressive ? this.progressiveDataLength : args.begin;
 
-     const end = begin + chunk.byteLength;
 
-     const beginChunk = Math.floor(begin / this.chunkSize);
 
-     const endChunk = end < this.length ? Math.floor(end / this.chunkSize) : Math.ceil(end / this.chunkSize);
 
-     if (isProgressive) {
 
-       this.stream.onReceiveProgressiveData(chunk);
 
-       this.progressiveDataLength = end;
 
-     } else {
 
-       this.stream.onReceiveData(begin, chunk);
 
-     }
 
-     if (this.stream.allChunksLoaded()) {
 
-       this._loadedStreamCapability.resolve(this.stream);
 
-     }
 
-     const loadedRequests = [];
 
-     for (let chunk = beginChunk; chunk < endChunk; ++chunk) {
 
-       const requestIds = this.requestsByChunk[chunk] || [];
 
-       delete this.requestsByChunk[chunk];
 
-       for (const requestId of requestIds) {
 
-         const chunksNeeded = this.chunksNeededByRequest[requestId];
 
-         if (chunk in chunksNeeded) {
 
-           delete chunksNeeded[chunk];
 
-         }
 
-         if (!(0, _util.isEmptyObj)(chunksNeeded)) {
 
-           continue;
 
-         }
 
-         loadedRequests.push(requestId);
 
-       }
 
-     }
 
-     if (!this.disableAutoFetch && (0, _util.isEmptyObj)(this.requestsByChunk)) {
 
-       let nextEmptyChunk;
 
-       if (this.stream.numChunksLoaded === 1) {
 
-         const lastChunk = this.stream.numChunks - 1;
 
-         if (!this.stream.hasChunk(lastChunk)) {
 
-           nextEmptyChunk = lastChunk;
 
-         }
 
-       } else {
 
-         nextEmptyChunk = this.stream.nextEmptyChunk(endChunk);
 
-       }
 
-       if (Number.isInteger(nextEmptyChunk)) {
 
-         this._requestChunks([nextEmptyChunk]);
 
-       }
 
-     }
 
-     for (const requestId of loadedRequests) {
 
-       const capability = this.promisesByRequest[requestId];
 
-       delete this.promisesByRequest[requestId];
 
-       capability.resolve();
 
-     }
 
-     this.msgHandler.send("DocProgress", {
 
-       loaded: this.stream.numChunksLoaded * this.chunkSize,
 
-       total: this.length
 
-     });
 
-   }
 
-   onError(err) {
 
-     this._loadedStreamCapability.reject(err);
 
-   }
 
-   getBeginChunk(begin) {
 
-     return Math.floor(begin / this.chunkSize);
 
-   }
 
-   getEndChunk(end) {
 
-     return Math.floor((end - 1) / this.chunkSize) + 1;
 
-   }
 
-   abort(reason) {
 
-     this.aborted = true;
 
-     if (this.pdfNetworkStream) {
 
-       this.pdfNetworkStream.cancelAllRequests(reason);
 
-     }
 
-     for (const requestId in this.promisesByRequest) {
 
-       this.promisesByRequest[requestId].reject(reason);
 
-     }
 
-   }
 
- }
 
- exports.ChunkedStreamManager = ChunkedStreamManager;
 
- /***/ }),
 
- /* 7 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getLookupTableFactory = getLookupTableFactory;
 
- exports.getInheritableProperty = getInheritableProperty;
 
- exports.toRomanNumerals = toRomanNumerals;
 
- exports.log2 = log2;
 
- exports.readInt8 = readInt8;
 
- exports.readUint16 = readUint16;
 
- exports.readUint32 = readUint32;
 
- exports.isWhiteSpace = isWhiteSpace;
 
- exports.XRefParseException = exports.XRefEntryException = exports.MissingDataException = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- function getLookupTableFactory(initializer) {
 
-   let lookup;
 
-   return function () {
 
-     if (initializer) {
 
-       lookup = Object.create(null);
 
-       initializer(lookup);
 
-       initializer = null;
 
-     }
 
-     return lookup;
 
-   };
 
- }
 
- class MissingDataException extends _util.BaseException {
 
-   constructor(begin, end) {
 
-     super(`Missing data [${begin}, ${end})`);
 
-     this.begin = begin;
 
-     this.end = end;
 
-   }
 
- }
 
- exports.MissingDataException = MissingDataException;
 
- class XRefEntryException extends _util.BaseException {}
 
- exports.XRefEntryException = XRefEntryException;
 
- class XRefParseException extends _util.BaseException {}
 
- exports.XRefParseException = XRefParseException;
 
- function getInheritableProperty({
 
-   dict,
 
-   key,
 
-   getArray = false,
 
-   stopWhenFound = true
 
- }) {
 
-   const LOOP_LIMIT = 100;
 
-   let loopCount = 0;
 
-   let values;
 
-   while (dict) {
 
-     const value = getArray ? dict.getArray(key) : dict.get(key);
 
-     if (value !== undefined) {
 
-       if (stopWhenFound) {
 
-         return value;
 
-       }
 
-       if (!values) {
 
-         values = [];
 
-       }
 
-       values.push(value);
 
-     }
 
-     if (++loopCount > LOOP_LIMIT) {
 
-       (0, _util.warn)(`getInheritableProperty: maximum loop count exceeded for "${key}"`);
 
-       break;
 
-     }
 
-     dict = dict.get("Parent");
 
-   }
 
-   return values;
 
- }
 
- const ROMAN_NUMBER_MAP = ["", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM", "", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC", "", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"];
 
- function toRomanNumerals(number, lowerCase = false) {
 
-   (0, _util.assert)(Number.isInteger(number) && number > 0, "The number should be a positive integer.");
 
-   const romanBuf = [];
 
-   let pos;
 
-   while (number >= 1000) {
 
-     number -= 1000;
 
-     romanBuf.push("M");
 
-   }
 
-   pos = number / 100 | 0;
 
-   number %= 100;
 
-   romanBuf.push(ROMAN_NUMBER_MAP[pos]);
 
-   pos = number / 10 | 0;
 
-   number %= 10;
 
-   romanBuf.push(ROMAN_NUMBER_MAP[10 + pos]);
 
-   romanBuf.push(ROMAN_NUMBER_MAP[20 + number]);
 
-   const romanStr = romanBuf.join("");
 
-   return lowerCase ? romanStr.toLowerCase() : romanStr;
 
- }
 
- function log2(x) {
 
-   if (x <= 0) {
 
-     return 0;
 
-   }
 
-   return Math.ceil(Math.log2(x));
 
- }
 
- function readInt8(data, offset) {
 
-   return data[offset] << 24 >> 24;
 
- }
 
- function readUint16(data, offset) {
 
-   return data[offset] << 8 | data[offset + 1];
 
- }
 
- function readUint32(data, offset) {
 
-   return (data[offset] << 24 | data[offset + 1] << 16 | data[offset + 2] << 8 | data[offset + 3]) >>> 0;
 
- }
 
- function isWhiteSpace(ch) {
 
-   return ch === 0x20 || ch === 0x09 || ch === 0x0d || ch === 0x0a;
 
- }
 
- /***/ }),
 
- /* 8 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.PDFDocument = exports.Page = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _obj = __w_pdfjs_require__(9);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _annotation = __w_pdfjs_require__(23);
 
- var _crypto = __w_pdfjs_require__(21);
 
- var _parser = __w_pdfjs_require__(10);
 
- var _operator_list = __w_pdfjs_require__(24);
 
- var _evaluator = __w_pdfjs_require__(25);
 
- var _function = __w_pdfjs_require__(39);
 
- const DEFAULT_USER_UNIT = 1.0;
 
- const LETTER_SIZE_MEDIABOX = [0, 0, 612, 792];
 
- function isAnnotationRenderable(annotation, intent) {
 
-   return intent === "display" && annotation.viewable || intent === "print" && annotation.printable;
 
- }
 
- class Page {
 
-   constructor({
 
-     pdfManager,
 
-     xref,
 
-     pageIndex,
 
-     pageDict,
 
-     ref,
 
-     fontCache,
 
-     builtInCMapCache,
 
-     pdfFunctionFactory
 
-   }) {
 
-     this.pdfManager = pdfManager;
 
-     this.pageIndex = pageIndex;
 
-     this.pageDict = pageDict;
 
-     this.xref = xref;
 
-     this.ref = ref;
 
-     this.fontCache = fontCache;
 
-     this.builtInCMapCache = builtInCMapCache;
 
-     this.pdfFunctionFactory = pdfFunctionFactory;
 
-     this.evaluatorOptions = pdfManager.evaluatorOptions;
 
-     this.resourcesPromise = null;
 
-     const idCounters = {
 
-       obj: 0
 
-     };
 
-     this.idFactory = {
 
-       createObjId() {
 
-         return `p${pageIndex}_${++idCounters.obj}`;
 
-       },
 
-       getDocId() {
 
-         return `g_${pdfManager.docId}`;
 
-       }
 
-     };
 
-   }
 
-   _getInheritableProperty(key, getArray = false) {
 
-     const value = (0, _core_utils.getInheritableProperty)({
 
-       dict: this.pageDict,
 
-       key,
 
-       getArray,
 
-       stopWhenFound: false
 
-     });
 
-     if (!Array.isArray(value)) {
 
-       return value;
 
-     }
 
-     if (value.length === 1 || !(0, _primitives.isDict)(value[0])) {
 
-       return value[0];
 
-     }
 
-     return _primitives.Dict.merge(this.xref, value);
 
-   }
 
-   get content() {
 
-     return this.pageDict.get("Contents");
 
-   }
 
-   get resources() {
 
-     return (0, _util.shadow)(this, "resources", this._getInheritableProperty("Resources") || _primitives.Dict.empty);
 
-   }
 
-   _getBoundingBox(name) {
 
-     const box = this._getInheritableProperty(name, true);
 
-     if (Array.isArray(box) && box.length === 4) {
 
-       if (box[2] - box[0] !== 0 && box[3] - box[1] !== 0) {
 
-         return box;
 
-       }
 
-       (0, _util.warn)(`Empty /${name} entry.`);
 
-     }
 
-     return null;
 
-   }
 
-   get mediaBox() {
 
-     return (0, _util.shadow)(this, "mediaBox", this._getBoundingBox("MediaBox") || LETTER_SIZE_MEDIABOX);
 
-   }
 
-   get cropBox() {
 
-     return (0, _util.shadow)(this, "cropBox", this._getBoundingBox("CropBox") || this.mediaBox);
 
-   }
 
-   get userUnit() {
 
-     let obj = this.pageDict.get("UserUnit");
 
-     if (!(0, _util.isNum)(obj) || obj <= 0) {
 
-       obj = DEFAULT_USER_UNIT;
 
-     }
 
-     return (0, _util.shadow)(this, "userUnit", obj);
 
-   }
 
-   get view() {
 
-     const {
 
-       cropBox,
 
-       mediaBox
 
-     } = this;
 
-     let view;
 
-     if (cropBox === mediaBox || (0, _util.isArrayEqual)(cropBox, mediaBox)) {
 
-       view = mediaBox;
 
-     } else {
 
-       const box = _util.Util.intersect(cropBox, mediaBox);
 
-       if (box && box[2] - box[0] !== 0 && box[3] - box[1] !== 0) {
 
-         view = box;
 
-       } else {
 
-         (0, _util.warn)("Empty /CropBox and /MediaBox intersection.");
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "view", view || mediaBox);
 
-   }
 
-   get rotate() {
 
-     let rotate = this._getInheritableProperty("Rotate") || 0;
 
-     if (rotate % 90 !== 0) {
 
-       rotate = 0;
 
-     } else if (rotate >= 360) {
 
-       rotate = rotate % 360;
 
-     } else if (rotate < 0) {
 
-       rotate = (rotate % 360 + 360) % 360;
 
-     }
 
-     return (0, _util.shadow)(this, "rotate", rotate);
 
-   }
 
-   getContentStream() {
 
-     const content = this.content;
 
-     let stream;
 
-     if (Array.isArray(content)) {
 
-       const xref = this.xref;
 
-       const streams = [];
 
-       for (const stream of content) {
 
-         streams.push(xref.fetchIfRef(stream));
 
-       }
 
-       stream = new _stream.StreamsSequenceStream(streams);
 
-     } else if ((0, _primitives.isStream)(content)) {
 
-       stream = content;
 
-     } else {
 
-       stream = new _stream.NullStream();
 
-     }
 
-     return stream;
 
-   }
 
-   loadResources(keys) {
 
-     if (!this.resourcesPromise) {
 
-       this.resourcesPromise = this.pdfManager.ensure(this, "resources");
 
-     }
 
-     return this.resourcesPromise.then(() => {
 
-       const objectLoader = new _obj.ObjectLoader(this.resources, keys, this.xref);
 
-       return objectLoader.load();
 
-     });
 
-   }
 
-   getOperatorList({
 
-     handler,
 
-     sink,
 
-     task,
 
-     intent,
 
-     renderInteractiveForms
 
-   }) {
 
-     const contentStreamPromise = this.pdfManager.ensure(this, "getContentStream");
 
-     const resourcesPromise = this.loadResources(["ExtGState", "ColorSpace", "Pattern", "Shading", "XObject", "Font"]);
 
-     const partialEvaluator = new _evaluator.PartialEvaluator({
 
-       xref: this.xref,
 
-       handler,
 
-       pageIndex: this.pageIndex,
 
-       idFactory: this.idFactory,
 
-       fontCache: this.fontCache,
 
-       builtInCMapCache: this.builtInCMapCache,
 
-       options: this.evaluatorOptions,
 
-       pdfFunctionFactory: this.pdfFunctionFactory
 
-     });
 
-     const dataPromises = Promise.all([contentStreamPromise, resourcesPromise]);
 
-     const pageListPromise = dataPromises.then(([contentStream]) => {
 
-       const opList = new _operator_list.OperatorList(intent, sink, this.pageIndex);
 
-       handler.send("StartRenderPage", {
 
-         transparency: partialEvaluator.hasBlendModes(this.resources),
 
-         pageIndex: this.pageIndex,
 
-         intent
 
-       });
 
-       return partialEvaluator.getOperatorList({
 
-         stream: contentStream,
 
-         task,
 
-         resources: this.resources,
 
-         operatorList: opList
 
-       }).then(function () {
 
-         return opList;
 
-       });
 
-     });
 
-     return Promise.all([pageListPromise, this._parsedAnnotations]).then(function ([pageOpList, annotations]) {
 
-       if (annotations.length === 0) {
 
-         pageOpList.flush(true);
 
-         return {
 
-           length: pageOpList.totalLength
 
-         };
 
-       }
 
-       const opListPromises = [];
 
-       for (const annotation of annotations) {
 
-         if (isAnnotationRenderable(annotation, intent)) {
 
-           opListPromises.push(annotation.getOperatorList(partialEvaluator, task, renderInteractiveForms));
 
-         }
 
-       }
 
-       return Promise.all(opListPromises).then(function (opLists) {
 
-         pageOpList.addOp(_util.OPS.beginAnnotations, []);
 
-         for (const opList of opLists) {
 
-           pageOpList.addOpList(opList);
 
-         }
 
-         pageOpList.addOp(_util.OPS.endAnnotations, []);
 
-         pageOpList.flush(true);
 
-         return {
 
-           length: pageOpList.totalLength
 
-         };
 
-       });
 
-     });
 
-   }
 
-   extractTextContent({
 
-     handler,
 
-     task,
 
-     normalizeWhitespace,
 
-     sink,
 
-     combineTextItems
 
-   }) {
 
-     const contentStreamPromise = this.pdfManager.ensure(this, "getContentStream");
 
-     const resourcesPromise = this.loadResources(["ExtGState", "XObject", "Font"]);
 
-     const dataPromises = Promise.all([contentStreamPromise, resourcesPromise]);
 
-     return dataPromises.then(([contentStream]) => {
 
-       const partialEvaluator = new _evaluator.PartialEvaluator({
 
-         xref: this.xref,
 
-         handler,
 
-         pageIndex: this.pageIndex,
 
-         idFactory: this.idFactory,
 
-         fontCache: this.fontCache,
 
-         builtInCMapCache: this.builtInCMapCache,
 
-         options: this.evaluatorOptions,
 
-         pdfFunctionFactory: this.pdfFunctionFactory
 
-       });
 
-       return partialEvaluator.getTextContent({
 
-         stream: contentStream,
 
-         task,
 
-         resources: this.resources,
 
-         normalizeWhitespace,
 
-         combineTextItems,
 
-         sink
 
-       });
 
-     });
 
-   }
 
-   getAnnotationsData(intent) {
 
-     return this._parsedAnnotations.then(function (annotations) {
 
-       const annotationsData = [];
 
-       for (let i = 0, ii = annotations.length; i < ii; i++) {
 
-         if (!intent || isAnnotationRenderable(annotations[i], intent)) {
 
-           annotationsData.push(annotations[i].data);
 
-         }
 
-       }
 
-       return annotationsData;
 
-     });
 
-   }
 
-   get annotations() {
 
-     return (0, _util.shadow)(this, "annotations", this._getInheritableProperty("Annots") || []);
 
-   }
 
-   get _parsedAnnotations() {
 
-     const parsedAnnotations = this.pdfManager.ensure(this, "annotations").then(() => {
 
-       const annotationRefs = this.annotations;
 
-       const annotationPromises = [];
 
-       for (let i = 0, ii = annotationRefs.length; i < ii; i++) {
 
-         annotationPromises.push(_annotation.AnnotationFactory.create(this.xref, annotationRefs[i], this.pdfManager, this.idFactory));
 
-       }
 
-       return Promise.all(annotationPromises).then(function (annotations) {
 
-         return annotations.filter(function isDefined(annotation) {
 
-           return !!annotation;
 
-         });
 
-       }, function (reason) {
 
-         (0, _util.warn)(`_parsedAnnotations: "${reason}".`);
 
-         return [];
 
-       });
 
-     });
 
-     return (0, _util.shadow)(this, "_parsedAnnotations", parsedAnnotations);
 
-   }
 
- }
 
- exports.Page = Page;
 
- const PDF_HEADER_SIGNATURE = new Uint8Array([0x25, 0x50, 0x44, 0x46, 0x2d]);
 
- const STARTXREF_SIGNATURE = new Uint8Array([0x73, 0x74, 0x61, 0x72, 0x74, 0x78, 0x72, 0x65, 0x66]);
 
- const ENDOBJ_SIGNATURE = new Uint8Array([0x65, 0x6e, 0x64, 0x6f, 0x62, 0x6a]);
 
- const FINGERPRINT_FIRST_BYTES = 1024;
 
- const EMPTY_FINGERPRINT = "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00";
 
- const PDF_HEADER_VERSION_REGEXP = /^[1-9]\.[0-9]$/;
 
- function find(stream, signature, limit = 1024, backwards = false) {
 
-   const signatureLength = signature.length;
 
-   const scanBytes = stream.peekBytes(limit);
 
-   const scanLength = scanBytes.length - signatureLength;
 
-   if (scanLength <= 0) {
 
-     return false;
 
-   }
 
-   if (backwards) {
 
-     const signatureEnd = signatureLength - 1;
 
-     let pos = scanBytes.length - 1;
 
-     while (pos >= signatureEnd) {
 
-       let j = 0;
 
-       while (j < signatureLength && scanBytes[pos - j] === signature[signatureEnd - j]) {
 
-         j++;
 
-       }
 
-       if (j >= signatureLength) {
 
-         stream.pos += pos - signatureEnd;
 
-         return true;
 
-       }
 
-       pos--;
 
-     }
 
-   } else {
 
-     let pos = 0;
 
-     while (pos <= scanLength) {
 
-       let j = 0;
 
-       while (j < signatureLength && scanBytes[pos + j] === signature[j]) {
 
-         j++;
 
-       }
 
-       if (j >= signatureLength) {
 
-         stream.pos += pos;
 
-         return true;
 
-       }
 
-       pos++;
 
-     }
 
-   }
 
-   return false;
 
- }
 
- class PDFDocument {
 
-   constructor(pdfManager, arg) {
 
-     let stream;
 
-     if ((0, _primitives.isStream)(arg)) {
 
-       stream = arg;
 
-     } else if ((0, _util.isArrayBuffer)(arg)) {
 
-       stream = new _stream.Stream(arg);
 
-     } else {
 
-       throw new Error("PDFDocument: Unknown argument type");
 
-     }
 
-     if (stream.length <= 0) {
 
-       throw new _util.InvalidPDFException("The PDF file is empty, i.e. its size is zero bytes.");
 
-     }
 
-     this.pdfManager = pdfManager;
 
-     this.stream = stream;
 
-     this.xref = new _obj.XRef(stream, pdfManager);
 
-     this.pdfFunctionFactory = new _function.PDFFunctionFactory({
 
-       xref: this.xref,
 
-       isEvalSupported: pdfManager.evaluatorOptions.isEvalSupported
 
-     });
 
-     this._pagePromises = [];
 
-   }
 
-   parse(recoveryMode) {
 
-     this.setup(recoveryMode);
 
-     const version = this.catalog.catDict.get("Version");
 
-     if ((0, _primitives.isName)(version)) {
 
-       this.pdfFormatVersion = version.name;
 
-     }
 
-     try {
 
-       this.acroForm = this.catalog.catDict.get("AcroForm");
 
-       if (this.acroForm) {
 
-         this.xfa = this.acroForm.get("XFA");
 
-         const fields = this.acroForm.get("Fields");
 
-         if ((!Array.isArray(fields) || fields.length === 0) && !this.xfa) {
 
-           this.acroForm = null;
 
-         }
 
-       }
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.info)("Cannot fetch AcroForm entry; assuming no AcroForms are present");
 
-       this.acroForm = null;
 
-     }
 
-     try {
 
-       const collection = this.catalog.catDict.get("Collection");
 
-       if ((0, _primitives.isDict)(collection) && collection.getKeys().length > 0) {
 
-         this.collection = collection;
 
-       }
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.info)("Cannot fetch Collection dictionary.");
 
-     }
 
-   }
 
-   get linearization() {
 
-     let linearization = null;
 
-     try {
 
-       linearization = _parser.Linearization.create(this.stream);
 
-     } catch (err) {
 
-       if (err instanceof _core_utils.MissingDataException) {
 
-         throw err;
 
-       }
 
-       (0, _util.info)(err);
 
-     }
 
-     return (0, _util.shadow)(this, "linearization", linearization);
 
-   }
 
-   get startXRef() {
 
-     const stream = this.stream;
 
-     let startXRef = 0;
 
-     if (this.linearization) {
 
-       stream.reset();
 
-       if (find(stream, ENDOBJ_SIGNATURE)) {
 
-         startXRef = stream.pos + 6 - stream.start;
 
-       }
 
-     } else {
 
-       const step = 1024;
 
-       const startXRefLength = STARTXREF_SIGNATURE.length;
 
-       let found = false,
 
-           pos = stream.end;
 
-       while (!found && pos > 0) {
 
-         pos -= step - startXRefLength;
 
-         if (pos < 0) {
 
-           pos = 0;
 
-         }
 
-         stream.pos = pos;
 
-         found = find(stream, STARTXREF_SIGNATURE, step, true);
 
-       }
 
-       if (found) {
 
-         stream.skip(9);
 
-         let ch;
 
-         do {
 
-           ch = stream.getByte();
 
-         } while ((0, _core_utils.isWhiteSpace)(ch));
 
-         let str = "";
 
-         while (ch >= 0x20 && ch <= 0x39) {
 
-           str += String.fromCharCode(ch);
 
-           ch = stream.getByte();
 
-         }
 
-         startXRef = parseInt(str, 10);
 
-         if (isNaN(startXRef)) {
 
-           startXRef = 0;
 
-         }
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "startXRef", startXRef);
 
-   }
 
-   checkHeader() {
 
-     const stream = this.stream;
 
-     stream.reset();
 
-     if (!find(stream, PDF_HEADER_SIGNATURE)) {
 
-       return;
 
-     }
 
-     stream.moveStart();
 
-     const MAX_PDF_VERSION_LENGTH = 12;
 
-     let version = "",
 
-         ch;
 
-     while ((ch = stream.getByte()) > 0x20) {
 
-       if (version.length >= MAX_PDF_VERSION_LENGTH) {
 
-         break;
 
-       }
 
-       version += String.fromCharCode(ch);
 
-     }
 
-     if (!this.pdfFormatVersion) {
 
-       this.pdfFormatVersion = version.substring(5);
 
-     }
 
-   }
 
-   parseStartXRef() {
 
-     this.xref.setStartXRef(this.startXRef);
 
-   }
 
-   setup(recoveryMode) {
 
-     this.xref.parse(recoveryMode);
 
-     this.catalog = new _obj.Catalog(this.pdfManager, this.xref);
 
-   }
 
-   get numPages() {
 
-     const linearization = this.linearization;
 
-     const num = linearization ? linearization.numPages : this.catalog.numPages;
 
-     return (0, _util.shadow)(this, "numPages", num);
 
-   }
 
-   get documentInfo() {
 
-     const DocumentInfoValidators = {
 
-       Title: _util.isString,
 
-       Author: _util.isString,
 
-       Subject: _util.isString,
 
-       Keywords: _util.isString,
 
-       Creator: _util.isString,
 
-       Producer: _util.isString,
 
-       CreationDate: _util.isString,
 
-       ModDate: _util.isString,
 
-       Trapped: _primitives.isName
 
-     };
 
-     let version = this.pdfFormatVersion;
 
-     if (typeof version !== "string" || !PDF_HEADER_VERSION_REGEXP.test(version)) {
 
-       (0, _util.warn)(`Invalid PDF header version number: ${version}`);
 
-       version = null;
 
-     }
 
-     const docInfo = {
 
-       PDFFormatVersion: version,
 
-       IsLinearized: !!this.linearization,
 
-       IsAcroFormPresent: !!this.acroForm,
 
-       IsXFAPresent: !!this.xfa,
 
-       IsCollectionPresent: !!this.collection
 
-     };
 
-     let infoDict;
 
-     try {
 
-       infoDict = this.xref.trailer.get("Info");
 
-     } catch (err) {
 
-       if (err instanceof _core_utils.MissingDataException) {
 
-         throw err;
 
-       }
 
-       (0, _util.info)("The document information dictionary is invalid.");
 
-     }
 
-     if ((0, _primitives.isDict)(infoDict)) {
 
-       for (const key of infoDict.getKeys()) {
 
-         const value = infoDict.get(key);
 
-         if (DocumentInfoValidators[key]) {
 
-           if (DocumentInfoValidators[key](value)) {
 
-             docInfo[key] = typeof value !== "string" ? value : (0, _util.stringToPDFString)(value);
 
-           } else {
 
-             (0, _util.info)(`Bad value in document info for "${key}".`);
 
-           }
 
-         } else if (typeof key === "string") {
 
-           let customValue;
 
-           if ((0, _util.isString)(value)) {
 
-             customValue = (0, _util.stringToPDFString)(value);
 
-           } else if ((0, _primitives.isName)(value) || (0, _util.isNum)(value) || (0, _util.isBool)(value)) {
 
-             customValue = value;
 
-           } else {
 
-             (0, _util.info)(`Unsupported value in document info for (custom) "${key}".`);
 
-             continue;
 
-           }
 
-           if (!docInfo["Custom"]) {
 
-             docInfo["Custom"] = Object.create(null);
 
-           }
 
-           docInfo["Custom"][key] = customValue;
 
-         }
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "documentInfo", docInfo);
 
-   }
 
-   get fingerprint() {
 
-     let hash;
 
-     const idArray = this.xref.trailer.get("ID");
 
-     if (Array.isArray(idArray) && idArray[0] && (0, _util.isString)(idArray[0]) && idArray[0] !== EMPTY_FINGERPRINT) {
 
-       hash = (0, _util.stringToBytes)(idArray[0]);
 
-     } else {
 
-       hash = (0, _crypto.calculateMD5)(this.stream.getByteRange(0, FINGERPRINT_FIRST_BYTES), 0, FINGERPRINT_FIRST_BYTES);
 
-     }
 
-     const fingerprintBuf = [];
 
-     for (let i = 0, ii = hash.length; i < ii; i++) {
 
-       const hex = hash[i].toString(16);
 
-       fingerprintBuf.push(hex.padStart(2, "0"));
 
-     }
 
-     return (0, _util.shadow)(this, "fingerprint", fingerprintBuf.join(""));
 
-   }
 
-   _getLinearizationPage(pageIndex) {
 
-     const {
 
-       catalog,
 
-       linearization
 
-     } = this;
 
-     (0, _util.assert)(linearization && linearization.pageFirst === pageIndex);
 
-     const ref = _primitives.Ref.get(linearization.objectNumberFirst, 0);
 
-     return this.xref.fetchAsync(ref).then(obj => {
 
-       if ((0, _primitives.isDict)(obj, "Page") || (0, _primitives.isDict)(obj) && !obj.has("Type") && obj.has("Contents")) {
 
-         if (ref && !catalog.pageKidsCountCache.has(ref)) {
 
-           catalog.pageKidsCountCache.put(ref, 1);
 
-         }
 
-         return [obj, ref];
 
-       }
 
-       throw new _util.FormatError("The Linearization dictionary doesn't point " + "to a valid Page dictionary.");
 
-     }).catch(reason => {
 
-       (0, _util.info)(reason);
 
-       return catalog.getPageDict(pageIndex);
 
-     });
 
-   }
 
-   getPage(pageIndex) {
 
-     if (this._pagePromises[pageIndex] !== undefined) {
 
-       return this._pagePromises[pageIndex];
 
-     }
 
-     const {
 
-       catalog,
 
-       linearization
 
-     } = this;
 
-     const promise = linearization && linearization.pageFirst === pageIndex ? this._getLinearizationPage(pageIndex) : catalog.getPageDict(pageIndex);
 
-     return this._pagePromises[pageIndex] = promise.then(([pageDict, ref]) => {
 
-       return new Page({
 
-         pdfManager: this.pdfManager,
 
-         xref: this.xref,
 
-         pageIndex,
 
-         pageDict,
 
-         ref,
 
-         fontCache: catalog.fontCache,
 
-         builtInCMapCache: catalog.builtInCMapCache,
 
-         pdfFunctionFactory: this.pdfFunctionFactory
 
-       });
 
-     });
 
-   }
 
-   checkFirstPage() {
 
-     return this.getPage(0).catch(async reason => {
 
-       if (reason instanceof _core_utils.XRefEntryException) {
 
-         this._pagePromises.length = 0;
 
-         await this.cleanup();
 
-         throw new _core_utils.XRefParseException();
 
-       }
 
-     });
 
-   }
 
-   fontFallback(id, handler) {
 
-     return this.catalog.fontFallback(id, handler);
 
-   }
 
-   async cleanup() {
 
-     return this.catalog ? this.catalog.cleanup() : (0, _primitives.clearPrimitiveCaches)();
 
-   }
 
- }
 
- exports.PDFDocument = PDFDocument;
 
- /***/ }),
 
- /* 9 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.FileSpec = exports.XRef = exports.ObjectLoader = exports.Catalog = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _parser = __w_pdfjs_require__(10);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _crypto = __w_pdfjs_require__(21);
 
- var _colorspace = __w_pdfjs_require__(22);
 
- function fetchDestination(dest) {
 
-   return (0, _primitives.isDict)(dest) ? dest.get("D") : dest;
 
- }
 
- class Catalog {
 
-   constructor(pdfManager, xref) {
 
-     this.pdfManager = pdfManager;
 
-     this.xref = xref;
 
-     this.catDict = xref.getCatalogObj();
 
-     if (!(0, _primitives.isDict)(this.catDict)) {
 
-       throw new _util.FormatError("Catalog object is not a dictionary.");
 
-     }
 
-     this.fontCache = new _primitives.RefSetCache();
 
-     this.builtInCMapCache = new Map();
 
-     this.pageKidsCountCache = new _primitives.RefSetCache();
 
-   }
 
-   get metadata() {
 
-     const streamRef = this.catDict.getRaw("Metadata");
 
-     if (!(0, _primitives.isRef)(streamRef)) {
 
-       return (0, _util.shadow)(this, "metadata", null);
 
-     }
 
-     const suppressEncryption = !(this.xref.encrypt && this.xref.encrypt.encryptMetadata);
 
-     const stream = this.xref.fetch(streamRef, suppressEncryption);
 
-     let metadata;
 
-     if (stream && (0, _primitives.isDict)(stream.dict)) {
 
-       const type = stream.dict.get("Type");
 
-       const subtype = stream.dict.get("Subtype");
 
-       if ((0, _primitives.isName)(type, "Metadata") && (0, _primitives.isName)(subtype, "XML")) {
 
-         try {
 
-           metadata = (0, _util.stringToUTF8String)((0, _util.bytesToString)(stream.getBytes()));
 
-         } catch (e) {
 
-           if (e instanceof _core_utils.MissingDataException) {
 
-             throw e;
 
-           }
 
-           (0, _util.info)("Skipping invalid metadata.");
 
-         }
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "metadata", metadata);
 
-   }
 
-   get toplevelPagesDict() {
 
-     const pagesObj = this.catDict.get("Pages");
 
-     if (!(0, _primitives.isDict)(pagesObj)) {
 
-       throw new _util.FormatError("Invalid top-level pages dictionary.");
 
-     }
 
-     return (0, _util.shadow)(this, "toplevelPagesDict", pagesObj);
 
-   }
 
-   get documentOutline() {
 
-     let obj = null;
 
-     try {
 
-       obj = this._readDocumentOutline();
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.warn)("Unable to read document outline.");
 
-     }
 
-     return (0, _util.shadow)(this, "documentOutline", obj);
 
-   }
 
-   _readDocumentOutline() {
 
-     let obj = this.catDict.get("Outlines");
 
-     if (!(0, _primitives.isDict)(obj)) {
 
-       return null;
 
-     }
 
-     obj = obj.getRaw("First");
 
-     if (!(0, _primitives.isRef)(obj)) {
 
-       return null;
 
-     }
 
-     const root = {
 
-       items: []
 
-     };
 
-     const queue = [{
 
-       obj,
 
-       parent: root
 
-     }];
 
-     const processed = new _primitives.RefSet();
 
-     processed.put(obj);
 
-     const xref = this.xref,
 
-           blackColor = new Uint8ClampedArray(3);
 
-     while (queue.length > 0) {
 
-       const i = queue.shift();
 
-       const outlineDict = xref.fetchIfRef(i.obj);
 
-       if (outlineDict === null) {
 
-         continue;
 
-       }
 
-       if (!outlineDict.has("Title")) {
 
-         throw new _util.FormatError("Invalid outline item encountered.");
 
-       }
 
-       const data = {
 
-         url: null,
 
-         dest: null
 
-       };
 
-       Catalog.parseDestDictionary({
 
-         destDict: outlineDict,
 
-         resultObj: data,
 
-         docBaseUrl: this.pdfManager.docBaseUrl
 
-       });
 
-       const title = outlineDict.get("Title");
 
-       const flags = outlineDict.get("F") || 0;
 
-       const color = outlineDict.getArray("C");
 
-       const count = outlineDict.get("Count");
 
-       let rgbColor = blackColor;
 
-       if (Array.isArray(color) && color.length === 3 && (color[0] !== 0 || color[1] !== 0 || color[2] !== 0)) {
 
-         rgbColor = _colorspace.ColorSpace.singletons.rgb.getRgb(color, 0);
 
-       }
 
-       const outlineItem = {
 
-         dest: data.dest,
 
-         url: data.url,
 
-         unsafeUrl: data.unsafeUrl,
 
-         newWindow: data.newWindow,
 
-         title: (0, _util.stringToPDFString)(title),
 
-         color: rgbColor,
 
-         count: Number.isInteger(count) ? count : undefined,
 
-         bold: !!(flags & 2),
 
-         italic: !!(flags & 1),
 
-         items: []
 
-       };
 
-       i.parent.items.push(outlineItem);
 
-       obj = outlineDict.getRaw("First");
 
-       if ((0, _primitives.isRef)(obj) && !processed.has(obj)) {
 
-         queue.push({
 
-           obj,
 
-           parent: outlineItem
 
-         });
 
-         processed.put(obj);
 
-       }
 
-       obj = outlineDict.getRaw("Next");
 
-       if ((0, _primitives.isRef)(obj) && !processed.has(obj)) {
 
-         queue.push({
 
-           obj,
 
-           parent: i.parent
 
-         });
 
-         processed.put(obj);
 
-       }
 
-     }
 
-     return root.items.length > 0 ? root.items : null;
 
-   }
 
-   get permissions() {
 
-     let permissions = null;
 
-     try {
 
-       permissions = this._readPermissions();
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.warn)("Unable to read permissions.");
 
-     }
 
-     return (0, _util.shadow)(this, "permissions", permissions);
 
-   }
 
-   _readPermissions() {
 
-     const encrypt = this.xref.trailer.get("Encrypt");
 
-     if (!(0, _primitives.isDict)(encrypt)) {
 
-       return null;
 
-     }
 
-     let flags = encrypt.get("P");
 
-     if (!(0, _util.isNum)(flags)) {
 
-       return null;
 
-     }
 
-     flags += 2 ** 32;
 
-     const permissions = [];
 
-     for (const key in _util.PermissionFlag) {
 
-       const value = _util.PermissionFlag[key];
 
-       if (flags & value) {
 
-         permissions.push(value);
 
-       }
 
-     }
 
-     return permissions;
 
-   }
 
-   get numPages() {
 
-     const obj = this.toplevelPagesDict.get("Count");
 
-     if (!Number.isInteger(obj)) {
 
-       throw new _util.FormatError("Page count in top-level pages dictionary is not an integer.");
 
-     }
 
-     return (0, _util.shadow)(this, "numPages", obj);
 
-   }
 
-   get destinations() {
 
-     const obj = this._readDests(),
 
-           dests = Object.create(null);
 
-     if (obj instanceof NameTree) {
 
-       const names = obj.getAll();
 
-       for (const name in names) {
 
-         dests[name] = fetchDestination(names[name]);
 
-       }
 
-     } else if (obj instanceof _primitives.Dict) {
 
-       obj.forEach(function (key, value) {
 
-         if (value) {
 
-           dests[key] = fetchDestination(value);
 
-         }
 
-       });
 
-     }
 
-     return (0, _util.shadow)(this, "destinations", dests);
 
-   }
 
-   getDestination(destinationId) {
 
-     const obj = this._readDests();
 
-     if (obj instanceof NameTree || obj instanceof _primitives.Dict) {
 
-       return fetchDestination(obj.get(destinationId) || null);
 
-     }
 
-     return null;
 
-   }
 
-   _readDests() {
 
-     const obj = this.catDict.get("Names");
 
-     if (obj && obj.has("Dests")) {
 
-       return new NameTree(obj.getRaw("Dests"), this.xref);
 
-     } else if (this.catDict.has("Dests")) {
 
-       return this.catDict.get("Dests");
 
-     }
 
-     return undefined;
 
-   }
 
-   get pageLabels() {
 
-     let obj = null;
 
-     try {
 
-       obj = this._readPageLabels();
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.warn)("Unable to read page labels.");
 
-     }
 
-     return (0, _util.shadow)(this, "pageLabels", obj);
 
-   }
 
-   _readPageLabels() {
 
-     const obj = this.catDict.getRaw("PageLabels");
 
-     if (!obj) {
 
-       return null;
 
-     }
 
-     const pageLabels = new Array(this.numPages);
 
-     let style = null,
 
-         prefix = "";
 
-     const numberTree = new NumberTree(obj, this.xref);
 
-     const nums = numberTree.getAll();
 
-     let currentLabel = "",
 
-         currentIndex = 1;
 
-     for (let i = 0, ii = this.numPages; i < ii; i++) {
 
-       if (i in nums) {
 
-         const labelDict = nums[i];
 
-         if (!(0, _primitives.isDict)(labelDict)) {
 
-           throw new _util.FormatError("PageLabel is not a dictionary.");
 
-         }
 
-         if (labelDict.has("Type") && !(0, _primitives.isName)(labelDict.get("Type"), "PageLabel")) {
 
-           throw new _util.FormatError("Invalid type in PageLabel dictionary.");
 
-         }
 
-         if (labelDict.has("S")) {
 
-           const s = labelDict.get("S");
 
-           if (!(0, _primitives.isName)(s)) {
 
-             throw new _util.FormatError("Invalid style in PageLabel dictionary.");
 
-           }
 
-           style = s.name;
 
-         } else {
 
-           style = null;
 
-         }
 
-         if (labelDict.has("P")) {
 
-           const p = labelDict.get("P");
 
-           if (!(0, _util.isString)(p)) {
 
-             throw new _util.FormatError("Invalid prefix in PageLabel dictionary.");
 
-           }
 
-           prefix = (0, _util.stringToPDFString)(p);
 
-         } else {
 
-           prefix = "";
 
-         }
 
-         if (labelDict.has("St")) {
 
-           const st = labelDict.get("St");
 
-           if (!(Number.isInteger(st) && st >= 1)) {
 
-             throw new _util.FormatError("Invalid start in PageLabel dictionary.");
 
-           }
 
-           currentIndex = st;
 
-         } else {
 
-           currentIndex = 1;
 
-         }
 
-       }
 
-       switch (style) {
 
-         case "D":
 
-           currentLabel = currentIndex;
 
-           break;
 
-         case "R":
 
-         case "r":
 
-           currentLabel = (0, _core_utils.toRomanNumerals)(currentIndex, style === "r");
 
-           break;
 
-         case "A":
 
-         case "a":
 
-           const LIMIT = 26;
 
-           const A_UPPER_CASE = 0x41,
 
-                 A_LOWER_CASE = 0x61;
 
-           const baseCharCode = style === "a" ? A_LOWER_CASE : A_UPPER_CASE;
 
-           const letterIndex = currentIndex - 1;
 
-           const character = String.fromCharCode(baseCharCode + letterIndex % LIMIT);
 
-           const charBuf = [];
 
-           for (let j = 0, jj = letterIndex / LIMIT | 0; j <= jj; j++) {
 
-             charBuf.push(character);
 
-           }
 
-           currentLabel = charBuf.join("");
 
-           break;
 
-         default:
 
-           if (style) {
 
-             throw new _util.FormatError(`Invalid style "${style}" in PageLabel dictionary.`);
 
-           }
 
-           currentLabel = "";
 
-       }
 
-       pageLabels[i] = prefix + currentLabel;
 
-       currentIndex++;
 
-     }
 
-     return pageLabels;
 
-   }
 
-   get pageLayout() {
 
-     const obj = this.catDict.get("PageLayout");
 
-     let pageLayout = "";
 
-     if ((0, _primitives.isName)(obj)) {
 
-       switch (obj.name) {
 
-         case "SinglePage":
 
-         case "OneColumn":
 
-         case "TwoColumnLeft":
 
-         case "TwoColumnRight":
 
-         case "TwoPageLeft":
 
-         case "TwoPageRight":
 
-           pageLayout = obj.name;
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "pageLayout", pageLayout);
 
-   }
 
-   get pageMode() {
 
-     const obj = this.catDict.get("PageMode");
 
-     let pageMode = "UseNone";
 
-     if ((0, _primitives.isName)(obj)) {
 
-       switch (obj.name) {
 
-         case "UseNone":
 
-         case "UseOutlines":
 
-         case "UseThumbs":
 
-         case "FullScreen":
 
-         case "UseOC":
 
-         case "UseAttachments":
 
-           pageMode = obj.name;
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "pageMode", pageMode);
 
-   }
 
-   get viewerPreferences() {
 
-     const ViewerPreferencesValidators = {
 
-       HideToolbar: _util.isBool,
 
-       HideMenubar: _util.isBool,
 
-       HideWindowUI: _util.isBool,
 
-       FitWindow: _util.isBool,
 
-       CenterWindow: _util.isBool,
 
-       DisplayDocTitle: _util.isBool,
 
-       NonFullScreenPageMode: _primitives.isName,
 
-       Direction: _primitives.isName,
 
-       ViewArea: _primitives.isName,
 
-       ViewClip: _primitives.isName,
 
-       PrintArea: _primitives.isName,
 
-       PrintClip: _primitives.isName,
 
-       PrintScaling: _primitives.isName,
 
-       Duplex: _primitives.isName,
 
-       PickTrayByPDFSize: _util.isBool,
 
-       PrintPageRange: Array.isArray,
 
-       NumCopies: Number.isInteger
 
-     };
 
-     const obj = this.catDict.get("ViewerPreferences");
 
-     const prefs = Object.create(null);
 
-     if ((0, _primitives.isDict)(obj)) {
 
-       for (const key in ViewerPreferencesValidators) {
 
-         if (!obj.has(key)) {
 
-           continue;
 
-         }
 
-         const value = obj.get(key);
 
-         if (!ViewerPreferencesValidators[key](value)) {
 
-           (0, _util.info)(`Bad value in ViewerPreferences for "${key}".`);
 
-           continue;
 
-         }
 
-         let prefValue;
 
-         switch (key) {
 
-           case "NonFullScreenPageMode":
 
-             switch (value.name) {
 
-               case "UseNone":
 
-               case "UseOutlines":
 
-               case "UseThumbs":
 
-               case "UseOC":
 
-                 prefValue = value.name;
 
-                 break;
 
-               default:
 
-                 prefValue = "UseNone";
 
-             }
 
-             break;
 
-           case "Direction":
 
-             switch (value.name) {
 
-               case "L2R":
 
-               case "R2L":
 
-                 prefValue = value.name;
 
-                 break;
 
-               default:
 
-                 prefValue = "L2R";
 
-             }
 
-             break;
 
-           case "ViewArea":
 
-           case "ViewClip":
 
-           case "PrintArea":
 
-           case "PrintClip":
 
-             switch (value.name) {
 
-               case "MediaBox":
 
-               case "CropBox":
 
-               case "BleedBox":
 
-               case "TrimBox":
 
-               case "ArtBox":
 
-                 prefValue = value.name;
 
-                 break;
 
-               default:
 
-                 prefValue = "CropBox";
 
-             }
 
-             break;
 
-           case "PrintScaling":
 
-             switch (value.name) {
 
-               case "None":
 
-               case "AppDefault":
 
-                 prefValue = value.name;
 
-                 break;
 
-               default:
 
-                 prefValue = "AppDefault";
 
-             }
 
-             break;
 
-           case "Duplex":
 
-             switch (value.name) {
 
-               case "Simplex":
 
-               case "DuplexFlipShortEdge":
 
-               case "DuplexFlipLongEdge":
 
-                 prefValue = value.name;
 
-                 break;
 
-               default:
 
-                 prefValue = "None";
 
-             }
 
-             break;
 
-           case "PrintPageRange":
 
-             const length = value.length;
 
-             if (length % 2 !== 0) {
 
-               break;
 
-             }
 
-             const isValid = value.every((page, i, arr) => {
 
-               return Number.isInteger(page) && page > 0 && (i === 0 || page >= arr[i - 1]) && page <= this.numPages;
 
-             });
 
-             if (isValid) {
 
-               prefValue = value;
 
-             }
 
-             break;
 
-           case "NumCopies":
 
-             if (value > 0) {
 
-               prefValue = value;
 
-             }
 
-             break;
 
-           default:
 
-             (0, _util.assert)(typeof value === "boolean");
 
-             prefValue = value;
 
-         }
 
-         if (prefValue !== undefined) {
 
-           prefs[key] = prefValue;
 
-         } else {
 
-           (0, _util.info)(`Bad value in ViewerPreferences for "${key}".`);
 
-         }
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "viewerPreferences", prefs);
 
-   }
 
-   get openAction() {
 
-     const obj = this.catDict.get("OpenAction");
 
-     let openAction = null;
 
-     if ((0, _primitives.isDict)(obj)) {
 
-       const destDict = new _primitives.Dict(this.xref);
 
-       destDict.set("A", obj);
 
-       const resultObj = {
 
-         url: null,
 
-         dest: null,
 
-         action: null
 
-       };
 
-       Catalog.parseDestDictionary({
 
-         destDict,
 
-         resultObj
 
-       });
 
-       if (Array.isArray(resultObj.dest)) {
 
-         if (!openAction) {
 
-           openAction = Object.create(null);
 
-         }
 
-         openAction.dest = resultObj.dest;
 
-       } else if (resultObj.action) {
 
-         if (!openAction) {
 
-           openAction = Object.create(null);
 
-         }
 
-         openAction.action = resultObj.action;
 
-       }
 
-     } else if (Array.isArray(obj)) {
 
-       if (!openAction) {
 
-         openAction = Object.create(null);
 
-       }
 
-       openAction.dest = obj;
 
-     }
 
-     return (0, _util.shadow)(this, "openAction", openAction);
 
-   }
 
-   get attachments() {
 
-     const obj = this.catDict.get("Names");
 
-     let attachments = null;
 
-     if (obj && obj.has("EmbeddedFiles")) {
 
-       const nameTree = new NameTree(obj.getRaw("EmbeddedFiles"), this.xref);
 
-       const names = nameTree.getAll();
 
-       for (const name in names) {
 
-         const fs = new FileSpec(names[name], this.xref);
 
-         if (!attachments) {
 
-           attachments = Object.create(null);
 
-         }
 
-         attachments[(0, _util.stringToPDFString)(name)] = fs.serializable;
 
-       }
 
-     }
 
-     return (0, _util.shadow)(this, "attachments", attachments);
 
-   }
 
-   get javaScript() {
 
-     const obj = this.catDict.get("Names");
 
-     let javaScript = null;
 
-     function appendIfJavaScriptDict(jsDict) {
 
-       const type = jsDict.get("S");
 
-       if (!(0, _primitives.isName)(type, "JavaScript")) {
 
-         return;
 
-       }
 
-       let js = jsDict.get("JS");
 
-       if ((0, _primitives.isStream)(js)) {
 
-         js = (0, _util.bytesToString)(js.getBytes());
 
-       } else if (!(0, _util.isString)(js)) {
 
-         return;
 
-       }
 
-       if (!javaScript) {
 
-         javaScript = [];
 
-       }
 
-       javaScript.push((0, _util.stringToPDFString)(js));
 
-     }
 
-     if (obj && obj.has("JavaScript")) {
 
-       const nameTree = new NameTree(obj.getRaw("JavaScript"), this.xref);
 
-       const names = nameTree.getAll();
 
-       for (const name in names) {
 
-         const jsDict = names[name];
 
-         if ((0, _primitives.isDict)(jsDict)) {
 
-           appendIfJavaScriptDict(jsDict);
 
-         }
 
-       }
 
-     }
 
-     const openAction = this.catDict.get("OpenAction");
 
-     if ((0, _primitives.isDict)(openAction) && (0, _primitives.isName)(openAction.get("S"), "JavaScript")) {
 
-       appendIfJavaScriptDict(openAction);
 
-     }
 
-     return (0, _util.shadow)(this, "javaScript", javaScript);
 
-   }
 
-   fontFallback(id, handler) {
 
-     const promises = [];
 
-     this.fontCache.forEach(function (promise) {
 
-       promises.push(promise);
 
-     });
 
-     return Promise.all(promises).then(translatedFonts => {
 
-       for (const translatedFont of translatedFonts) {
 
-         if (translatedFont.loadedName === id) {
 
-           translatedFont.fallback(handler);
 
-           return;
 
-         }
 
-       }
 
-     });
 
-   }
 
-   cleanup() {
 
-     (0, _primitives.clearPrimitiveCaches)();
 
-     this.pageKidsCountCache.clear();
 
-     const promises = [];
 
-     this.fontCache.forEach(function (promise) {
 
-       promises.push(promise);
 
-     });
 
-     return Promise.all(promises).then(translatedFonts => {
 
-       for (const {
 
-         dict
 
-       } of translatedFonts) {
 
-         delete dict.translated;
 
-       }
 
-       this.fontCache.clear();
 
-       this.builtInCMapCache.clear();
 
-     });
 
-   }
 
-   getPageDict(pageIndex) {
 
-     const capability = (0, _util.createPromiseCapability)();
 
-     const nodesToVisit = [this.catDict.getRaw("Pages")];
 
-     const visitedNodes = new _primitives.RefSet();
 
-     const xref = this.xref,
 
-           pageKidsCountCache = this.pageKidsCountCache;
 
-     let count,
 
-         currentPageIndex = 0;
 
-     function next() {
 
-       while (nodesToVisit.length) {
 
-         const currentNode = nodesToVisit.pop();
 
-         if ((0, _primitives.isRef)(currentNode)) {
 
-           count = pageKidsCountCache.get(currentNode);
 
-           if (count > 0 && currentPageIndex + count < pageIndex) {
 
-             currentPageIndex += count;
 
-             continue;
 
-           }
 
-           if (visitedNodes.has(currentNode)) {
 
-             capability.reject(new _util.FormatError("Pages tree contains circular reference."));
 
-             return;
 
-           }
 
-           visitedNodes.put(currentNode);
 
-           xref.fetchAsync(currentNode).then(function (obj) {
 
-             if ((0, _primitives.isDict)(obj, "Page") || (0, _primitives.isDict)(obj) && !obj.has("Kids")) {
 
-               if (pageIndex === currentPageIndex) {
 
-                 if (currentNode && !pageKidsCountCache.has(currentNode)) {
 
-                   pageKidsCountCache.put(currentNode, 1);
 
-                 }
 
-                 capability.resolve([obj, currentNode]);
 
-               } else {
 
-                 currentPageIndex++;
 
-                 next();
 
-               }
 
-               return;
 
-             }
 
-             nodesToVisit.push(obj);
 
-             next();
 
-           }, capability.reject);
 
-           return;
 
-         }
 
-         if (!(0, _primitives.isDict)(currentNode)) {
 
-           capability.reject(new _util.FormatError("Page dictionary kid reference points to wrong type of object."));
 
-           return;
 
-         }
 
-         count = currentNode.get("Count");
 
-         if (Number.isInteger(count) && count >= 0) {
 
-           const objId = currentNode.objId;
 
-           if (objId && !pageKidsCountCache.has(objId)) {
 
-             pageKidsCountCache.put(objId, count);
 
-           }
 
-           if (currentPageIndex + count <= pageIndex) {
 
-             currentPageIndex += count;
 
-             continue;
 
-           }
 
-         }
 
-         const kids = currentNode.get("Kids");
 
-         if (!Array.isArray(kids)) {
 
-           if ((0, _primitives.isName)(currentNode.get("Type"), "Page") || !currentNode.has("Type") && currentNode.has("Contents")) {
 
-             if (currentPageIndex === pageIndex) {
 
-               capability.resolve([currentNode, null]);
 
-               return;
 
-             }
 
-             currentPageIndex++;
 
-             continue;
 
-           }
 
-           capability.reject(new _util.FormatError("Page dictionary kids object is not an array."));
 
-           return;
 
-         }
 
-         for (let last = kids.length - 1; last >= 0; last--) {
 
-           nodesToVisit.push(kids[last]);
 
-         }
 
-       }
 
-       capability.reject(new Error(`Page index ${pageIndex} not found.`));
 
-     }
 
-     next();
 
-     return capability.promise;
 
-   }
 
-   getPageIndex(pageRef) {
 
-     const xref = this.xref;
 
-     function pagesBeforeRef(kidRef) {
 
-       let total = 0,
 
-           parentRef;
 
-       return xref.fetchAsync(kidRef).then(function (node) {
 
-         if ((0, _primitives.isRefsEqual)(kidRef, pageRef) && !(0, _primitives.isDict)(node, "Page") && !((0, _primitives.isDict)(node) && !node.has("Type") && node.has("Contents"))) {
 
-           throw new _util.FormatError("The reference does not point to a /Page dictionary.");
 
-         }
 
-         if (!node) {
 
-           return null;
 
-         }
 
-         if (!(0, _primitives.isDict)(node)) {
 
-           throw new _util.FormatError("Node must be a dictionary.");
 
-         }
 
-         parentRef = node.getRaw("Parent");
 
-         return node.getAsync("Parent");
 
-       }).then(function (parent) {
 
-         if (!parent) {
 
-           return null;
 
-         }
 
-         if (!(0, _primitives.isDict)(parent)) {
 
-           throw new _util.FormatError("Parent must be a dictionary.");
 
-         }
 
-         return parent.getAsync("Kids");
 
-       }).then(function (kids) {
 
-         if (!kids) {
 
-           return null;
 
-         }
 
-         const kidPromises = [];
 
-         let found = false;
 
-         for (let i = 0, ii = kids.length; i < ii; i++) {
 
-           const kid = kids[i];
 
-           if (!(0, _primitives.isRef)(kid)) {
 
-             throw new _util.FormatError("Kid must be a reference.");
 
-           }
 
-           if ((0, _primitives.isRefsEqual)(kid, kidRef)) {
 
-             found = true;
 
-             break;
 
-           }
 
-           kidPromises.push(xref.fetchAsync(kid).then(function (kid) {
 
-             if (!(0, _primitives.isDict)(kid)) {
 
-               throw new _util.FormatError("Kid node must be a dictionary.");
 
-             }
 
-             if (kid.has("Count")) {
 
-               total += kid.get("Count");
 
-             } else {
 
-               total++;
 
-             }
 
-           }));
 
-         }
 
-         if (!found) {
 
-           throw new _util.FormatError("Kid reference not found in parent's kids.");
 
-         }
 
-         return Promise.all(kidPromises).then(function () {
 
-           return [total, parentRef];
 
-         });
 
-       });
 
-     }
 
-     let total = 0;
 
-     function next(ref) {
 
-       return pagesBeforeRef(ref).then(function (args) {
 
-         if (!args) {
 
-           return total;
 
-         }
 
-         const [count, parentRef] = args;
 
-         total += count;
 
-         return next(parentRef);
 
-       });
 
-     }
 
-     return next(pageRef);
 
-   }
 
-   static parseDestDictionary(params) {
 
-     function addDefaultProtocolToUrl(url) {
 
-       return url.startsWith("www.") ? `http://${url}` : url;
 
-     }
 
-     function tryConvertUrlEncoding(url) {
 
-       try {
 
-         return (0, _util.stringToUTF8String)(url);
 
-       } catch (e) {
 
-         return url;
 
-       }
 
-     }
 
-     const destDict = params.destDict;
 
-     if (!(0, _primitives.isDict)(destDict)) {
 
-       (0, _util.warn)("parseDestDictionary: `destDict` must be a dictionary.");
 
-       return;
 
-     }
 
-     const resultObj = params.resultObj;
 
-     if (typeof resultObj !== "object") {
 
-       (0, _util.warn)("parseDestDictionary: `resultObj` must be an object.");
 
-       return;
 
-     }
 
-     const docBaseUrl = params.docBaseUrl || null;
 
-     let action = destDict.get("A"),
 
-         url,
 
-         dest;
 
-     if (!(0, _primitives.isDict)(action) && destDict.has("Dest")) {
 
-       action = destDict.get("Dest");
 
-     }
 
-     if ((0, _primitives.isDict)(action)) {
 
-       const actionType = action.get("S");
 
-       if (!(0, _primitives.isName)(actionType)) {
 
-         (0, _util.warn)("parseDestDictionary: Invalid type in Action dictionary.");
 
-         return;
 
-       }
 
-       const actionName = actionType.name;
 
-       switch (actionName) {
 
-         case "URI":
 
-           url = action.get("URI");
 
-           if ((0, _primitives.isName)(url)) {
 
-             url = "/" + url.name;
 
-           } else if ((0, _util.isString)(url)) {
 
-             url = addDefaultProtocolToUrl(url);
 
-           }
 
-           break;
 
-         case "GoTo":
 
-           dest = action.get("D");
 
-           break;
 
-         case "Launch":
 
-         case "GoToR":
 
-           const urlDict = action.get("F");
 
-           if ((0, _primitives.isDict)(urlDict)) {
 
-             url = urlDict.get("F") || null;
 
-           } else if ((0, _util.isString)(urlDict)) {
 
-             url = urlDict;
 
-           }
 
-           let remoteDest = action.get("D");
 
-           if (remoteDest) {
 
-             if ((0, _primitives.isName)(remoteDest)) {
 
-               remoteDest = remoteDest.name;
 
-             }
 
-             if ((0, _util.isString)(url)) {
 
-               const baseUrl = url.split("#")[0];
 
-               if ((0, _util.isString)(remoteDest)) {
 
-                 url = baseUrl + "#" + remoteDest;
 
-               } else if (Array.isArray(remoteDest)) {
 
-                 url = baseUrl + "#" + JSON.stringify(remoteDest);
 
-               }
 
-             }
 
-           }
 
-           const newWindow = action.get("NewWindow");
 
-           if ((0, _util.isBool)(newWindow)) {
 
-             resultObj.newWindow = newWindow;
 
-           }
 
-           break;
 
-         case "Named":
 
-           const namedAction = action.get("N");
 
-           if ((0, _primitives.isName)(namedAction)) {
 
-             resultObj.action = namedAction.name;
 
-           }
 
-           break;
 
-         case "JavaScript":
 
-           const jsAction = action.get("JS");
 
-           let js;
 
-           if ((0, _primitives.isStream)(jsAction)) {
 
-             js = (0, _util.bytesToString)(jsAction.getBytes());
 
-           } else if ((0, _util.isString)(jsAction)) {
 
-             js = jsAction;
 
-           }
 
-           if (js) {
 
-             const URL_OPEN_METHODS = ["app.launchURL", "window.open"];
 
-             const regex = new RegExp("^\\s*(" + URL_OPEN_METHODS.join("|").split(".").join("\\.") + ")\\((?:'|\")([^'\"]*)(?:'|\")(?:,\\s*(\\w+)\\)|\\))", "i");
 
-             const jsUrl = regex.exec((0, _util.stringToPDFString)(js));
 
-             if (jsUrl && jsUrl[2]) {
 
-               url = jsUrl[2];
 
-               if (jsUrl[3] === "true" && jsUrl[1] === "app.launchURL") {
 
-                 resultObj.newWindow = true;
 
-               }
 
-               break;
 
-             }
 
-           }
 
-         default:
 
-           (0, _util.warn)(`parseDestDictionary: unsupported action type "${actionName}".`);
 
-           break;
 
-       }
 
-     } else if (destDict.has("Dest")) {
 
-       dest = destDict.get("Dest");
 
-     }
 
-     if ((0, _util.isString)(url)) {
 
-       url = tryConvertUrlEncoding(url);
 
-       const absoluteUrl = (0, _util.createValidAbsoluteUrl)(url, docBaseUrl);
 
-       if (absoluteUrl) {
 
-         resultObj.url = absoluteUrl.href;
 
-       }
 
-       resultObj.unsafeUrl = url;
 
-     }
 
-     if (dest) {
 
-       if ((0, _primitives.isName)(dest)) {
 
-         dest = dest.name;
 
-       }
 
-       if ((0, _util.isString)(dest) || Array.isArray(dest)) {
 
-         resultObj.dest = dest;
 
-       }
 
-     }
 
-   }
 
- }
 
- exports.Catalog = Catalog;
 
- var XRef = function XRefClosure() {
 
-   function XRef(stream, pdfManager) {
 
-     this.stream = stream;
 
-     this.pdfManager = pdfManager;
 
-     this.entries = [];
 
-     this.xrefstms = Object.create(null);
 
-     this._cacheMap = new Map();
 
-     this.stats = {
 
-       streamTypes: Object.create(null),
 
-       fontTypes: Object.create(null)
 
-     };
 
-   }
 
-   XRef.prototype = {
 
-     setStartXRef: function XRef_setStartXRef(startXRef) {
 
-       this.startXRefQueue = [startXRef];
 
-     },
 
-     parse: function XRef_parse(recoveryMode) {
 
-       var trailerDict;
 
-       if (!recoveryMode) {
 
-         trailerDict = this.readXRef();
 
-       } else {
 
-         (0, _util.warn)("Indexing all PDF objects");
 
-         trailerDict = this.indexObjects();
 
-       }
 
-       trailerDict.assignXref(this);
 
-       this.trailer = trailerDict;
 
-       let encrypt;
 
-       try {
 
-         encrypt = trailerDict.get("Encrypt");
 
-       } catch (ex) {
 
-         if (ex instanceof _core_utils.MissingDataException) {
 
-           throw ex;
 
-         }
 
-         (0, _util.warn)(`XRef.parse - Invalid "Encrypt" reference: "${ex}".`);
 
-       }
 
-       if ((0, _primitives.isDict)(encrypt)) {
 
-         var ids = trailerDict.get("ID");
 
-         var fileId = ids && ids.length ? ids[0] : "";
 
-         encrypt.suppressEncryption = true;
 
-         this.encrypt = new _crypto.CipherTransformFactory(encrypt, fileId, this.pdfManager.password);
 
-       }
 
-       let root;
 
-       try {
 
-         root = trailerDict.get("Root");
 
-       } catch (ex) {
 
-         if (ex instanceof _core_utils.MissingDataException) {
 
-           throw ex;
 
-         }
 
-         (0, _util.warn)(`XRef.parse - Invalid "Root" reference: "${ex}".`);
 
-       }
 
-       if ((0, _primitives.isDict)(root) && root.has("Pages")) {
 
-         this.root = root;
 
-       } else {
 
-         if (!recoveryMode) {
 
-           throw new _core_utils.XRefParseException();
 
-         }
 
-         throw new _util.FormatError("Invalid root reference");
 
-       }
 
-     },
 
-     processXRefTable: function XRef_processXRefTable(parser) {
 
-       if (!("tableState" in this)) {
 
-         this.tableState = {
 
-           entryNum: 0,
 
-           streamPos: parser.lexer.stream.pos,
 
-           parserBuf1: parser.buf1,
 
-           parserBuf2: parser.buf2
 
-         };
 
-       }
 
-       var obj = this.readXRefTable(parser);
 
-       if (!(0, _primitives.isCmd)(obj, "trailer")) {
 
-         throw new _util.FormatError("Invalid XRef table: could not find trailer dictionary");
 
-       }
 
-       var dict = parser.getObj();
 
-       if (!(0, _primitives.isDict)(dict) && dict.dict) {
 
-         dict = dict.dict;
 
-       }
 
-       if (!(0, _primitives.isDict)(dict)) {
 
-         throw new _util.FormatError("Invalid XRef table: could not parse trailer dictionary");
 
-       }
 
-       delete this.tableState;
 
-       return dict;
 
-     },
 
-     readXRefTable: function XRef_readXRefTable(parser) {
 
-       var stream = parser.lexer.stream;
 
-       var tableState = this.tableState;
 
-       stream.pos = tableState.streamPos;
 
-       parser.buf1 = tableState.parserBuf1;
 
-       parser.buf2 = tableState.parserBuf2;
 
-       var obj;
 
-       while (true) {
 
-         if (!("firstEntryNum" in tableState) || !("entryCount" in tableState)) {
 
-           if ((0, _primitives.isCmd)(obj = parser.getObj(), "trailer")) {
 
-             break;
 
-           }
 
-           tableState.firstEntryNum = obj;
 
-           tableState.entryCount = parser.getObj();
 
-         }
 
-         var first = tableState.firstEntryNum;
 
-         var count = tableState.entryCount;
 
-         if (!Number.isInteger(first) || !Number.isInteger(count)) {
 
-           throw new _util.FormatError("Invalid XRef table: wrong types in subsection header");
 
-         }
 
-         for (var i = tableState.entryNum; i < count; i++) {
 
-           tableState.streamPos = stream.pos;
 
-           tableState.entryNum = i;
 
-           tableState.parserBuf1 = parser.buf1;
 
-           tableState.parserBuf2 = parser.buf2;
 
-           var entry = {};
 
-           entry.offset = parser.getObj();
 
-           entry.gen = parser.getObj();
 
-           var type = parser.getObj();
 
-           if (type instanceof _primitives.Cmd) {
 
-             switch (type.cmd) {
 
-               case "f":
 
-                 entry.free = true;
 
-                 break;
 
-               case "n":
 
-                 entry.uncompressed = true;
 
-                 break;
 
-             }
 
-           }
 
-           if (!Number.isInteger(entry.offset) || !Number.isInteger(entry.gen) || !(entry.free || entry.uncompressed)) {
 
-             throw new _util.FormatError(`Invalid entry in XRef subsection: ${first}, ${count}`);
 
-           }
 
-           if (i === 0 && entry.free && first === 1) {
 
-             first = 0;
 
-           }
 
-           if (!this.entries[i + first]) {
 
-             this.entries[i + first] = entry;
 
-           }
 
-         }
 
-         tableState.entryNum = 0;
 
-         tableState.streamPos = stream.pos;
 
-         tableState.parserBuf1 = parser.buf1;
 
-         tableState.parserBuf2 = parser.buf2;
 
-         delete tableState.firstEntryNum;
 
-         delete tableState.entryCount;
 
-       }
 
-       if (this.entries[0] && !this.entries[0].free) {
 
-         throw new _util.FormatError("Invalid XRef table: unexpected first object");
 
-       }
 
-       return obj;
 
-     },
 
-     processXRefStream: function XRef_processXRefStream(stream) {
 
-       if (!("streamState" in this)) {
 
-         var streamParameters = stream.dict;
 
-         var byteWidths = streamParameters.get("W");
 
-         var range = streamParameters.get("Index");
 
-         if (!range) {
 
-           range = [0, streamParameters.get("Size")];
 
-         }
 
-         this.streamState = {
 
-           entryRanges: range,
 
-           byteWidths,
 
-           entryNum: 0,
 
-           streamPos: stream.pos
 
-         };
 
-       }
 
-       this.readXRefStream(stream);
 
-       delete this.streamState;
 
-       return stream.dict;
 
-     },
 
-     readXRefStream: function XRef_readXRefStream(stream) {
 
-       var i, j;
 
-       var streamState = this.streamState;
 
-       stream.pos = streamState.streamPos;
 
-       var byteWidths = streamState.byteWidths;
 
-       var typeFieldWidth = byteWidths[0];
 
-       var offsetFieldWidth = byteWidths[1];
 
-       var generationFieldWidth = byteWidths[2];
 
-       var entryRanges = streamState.entryRanges;
 
-       while (entryRanges.length > 0) {
 
-         var first = entryRanges[0];
 
-         var n = entryRanges[1];
 
-         if (!Number.isInteger(first) || !Number.isInteger(n)) {
 
-           throw new _util.FormatError(`Invalid XRef range fields: ${first}, ${n}`);
 
-         }
 
-         if (!Number.isInteger(typeFieldWidth) || !Number.isInteger(offsetFieldWidth) || !Number.isInteger(generationFieldWidth)) {
 
-           throw new _util.FormatError(`Invalid XRef entry fields length: ${first}, ${n}`);
 
-         }
 
-         for (i = streamState.entryNum; i < n; ++i) {
 
-           streamState.entryNum = i;
 
-           streamState.streamPos = stream.pos;
 
-           var type = 0,
 
-               offset = 0,
 
-               generation = 0;
 
-           for (j = 0; j < typeFieldWidth; ++j) {
 
-             type = type << 8 | stream.getByte();
 
-           }
 
-           if (typeFieldWidth === 0) {
 
-             type = 1;
 
-           }
 
-           for (j = 0; j < offsetFieldWidth; ++j) {
 
-             offset = offset << 8 | stream.getByte();
 
-           }
 
-           for (j = 0; j < generationFieldWidth; ++j) {
 
-             generation = generation << 8 | stream.getByte();
 
-           }
 
-           var entry = {};
 
-           entry.offset = offset;
 
-           entry.gen = generation;
 
-           switch (type) {
 
-             case 0:
 
-               entry.free = true;
 
-               break;
 
-             case 1:
 
-               entry.uncompressed = true;
 
-               break;
 
-             case 2:
 
-               break;
 
-             default:
 
-               throw new _util.FormatError(`Invalid XRef entry type: ${type}`);
 
-           }
 
-           if (!this.entries[first + i]) {
 
-             this.entries[first + i] = entry;
 
-           }
 
-         }
 
-         streamState.entryNum = 0;
 
-         streamState.streamPos = stream.pos;
 
-         entryRanges.splice(0, 2);
 
-       }
 
-     },
 
-     indexObjects: function XRef_indexObjects() {
 
-       var TAB = 0x9,
 
-           LF = 0xa,
 
-           CR = 0xd,
 
-           SPACE = 0x20;
 
-       var PERCENT = 0x25,
 
-           LT = 0x3c;
 
-       function readToken(data, offset) {
 
-         var token = "",
 
-             ch = data[offset];
 
-         while (ch !== LF && ch !== CR && ch !== LT) {
 
-           if (++offset >= data.length) {
 
-             break;
 
-           }
 
-           token += String.fromCharCode(ch);
 
-           ch = data[offset];
 
-         }
 
-         return token;
 
-       }
 
-       function skipUntil(data, offset, what) {
 
-         var length = what.length,
 
-             dataLength = data.length;
 
-         var skipped = 0;
 
-         while (offset < dataLength) {
 
-           var i = 0;
 
-           while (i < length && data[offset + i] === what[i]) {
 
-             ++i;
 
-           }
 
-           if (i >= length) {
 
-             break;
 
-           }
 
-           offset++;
 
-           skipped++;
 
-         }
 
-         return skipped;
 
-       }
 
-       var objRegExp = /^(\d+)\s+(\d+)\s+obj\b/;
 
-       const endobjRegExp = /\bendobj[\b\s]$/;
 
-       const nestedObjRegExp = /\s+(\d+\s+\d+\s+obj[\b\s<])$/;
 
-       const CHECK_CONTENT_LENGTH = 25;
 
-       var trailerBytes = new Uint8Array([116, 114, 97, 105, 108, 101, 114]);
 
-       var startxrefBytes = new Uint8Array([115, 116, 97, 114, 116, 120, 114, 101, 102]);
 
-       const objBytes = new Uint8Array([111, 98, 106]);
 
-       var xrefBytes = new Uint8Array([47, 88, 82, 101, 102]);
 
-       this.entries.length = 0;
 
-       var stream = this.stream;
 
-       stream.pos = 0;
 
-       var buffer = stream.getBytes();
 
-       var position = stream.start,
 
-           length = buffer.length;
 
-       var trailers = [],
 
-           xrefStms = [];
 
-       while (position < length) {
 
-         var ch = buffer[position];
 
-         if (ch === TAB || ch === LF || ch === CR || ch === SPACE) {
 
-           ++position;
 
-           continue;
 
-         }
 
-         if (ch === PERCENT) {
 
-           do {
 
-             ++position;
 
-             if (position >= length) {
 
-               break;
 
-             }
 
-             ch = buffer[position];
 
-           } while (ch !== LF && ch !== CR);
 
-           continue;
 
-         }
 
-         var token = readToken(buffer, position);
 
-         var m;
 
-         if (token.startsWith("xref") && (token.length === 4 || /\s/.test(token[4]))) {
 
-           position += skipUntil(buffer, position, trailerBytes);
 
-           trailers.push(position);
 
-           position += skipUntil(buffer, position, startxrefBytes);
 
-         } else if (m = objRegExp.exec(token)) {
 
-           const num = m[1] | 0,
 
-                 gen = m[2] | 0;
 
-           if (!this.entries[num] || this.entries[num].gen === gen) {
 
-             this.entries[num] = {
 
-               offset: position - stream.start,
 
-               gen,
 
-               uncompressed: true
 
-             };
 
-           }
 
-           let contentLength,
 
-               startPos = position + token.length;
 
-           while (startPos < buffer.length) {
 
-             const endPos = startPos + skipUntil(buffer, startPos, objBytes) + 4;
 
-             contentLength = endPos - position;
 
-             const checkPos = Math.max(endPos - CHECK_CONTENT_LENGTH, startPos);
 
-             const tokenStr = (0, _util.bytesToString)(buffer.subarray(checkPos, endPos));
 
-             if (endobjRegExp.test(tokenStr)) {
 
-               break;
 
-             } else {
 
-               const objToken = nestedObjRegExp.exec(tokenStr);
 
-               if (objToken && objToken[1]) {
 
-                 (0, _util.warn)('indexObjects: Found new "obj" inside of another "obj", ' + 'caused by missing "endobj" -- trying to recover.');
 
-                 contentLength -= objToken[1].length;
 
-                 break;
 
-               }
 
-             }
 
-             startPos = endPos;
 
-           }
 
-           const content = buffer.subarray(position, position + contentLength);
 
-           var xrefTagOffset = skipUntil(content, 0, xrefBytes);
 
-           if (xrefTagOffset < contentLength && content[xrefTagOffset + 5] < 64) {
 
-             xrefStms.push(position - stream.start);
 
-             this.xrefstms[position - stream.start] = 1;
 
-           }
 
-           position += contentLength;
 
-         } else if (token.startsWith("trailer") && (token.length === 7 || /\s/.test(token[7]))) {
 
-           trailers.push(position);
 
-           position += skipUntil(buffer, position, startxrefBytes);
 
-         } else {
 
-           position += token.length + 1;
 
-         }
 
-       }
 
-       var i, ii;
 
-       for (i = 0, ii = xrefStms.length; i < ii; ++i) {
 
-         this.startXRefQueue.push(xrefStms[i]);
 
-         this.readXRef(true);
 
-       }
 
-       let trailerDict;
 
-       for (i = 0, ii = trailers.length; i < ii; ++i) {
 
-         stream.pos = trailers[i];
 
-         const parser = new _parser.Parser({
 
-           lexer: new _parser.Lexer(stream),
 
-           xref: this,
 
-           allowStreams: true,
 
-           recoveryMode: true
 
-         });
 
-         var obj = parser.getObj();
 
-         if (!(0, _primitives.isCmd)(obj, "trailer")) {
 
-           continue;
 
-         }
 
-         const dict = parser.getObj();
 
-         if (!(0, _primitives.isDict)(dict)) {
 
-           continue;
 
-         }
 
-         let rootDict;
 
-         try {
 
-           rootDict = dict.get("Root");
 
-         } catch (ex) {
 
-           if (ex instanceof _core_utils.MissingDataException) {
 
-             throw ex;
 
-           }
 
-           continue;
 
-         }
 
-         if (!(0, _primitives.isDict)(rootDict) || !rootDict.has("Pages")) {
 
-           continue;
 
-         }
 
-         if (dict.has("ID")) {
 
-           return dict;
 
-         }
 
-         trailerDict = dict;
 
-       }
 
-       if (trailerDict) {
 
-         return trailerDict;
 
-       }
 
-       throw new _util.InvalidPDFException("Invalid PDF structure.");
 
-     },
 
-     readXRef: function XRef_readXRef(recoveryMode) {
 
-       var stream = this.stream;
 
-       const startXRefParsedCache = Object.create(null);
 
-       try {
 
-         while (this.startXRefQueue.length) {
 
-           var startXRef = this.startXRefQueue[0];
 
-           if (startXRefParsedCache[startXRef]) {
 
-             (0, _util.warn)("readXRef - skipping XRef table since it was already parsed.");
 
-             this.startXRefQueue.shift();
 
-             continue;
 
-           }
 
-           startXRefParsedCache[startXRef] = true;
 
-           stream.pos = startXRef + stream.start;
 
-           const parser = new _parser.Parser({
 
-             lexer: new _parser.Lexer(stream),
 
-             xref: this,
 
-             allowStreams: true
 
-           });
 
-           var obj = parser.getObj();
 
-           var dict;
 
-           if ((0, _primitives.isCmd)(obj, "xref")) {
 
-             dict = this.processXRefTable(parser);
 
-             if (!this.topDict) {
 
-               this.topDict = dict;
 
-             }
 
-             obj = dict.get("XRefStm");
 
-             if (Number.isInteger(obj)) {
 
-               var pos = obj;
 
-               if (!(pos in this.xrefstms)) {
 
-                 this.xrefstms[pos] = 1;
 
-                 this.startXRefQueue.push(pos);
 
-               }
 
-             }
 
-           } else if (Number.isInteger(obj)) {
 
-             if (!Number.isInteger(parser.getObj()) || !(0, _primitives.isCmd)(parser.getObj(), "obj") || !(0, _primitives.isStream)(obj = parser.getObj())) {
 
-               throw new _util.FormatError("Invalid XRef stream");
 
-             }
 
-             dict = this.processXRefStream(obj);
 
-             if (!this.topDict) {
 
-               this.topDict = dict;
 
-             }
 
-             if (!dict) {
 
-               throw new _util.FormatError("Failed to read XRef stream");
 
-             }
 
-           } else {
 
-             throw new _util.FormatError("Invalid XRef stream header");
 
-           }
 
-           obj = dict.get("Prev");
 
-           if (Number.isInteger(obj)) {
 
-             this.startXRefQueue.push(obj);
 
-           } else if ((0, _primitives.isRef)(obj)) {
 
-             this.startXRefQueue.push(obj.num);
 
-           }
 
-           this.startXRefQueue.shift();
 
-         }
 
-         return this.topDict;
 
-       } catch (e) {
 
-         if (e instanceof _core_utils.MissingDataException) {
 
-           throw e;
 
-         }
 
-         (0, _util.info)("(while reading XRef): " + e);
 
-       }
 
-       if (recoveryMode) {
 
-         return undefined;
 
-       }
 
-       throw new _core_utils.XRefParseException();
 
-     },
 
-     getEntry: function XRef_getEntry(i) {
 
-       var xrefEntry = this.entries[i];
 
-       if (xrefEntry && !xrefEntry.free && xrefEntry.offset) {
 
-         return xrefEntry;
 
-       }
 
-       return null;
 
-     },
 
-     fetchIfRef: function XRef_fetchIfRef(obj, suppressEncryption) {
 
-       if (obj instanceof _primitives.Ref) {
 
-         return this.fetch(obj, suppressEncryption);
 
-       }
 
-       return obj;
 
-     },
 
-     fetch: function XRef_fetch(ref, suppressEncryption) {
 
-       if (!(ref instanceof _primitives.Ref)) {
 
-         throw new Error("ref object is not a reference");
 
-       }
 
-       const num = ref.num;
 
-       const cacheEntry = this._cacheMap.get(num);
 
-       if (cacheEntry !== undefined) {
 
-         if (cacheEntry instanceof _primitives.Dict && !cacheEntry.objId) {
 
-           cacheEntry.objId = ref.toString();
 
-         }
 
-         return cacheEntry;
 
-       }
 
-       let xrefEntry = this.getEntry(num);
 
-       if (xrefEntry === null) {
 
-         this._cacheMap.set(num, xrefEntry);
 
-         return xrefEntry;
 
-       }
 
-       if (xrefEntry.uncompressed) {
 
-         xrefEntry = this.fetchUncompressed(ref, xrefEntry, suppressEncryption);
 
-       } else {
 
-         xrefEntry = this.fetchCompressed(ref, xrefEntry, suppressEncryption);
 
-       }
 
-       if ((0, _primitives.isDict)(xrefEntry)) {
 
-         xrefEntry.objId = ref.toString();
 
-       } else if ((0, _primitives.isStream)(xrefEntry)) {
 
-         xrefEntry.dict.objId = ref.toString();
 
-       }
 
-       return xrefEntry;
 
-     },
 
-     fetchUncompressed(ref, xrefEntry, suppressEncryption = false) {
 
-       var gen = ref.gen;
 
-       var num = ref.num;
 
-       if (xrefEntry.gen !== gen) {
 
-         throw new _core_utils.XRefEntryException(`Inconsistent generation in XRef: ${ref}`);
 
-       }
 
-       var stream = this.stream.makeSubStream(xrefEntry.offset + this.stream.start);
 
-       const parser = new _parser.Parser({
 
-         lexer: new _parser.Lexer(stream),
 
-         xref: this,
 
-         allowStreams: true
 
-       });
 
-       var obj1 = parser.getObj();
 
-       var obj2 = parser.getObj();
 
-       var obj3 = parser.getObj();
 
-       if (obj1 !== num || obj2 !== gen || !(obj3 instanceof _primitives.Cmd)) {
 
-         throw new _core_utils.XRefEntryException(`Bad (uncompressed) XRef entry: ${ref}`);
 
-       }
 
-       if (obj3.cmd !== "obj") {
 
-         if (obj3.cmd.startsWith("obj")) {
 
-           num = parseInt(obj3.cmd.substring(3), 10);
 
-           if (!Number.isNaN(num)) {
 
-             return num;
 
-           }
 
-         }
 
-         throw new _core_utils.XRefEntryException(`Bad (uncompressed) XRef entry: ${ref}`);
 
-       }
 
-       if (this.encrypt && !suppressEncryption) {
 
-         xrefEntry = parser.getObj(this.encrypt.createCipherTransform(num, gen));
 
-       } else {
 
-         xrefEntry = parser.getObj();
 
-       }
 
-       if (!(0, _primitives.isStream)(xrefEntry)) {
 
-         this._cacheMap.set(num, xrefEntry);
 
-       }
 
-       return xrefEntry;
 
-     },
 
-     fetchCompressed(ref, xrefEntry, suppressEncryption = false) {
 
-       const tableOffset = xrefEntry.offset;
 
-       const stream = this.fetch(_primitives.Ref.get(tableOffset, 0));
 
-       if (!(0, _primitives.isStream)(stream)) {
 
-         throw new _util.FormatError("bad ObjStm stream");
 
-       }
 
-       const first = stream.dict.get("First");
 
-       const n = stream.dict.get("N");
 
-       if (!Number.isInteger(first) || !Number.isInteger(n)) {
 
-         throw new _util.FormatError("invalid first and n parameters for ObjStm stream");
 
-       }
 
-       const parser = new _parser.Parser({
 
-         lexer: new _parser.Lexer(stream),
 
-         xref: this,
 
-         allowStreams: true
 
-       });
 
-       const nums = new Array(n);
 
-       for (let i = 0; i < n; ++i) {
 
-         const num = parser.getObj();
 
-         if (!Number.isInteger(num)) {
 
-           throw new _util.FormatError(`invalid object number in the ObjStm stream: ${num}`);
 
-         }
 
-         const offset = parser.getObj();
 
-         if (!Number.isInteger(offset)) {
 
-           throw new _util.FormatError(`invalid object offset in the ObjStm stream: ${offset}`);
 
-         }
 
-         nums[i] = num;
 
-       }
 
-       const entries = new Array(n);
 
-       for (let i = 0; i < n; ++i) {
 
-         const obj = parser.getObj();
 
-         entries[i] = obj;
 
-         if (parser.buf1 instanceof _primitives.Cmd && parser.buf1.cmd === "endobj") {
 
-           parser.shift();
 
-         }
 
-         if ((0, _primitives.isStream)(obj)) {
 
-           continue;
 
-         }
 
-         const num = nums[i],
 
-               entry = this.entries[num];
 
-         if (entry && entry.offset === tableOffset && entry.gen === i) {
 
-           this._cacheMap.set(num, obj);
 
-         }
 
-       }
 
-       xrefEntry = entries[xrefEntry.gen];
 
-       if (xrefEntry === undefined) {
 
-         throw new _core_utils.XRefEntryException(`Bad (compressed) XRef entry: ${ref}`);
 
-       }
 
-       return xrefEntry;
 
-     },
 
-     async fetchIfRefAsync(obj, suppressEncryption) {
 
-       if (obj instanceof _primitives.Ref) {
 
-         return this.fetchAsync(obj, suppressEncryption);
 
-       }
 
-       return obj;
 
-     },
 
-     async fetchAsync(ref, suppressEncryption) {
 
-       try {
 
-         return this.fetch(ref, suppressEncryption);
 
-       } catch (ex) {
 
-         if (!(ex instanceof _core_utils.MissingDataException)) {
 
-           throw ex;
 
-         }
 
-         await this.pdfManager.requestRange(ex.begin, ex.end);
 
-         return this.fetchAsync(ref, suppressEncryption);
 
-       }
 
-     },
 
-     getCatalogObj: function XRef_getCatalogObj() {
 
-       return this.root;
 
-     }
 
-   };
 
-   return XRef;
 
- }();
 
- exports.XRef = XRef;
 
- class NameOrNumberTree {
 
-   constructor(root, xref, type) {
 
-     if (this.constructor === NameOrNumberTree) {
 
-       (0, _util.unreachable)("Cannot initialize NameOrNumberTree.");
 
-     }
 
-     this.root = root;
 
-     this.xref = xref;
 
-     this._type = type;
 
-   }
 
-   getAll() {
 
-     const dict = Object.create(null);
 
-     if (!this.root) {
 
-       return dict;
 
-     }
 
-     const xref = this.xref;
 
-     const processed = new _primitives.RefSet();
 
-     processed.put(this.root);
 
-     const queue = [this.root];
 
-     while (queue.length > 0) {
 
-       const obj = xref.fetchIfRef(queue.shift());
 
-       if (!(0, _primitives.isDict)(obj)) {
 
-         continue;
 
-       }
 
-       if (obj.has("Kids")) {
 
-         const kids = obj.get("Kids");
 
-         for (let i = 0, ii = kids.length; i < ii; i++) {
 
-           const kid = kids[i];
 
-           if (processed.has(kid)) {
 
-             throw new _util.FormatError(`Duplicate entry in "${this._type}" tree.`);
 
-           }
 
-           queue.push(kid);
 
-           processed.put(kid);
 
-         }
 
-         continue;
 
-       }
 
-       const entries = obj.get(this._type);
 
-       if (Array.isArray(entries)) {
 
-         for (let i = 0, ii = entries.length; i < ii; i += 2) {
 
-           dict[xref.fetchIfRef(entries[i])] = xref.fetchIfRef(entries[i + 1]);
 
-         }
 
-       }
 
-     }
 
-     return dict;
 
-   }
 
-   get(key) {
 
-     if (!this.root) {
 
-       return null;
 
-     }
 
-     const xref = this.xref;
 
-     let kidsOrEntries = xref.fetchIfRef(this.root);
 
-     let loopCount = 0;
 
-     const MAX_LEVELS = 10;
 
-     while (kidsOrEntries.has("Kids")) {
 
-       if (++loopCount > MAX_LEVELS) {
 
-         (0, _util.warn)(`Search depth limit reached for "${this._type}" tree.`);
 
-         return null;
 
-       }
 
-       const kids = kidsOrEntries.get("Kids");
 
-       if (!Array.isArray(kids)) {
 
-         return null;
 
-       }
 
-       let l = 0,
 
-           r = kids.length - 1;
 
-       while (l <= r) {
 
-         const m = l + r >> 1;
 
-         const kid = xref.fetchIfRef(kids[m]);
 
-         const limits = kid.get("Limits");
 
-         if (key < xref.fetchIfRef(limits[0])) {
 
-           r = m - 1;
 
-         } else if (key > xref.fetchIfRef(limits[1])) {
 
-           l = m + 1;
 
-         } else {
 
-           kidsOrEntries = xref.fetchIfRef(kids[m]);
 
-           break;
 
-         }
 
-       }
 
-       if (l > r) {
 
-         return null;
 
-       }
 
-     }
 
-     const entries = kidsOrEntries.get(this._type);
 
-     if (Array.isArray(entries)) {
 
-       let l = 0,
 
-           r = entries.length - 2;
 
-       while (l <= r) {
 
-         const tmp = l + r >> 1,
 
-               m = tmp + (tmp & 1);
 
-         const currentKey = xref.fetchIfRef(entries[m]);
 
-         if (key < currentKey) {
 
-           r = m - 2;
 
-         } else if (key > currentKey) {
 
-           l = m + 2;
 
-         } else {
 
-           return xref.fetchIfRef(entries[m + 1]);
 
-         }
 
-       }
 
-       (0, _util.info)(`Falling back to an exhaustive search, for key "${key}", ` + `in "${this._type}" tree.`);
 
-       for (let m = 0, mm = entries.length; m < mm; m += 2) {
 
-         const currentKey = xref.fetchIfRef(entries[m]);
 
-         if (currentKey === key) {
 
-           (0, _util.warn)(`The "${key}" key was found at an incorrect, ` + `i.e. out-of-order, position in "${this._type}" tree.`);
 
-           return xref.fetchIfRef(entries[m + 1]);
 
-         }
 
-       }
 
-     }
 
-     return null;
 
-   }
 
- }
 
- class NameTree extends NameOrNumberTree {
 
-   constructor(root, xref) {
 
-     super(root, xref, "Names");
 
-   }
 
- }
 
- class NumberTree extends NameOrNumberTree {
 
-   constructor(root, xref) {
 
-     super(root, xref, "Nums");
 
-   }
 
- }
 
- var FileSpec = function FileSpecClosure() {
 
-   function FileSpec(root, xref) {
 
-     if (!root || !(0, _primitives.isDict)(root)) {
 
-       return;
 
-     }
 
-     this.xref = xref;
 
-     this.root = root;
 
-     if (root.has("FS")) {
 
-       this.fs = root.get("FS");
 
-     }
 
-     this.description = root.has("Desc") ? (0, _util.stringToPDFString)(root.get("Desc")) : "";
 
-     if (root.has("RF")) {
 
-       (0, _util.warn)("Related file specifications are not supported");
 
-     }
 
-     this.contentAvailable = true;
 
-     if (!root.has("EF")) {
 
-       this.contentAvailable = false;
 
-       (0, _util.warn)("Non-embedded file specifications are not supported");
 
-     }
 
-   }
 
-   function pickPlatformItem(dict) {
 
-     if (dict.has("UF")) {
 
-       return dict.get("UF");
 
-     } else if (dict.has("F")) {
 
-       return dict.get("F");
 
-     } else if (dict.has("Unix")) {
 
-       return dict.get("Unix");
 
-     } else if (dict.has("Mac")) {
 
-       return dict.get("Mac");
 
-     } else if (dict.has("DOS")) {
 
-       return dict.get("DOS");
 
-     }
 
-     return null;
 
-   }
 
-   FileSpec.prototype = {
 
-     get filename() {
 
-       if (!this._filename && this.root) {
 
-         var filename = pickPlatformItem(this.root) || "unnamed";
 
-         this._filename = (0, _util.stringToPDFString)(filename).replace(/\\\\/g, "\\").replace(/\\\//g, "/").replace(/\\/g, "/");
 
-       }
 
-       return this._filename;
 
-     },
 
-     get content() {
 
-       if (!this.contentAvailable) {
 
-         return null;
 
-       }
 
-       if (!this.contentRef && this.root) {
 
-         this.contentRef = pickPlatformItem(this.root.get("EF"));
 
-       }
 
-       var content = null;
 
-       if (this.contentRef) {
 
-         var xref = this.xref;
 
-         var fileObj = xref.fetchIfRef(this.contentRef);
 
-         if (fileObj && (0, _primitives.isStream)(fileObj)) {
 
-           content = fileObj.getBytes();
 
-         } else {
 
-           (0, _util.warn)("Embedded file specification points to non-existing/invalid " + "content");
 
-         }
 
-       } else {
 
-         (0, _util.warn)("Embedded file specification does not have a content");
 
-       }
 
-       return content;
 
-     },
 
-     get serializable() {
 
-       return {
 
-         filename: this.filename,
 
-         content: this.content
 
-       };
 
-     }
 
-   };
 
-   return FileSpec;
 
- }();
 
- exports.FileSpec = FileSpec;
 
- const ObjectLoader = function () {
 
-   function mayHaveChildren(value) {
 
-     return value instanceof _primitives.Ref || value instanceof _primitives.Dict || Array.isArray(value) || (0, _primitives.isStream)(value);
 
-   }
 
-   function addChildren(node, nodesToVisit) {
 
-     if (node instanceof _primitives.Dict || (0, _primitives.isStream)(node)) {
 
-       const dict = node instanceof _primitives.Dict ? node : node.dict;
 
-       const dictKeys = dict.getKeys();
 
-       for (let i = 0, ii = dictKeys.length; i < ii; i++) {
 
-         const rawValue = dict.getRaw(dictKeys[i]);
 
-         if (mayHaveChildren(rawValue)) {
 
-           nodesToVisit.push(rawValue);
 
-         }
 
-       }
 
-     } else if (Array.isArray(node)) {
 
-       for (let i = 0, ii = node.length; i < ii; i++) {
 
-         const value = node[i];
 
-         if (mayHaveChildren(value)) {
 
-           nodesToVisit.push(value);
 
-         }
 
-       }
 
-     }
 
-   }
 
-   function ObjectLoader(dict, keys, xref) {
 
-     this.dict = dict;
 
-     this.keys = keys;
 
-     this.xref = xref;
 
-     this.refSet = null;
 
-   }
 
-   ObjectLoader.prototype = {
 
-     async load() {
 
-       if (!this.xref.stream.allChunksLoaded || this.xref.stream.allChunksLoaded()) {
 
-         return undefined;
 
-       }
 
-       const {
 
-         keys,
 
-         dict
 
-       } = this;
 
-       this.refSet = new _primitives.RefSet();
 
-       const nodesToVisit = [];
 
-       for (let i = 0, ii = keys.length; i < ii; i++) {
 
-         const rawValue = dict.getRaw(keys[i]);
 
-         if (rawValue !== undefined) {
 
-           nodesToVisit.push(rawValue);
 
-         }
 
-       }
 
-       return this._walk(nodesToVisit);
 
-     },
 
-     async _walk(nodesToVisit) {
 
-       const nodesToRevisit = [];
 
-       const pendingRequests = [];
 
-       while (nodesToVisit.length) {
 
-         let currentNode = nodesToVisit.pop();
 
-         if (currentNode instanceof _primitives.Ref) {
 
-           if (this.refSet.has(currentNode)) {
 
-             continue;
 
-           }
 
-           try {
 
-             this.refSet.put(currentNode);
 
-             currentNode = this.xref.fetch(currentNode);
 
-           } catch (ex) {
 
-             if (!(ex instanceof _core_utils.MissingDataException)) {
 
-               throw ex;
 
-             }
 
-             nodesToRevisit.push(currentNode);
 
-             pendingRequests.push({
 
-               begin: ex.begin,
 
-               end: ex.end
 
-             });
 
-           }
 
-         }
 
-         if (currentNode && currentNode.getBaseStreams) {
 
-           const baseStreams = currentNode.getBaseStreams();
 
-           let foundMissingData = false;
 
-           for (let i = 0, ii = baseStreams.length; i < ii; i++) {
 
-             const stream = baseStreams[i];
 
-             if (stream.allChunksLoaded && !stream.allChunksLoaded()) {
 
-               foundMissingData = true;
 
-               pendingRequests.push({
 
-                 begin: stream.start,
 
-                 end: stream.end
 
-               });
 
-             }
 
-           }
 
-           if (foundMissingData) {
 
-             nodesToRevisit.push(currentNode);
 
-           }
 
-         }
 
-         addChildren(currentNode, nodesToVisit);
 
-       }
 
-       if (pendingRequests.length) {
 
-         await this.xref.stream.manager.requestRanges(pendingRequests);
 
-         for (let i = 0, ii = nodesToRevisit.length; i < ii; i++) {
 
-           const node = nodesToRevisit[i];
 
-           if (node instanceof _primitives.Ref) {
 
-             this.refSet.remove(node);
 
-           }
 
-         }
 
-         return this._walk(nodesToRevisit);
 
-       }
 
-       this.refSet = null;
 
-       return undefined;
 
-     }
 
-   };
 
-   return ObjectLoader;
 
- }();
 
- exports.ObjectLoader = ObjectLoader;
 
- /***/ }),
 
- /* 10 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.Parser = exports.Linearization = exports.Lexer = void 0;
 
- var _stream = __w_pdfjs_require__(11);
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _ccitt_stream = __w_pdfjs_require__(12);
 
- var _jbig2_stream = __w_pdfjs_require__(14);
 
- var _jpeg_stream = __w_pdfjs_require__(17);
 
- var _jpx_stream = __w_pdfjs_require__(19);
 
- const MAX_LENGTH_TO_CACHE = 1000;
 
- const MAX_ADLER32_LENGTH = 5552;
 
- function computeAdler32(bytes) {
 
-   const bytesLength = bytes.length;
 
-   let a = 1,
 
-       b = 0;
 
-   for (let i = 0; i < bytesLength; ++i) {
 
-     a += bytes[i] & 0xff;
 
-     b += a;
 
-   }
 
-   return b % 65521 << 16 | a % 65521;
 
- }
 
- class Parser {
 
-   constructor({
 
-     lexer,
 
-     xref,
 
-     allowStreams = false,
 
-     recoveryMode = false
 
-   }) {
 
-     this.lexer = lexer;
 
-     this.xref = xref;
 
-     this.allowStreams = allowStreams;
 
-     this.recoveryMode = recoveryMode;
 
-     this.imageCache = Object.create(null);
 
-     this.refill();
 
-   }
 
-   refill() {
 
-     this.buf1 = this.lexer.getObj();
 
-     this.buf2 = this.lexer.getObj();
 
-   }
 
-   shift() {
 
-     if (this.buf2 instanceof _primitives.Cmd && this.buf2.cmd === "ID") {
 
-       this.buf1 = this.buf2;
 
-       this.buf2 = null;
 
-     } else {
 
-       this.buf1 = this.buf2;
 
-       this.buf2 = this.lexer.getObj();
 
-     }
 
-   }
 
-   tryShift() {
 
-     try {
 
-       this.shift();
 
-       return true;
 
-     } catch (e) {
 
-       if (e instanceof _core_utils.MissingDataException) {
 
-         throw e;
 
-       }
 
-       return false;
 
-     }
 
-   }
 
-   getObj(cipherTransform = null) {
 
-     const buf1 = this.buf1;
 
-     this.shift();
 
-     if (buf1 instanceof _primitives.Cmd) {
 
-       switch (buf1.cmd) {
 
-         case "BI":
 
-           return this.makeInlineImage(cipherTransform);
 
-         case "[":
 
-           const array = [];
 
-           while (!(0, _primitives.isCmd)(this.buf1, "]") && !(0, _primitives.isEOF)(this.buf1)) {
 
-             array.push(this.getObj(cipherTransform));
 
-           }
 
-           if ((0, _primitives.isEOF)(this.buf1)) {
 
-             if (!this.recoveryMode) {
 
-               throw new _util.FormatError("End of file inside array");
 
-             }
 
-             return array;
 
-           }
 
-           this.shift();
 
-           return array;
 
-         case "<<":
 
-           const dict = new _primitives.Dict(this.xref);
 
-           while (!(0, _primitives.isCmd)(this.buf1, ">>") && !(0, _primitives.isEOF)(this.buf1)) {
 
-             if (!(0, _primitives.isName)(this.buf1)) {
 
-               (0, _util.info)("Malformed dictionary: key must be a name object");
 
-               this.shift();
 
-               continue;
 
-             }
 
-             const key = this.buf1.name;
 
-             this.shift();
 
-             if ((0, _primitives.isEOF)(this.buf1)) {
 
-               break;
 
-             }
 
-             dict.set(key, this.getObj(cipherTransform));
 
-           }
 
-           if ((0, _primitives.isEOF)(this.buf1)) {
 
-             if (!this.recoveryMode) {
 
-               throw new _util.FormatError("End of file inside dictionary");
 
-             }
 
-             return dict;
 
-           }
 
-           if ((0, _primitives.isCmd)(this.buf2, "stream")) {
 
-             return this.allowStreams ? this.makeStream(dict, cipherTransform) : dict;
 
-           }
 
-           this.shift();
 
-           return dict;
 
-         default:
 
-           return buf1;
 
-       }
 
-     }
 
-     if (Number.isInteger(buf1)) {
 
-       if (Number.isInteger(this.buf1) && (0, _primitives.isCmd)(this.buf2, "R")) {
 
-         const ref = _primitives.Ref.get(buf1, this.buf1);
 
-         this.shift();
 
-         this.shift();
 
-         return ref;
 
-       }
 
-       return buf1;
 
-     }
 
-     if (typeof buf1 === "string") {
 
-       if (cipherTransform) {
 
-         return cipherTransform.decryptString(buf1);
 
-       }
 
-       return buf1;
 
-     }
 
-     return buf1;
 
-   }
 
-   findDefaultInlineStreamEnd(stream) {
 
-     const E = 0x45,
 
-           I = 0x49,
 
-           SPACE = 0x20,
 
-           LF = 0xa,
 
-           CR = 0xd;
 
-     const n = 10,
 
-           NUL = 0x0;
 
-     const startPos = stream.pos;
 
-     let state = 0,
 
-         ch,
 
-         maybeEIPos;
 
-     while ((ch = stream.getByte()) !== -1) {
 
-       if (state === 0) {
 
-         state = ch === E ? 1 : 0;
 
-       } else if (state === 1) {
 
-         state = ch === I ? 2 : 0;
 
-       } else {
 
-         (0, _util.assert)(state === 2);
 
-         if (ch === SPACE || ch === LF || ch === CR) {
 
-           maybeEIPos = stream.pos;
 
-           const followingBytes = stream.peekBytes(n);
 
-           for (let i = 0, ii = followingBytes.length; i < ii; i++) {
 
-             ch = followingBytes[i];
 
-             if (ch === NUL && followingBytes[i + 1] !== NUL) {
 
-               continue;
 
-             }
 
-             if (ch !== LF && ch !== CR && (ch < SPACE || ch > 0x7f)) {
 
-               state = 0;
 
-               break;
 
-             }
 
-           }
 
-           if (state === 2) {
 
-             break;
 
-           }
 
-         } else {
 
-           state = 0;
 
-         }
 
-       }
 
-     }
 
-     if (ch === -1) {
 
-       (0, _util.warn)("findDefaultInlineStreamEnd: " + "Reached the end of the stream without finding a valid EI marker");
 
-       if (maybeEIPos) {
 
-         (0, _util.warn)('... trying to recover by using the last "EI" occurrence.');
 
-         stream.skip(-(stream.pos - maybeEIPos));
 
-       }
 
-     }
 
-     let endOffset = 4;
 
-     stream.skip(-endOffset);
 
-     ch = stream.peekByte();
 
-     stream.skip(endOffset);
 
-     if (!(0, _core_utils.isWhiteSpace)(ch)) {
 
-       endOffset--;
 
-     }
 
-     return stream.pos - endOffset - startPos;
 
-   }
 
-   findDCTDecodeInlineStreamEnd(stream) {
 
-     const startPos = stream.pos;
 
-     let foundEOI = false,
 
-         b,
 
-         markerLength;
 
-     while ((b = stream.getByte()) !== -1) {
 
-       if (b !== 0xff) {
 
-         continue;
 
-       }
 
-       switch (stream.getByte()) {
 
-         case 0x00:
 
-           break;
 
-         case 0xff:
 
-           stream.skip(-1);
 
-           break;
 
-         case 0xd9:
 
-           foundEOI = true;
 
-           break;
 
-         case 0xc0:
 
-         case 0xc1:
 
-         case 0xc2:
 
-         case 0xc3:
 
-         case 0xc5:
 
-         case 0xc6:
 
-         case 0xc7:
 
-         case 0xc9:
 
-         case 0xca:
 
-         case 0xcb:
 
-         case 0xcd:
 
-         case 0xce:
 
-         case 0xcf:
 
-         case 0xc4:
 
-         case 0xcc:
 
-         case 0xda:
 
-         case 0xdb:
 
-         case 0xdc:
 
-         case 0xdd:
 
-         case 0xde:
 
-         case 0xdf:
 
-         case 0xe0:
 
-         case 0xe1:
 
-         case 0xe2:
 
-         case 0xe3:
 
-         case 0xe4:
 
-         case 0xe5:
 
-         case 0xe6:
 
-         case 0xe7:
 
-         case 0xe8:
 
-         case 0xe9:
 
-         case 0xea:
 
-         case 0xeb:
 
-         case 0xec:
 
-         case 0xed:
 
-         case 0xee:
 
-         case 0xef:
 
-         case 0xfe:
 
-           markerLength = stream.getUint16();
 
-           if (markerLength > 2) {
 
-             stream.skip(markerLength - 2);
 
-           } else {
 
-             stream.skip(-2);
 
-           }
 
-           break;
 
-       }
 
-       if (foundEOI) {
 
-         break;
 
-       }
 
-     }
 
-     const length = stream.pos - startPos;
 
-     if (b === -1) {
 
-       (0, _util.warn)("Inline DCTDecode image stream: " + "EOI marker not found, searching for /EI/ instead.");
 
-       stream.skip(-length);
 
-       return this.findDefaultInlineStreamEnd(stream);
 
-     }
 
-     this.inlineStreamSkipEI(stream);
 
-     return length;
 
-   }
 
-   findASCII85DecodeInlineStreamEnd(stream) {
 
-     const TILDE = 0x7e,
 
-           GT = 0x3e;
 
-     const startPos = stream.pos;
 
-     let ch;
 
-     while ((ch = stream.getByte()) !== -1) {
 
-       if (ch === TILDE) {
 
-         const tildePos = stream.pos;
 
-         ch = stream.peekByte();
 
-         while ((0, _core_utils.isWhiteSpace)(ch)) {
 
-           stream.skip();
 
-           ch = stream.peekByte();
 
-         }
 
-         if (ch === GT) {
 
-           stream.skip();
 
-           break;
 
-         }
 
-         if (stream.pos > tildePos) {
 
-           const maybeEI = stream.peekBytes(2);
 
-           if (maybeEI[0] === 0x45 && maybeEI[1] === 0x49) {
 
-             break;
 
-           }
 
-         }
 
-       }
 
-     }
 
-     const length = stream.pos - startPos;
 
-     if (ch === -1) {
 
-       (0, _util.warn)("Inline ASCII85Decode image stream: " + "EOD marker not found, searching for /EI/ instead.");
 
-       stream.skip(-length);
 
-       return this.findDefaultInlineStreamEnd(stream);
 
-     }
 
-     this.inlineStreamSkipEI(stream);
 
-     return length;
 
-   }
 
-   findASCIIHexDecodeInlineStreamEnd(stream) {
 
-     const GT = 0x3e;
 
-     const startPos = stream.pos;
 
-     let ch;
 
-     while ((ch = stream.getByte()) !== -1) {
 
-       if (ch === GT) {
 
-         break;
 
-       }
 
-     }
 
-     const length = stream.pos - startPos;
 
-     if (ch === -1) {
 
-       (0, _util.warn)("Inline ASCIIHexDecode image stream: " + "EOD marker not found, searching for /EI/ instead.");
 
-       stream.skip(-length);
 
-       return this.findDefaultInlineStreamEnd(stream);
 
-     }
 
-     this.inlineStreamSkipEI(stream);
 
-     return length;
 
-   }
 
-   inlineStreamSkipEI(stream) {
 
-     const E = 0x45,
 
-           I = 0x49;
 
-     let state = 0,
 
-         ch;
 
-     while ((ch = stream.getByte()) !== -1) {
 
-       if (state === 0) {
 
-         state = ch === E ? 1 : 0;
 
-       } else if (state === 1) {
 
-         state = ch === I ? 2 : 0;
 
-       } else if (state === 2) {
 
-         break;
 
-       }
 
-     }
 
-   }
 
-   makeInlineImage(cipherTransform) {
 
-     const lexer = this.lexer;
 
-     const stream = lexer.stream;
 
-     const dict = new _primitives.Dict(this.xref);
 
-     let dictLength;
 
-     while (!(0, _primitives.isCmd)(this.buf1, "ID") && !(0, _primitives.isEOF)(this.buf1)) {
 
-       if (!(0, _primitives.isName)(this.buf1)) {
 
-         throw new _util.FormatError("Dictionary key must be a name object");
 
-       }
 
-       const key = this.buf1.name;
 
-       this.shift();
 
-       if ((0, _primitives.isEOF)(this.buf1)) {
 
-         break;
 
-       }
 
-       dict.set(key, this.getObj(cipherTransform));
 
-     }
 
-     if (lexer.beginInlineImagePos !== -1) {
 
-       dictLength = stream.pos - lexer.beginInlineImagePos;
 
-     }
 
-     const filter = dict.get("Filter", "F");
 
-     let filterName;
 
-     if ((0, _primitives.isName)(filter)) {
 
-       filterName = filter.name;
 
-     } else if (Array.isArray(filter)) {
 
-       const filterZero = this.xref.fetchIfRef(filter[0]);
 
-       if ((0, _primitives.isName)(filterZero)) {
 
-         filterName = filterZero.name;
 
-       }
 
-     }
 
-     const startPos = stream.pos;
 
-     let length;
 
-     if (filterName === "DCTDecode" || filterName === "DCT") {
 
-       length = this.findDCTDecodeInlineStreamEnd(stream);
 
-     } else if (filterName === "ASCII85Decode" || filterName === "A85") {
 
-       length = this.findASCII85DecodeInlineStreamEnd(stream);
 
-     } else if (filterName === "ASCIIHexDecode" || filterName === "AHx") {
 
-       length = this.findASCIIHexDecodeInlineStreamEnd(stream);
 
-     } else {
 
-       length = this.findDefaultInlineStreamEnd(stream);
 
-     }
 
-     let imageStream = stream.makeSubStream(startPos, length, dict);
 
-     let cacheKey;
 
-     if (length < MAX_LENGTH_TO_CACHE && dictLength < MAX_ADLER32_LENGTH) {
 
-       const imageBytes = imageStream.getBytes();
 
-       imageStream.reset();
 
-       const initialStreamPos = stream.pos;
 
-       stream.pos = lexer.beginInlineImagePos;
 
-       const dictBytes = stream.getBytes(dictLength);
 
-       stream.pos = initialStreamPos;
 
-       cacheKey = computeAdler32(imageBytes) + "_" + computeAdler32(dictBytes);
 
-       const cacheEntry = this.imageCache[cacheKey];
 
-       if (cacheEntry !== undefined) {
 
-         this.buf2 = _primitives.Cmd.get("EI");
 
-         this.shift();
 
-         cacheEntry.reset();
 
-         return cacheEntry;
 
-       }
 
-     }
 
-     if (cipherTransform) {
 
-       imageStream = cipherTransform.createStream(imageStream, length);
 
-     }
 
-     imageStream = this.filter(imageStream, dict, length);
 
-     imageStream.dict = dict;
 
-     if (cacheKey !== undefined) {
 
-       imageStream.cacheKey = `inline_${length}_${cacheKey}`;
 
-       this.imageCache[cacheKey] = imageStream;
 
-     }
 
-     this.buf2 = _primitives.Cmd.get("EI");
 
-     this.shift();
 
-     return imageStream;
 
-   }
 
-   _findStreamLength(startPos, signature) {
 
-     const {
 
-       stream
 
-     } = this.lexer;
 
-     stream.pos = startPos;
 
-     const SCAN_BLOCK_LENGTH = 2048;
 
-     const signatureLength = signature.length;
 
-     while (stream.pos < stream.end) {
 
-       const scanBytes = stream.peekBytes(SCAN_BLOCK_LENGTH);
 
-       const scanLength = scanBytes.length - signatureLength;
 
-       if (scanLength <= 0) {
 
-         break;
 
-       }
 
-       let pos = 0;
 
-       while (pos < scanLength) {
 
-         let j = 0;
 
-         while (j < signatureLength && scanBytes[pos + j] === signature[j]) {
 
-           j++;
 
-         }
 
-         if (j >= signatureLength) {
 
-           stream.pos += pos;
 
-           return stream.pos - startPos;
 
-         }
 
-         pos++;
 
-       }
 
-       stream.pos += scanLength;
 
-     }
 
-     return -1;
 
-   }
 
-   makeStream(dict, cipherTransform) {
 
-     const lexer = this.lexer;
 
-     let stream = lexer.stream;
 
-     lexer.skipToNextLine();
 
-     const startPos = stream.pos - 1;
 
-     let length = dict.get("Length");
 
-     if (!Number.isInteger(length)) {
 
-       (0, _util.info)(`Bad length "${length}" in stream`);
 
-       length = 0;
 
-     }
 
-     stream.pos = startPos + length;
 
-     lexer.nextChar();
 
-     if (this.tryShift() && (0, _primitives.isCmd)(this.buf2, "endstream")) {
 
-       this.shift();
 
-     } else {
 
-       const ENDSTREAM_SIGNATURE = new Uint8Array([0x65, 0x6E, 0x64, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6D]);
 
-       let actualLength = this._findStreamLength(startPos, ENDSTREAM_SIGNATURE);
 
-       if (actualLength < 0) {
 
-         const MAX_TRUNCATION = 1;
 
-         for (let i = 1; i <= MAX_TRUNCATION; i++) {
 
-           const end = ENDSTREAM_SIGNATURE.length - i;
 
-           const TRUNCATED_SIGNATURE = ENDSTREAM_SIGNATURE.slice(0, end);
 
-           const maybeLength = this._findStreamLength(startPos, TRUNCATED_SIGNATURE);
 
-           if (maybeLength >= 0) {
 
-             const lastByte = stream.peekBytes(end + 1)[end];
 
-             if (!(0, _core_utils.isWhiteSpace)(lastByte)) {
 
-               break;
 
-             }
 
-             (0, _util.info)(`Found "${(0, _util.bytesToString)(TRUNCATED_SIGNATURE)}" when ` + "searching for endstream command.");
 
-             actualLength = maybeLength;
 
-             break;
 
-           }
 
-         }
 
-         if (actualLength < 0) {
 
-           throw new _util.FormatError("Missing endstream command.");
 
-         }
 
-       }
 
-       length = actualLength;
 
-       lexer.nextChar();
 
-       this.shift();
 
-       this.shift();
 
-     }
 
-     this.shift();
 
-     stream = stream.makeSubStream(startPos, length, dict);
 
-     if (cipherTransform) {
 
-       stream = cipherTransform.createStream(stream, length);
 
-     }
 
-     stream = this.filter(stream, dict, length);
 
-     stream.dict = dict;
 
-     return stream;
 
-   }
 
-   filter(stream, dict, length) {
 
-     let filter = dict.get("Filter", "F");
 
-     let params = dict.get("DecodeParms", "DP");
 
-     if ((0, _primitives.isName)(filter)) {
 
-       if (Array.isArray(params)) {
 
-         (0, _util.warn)("/DecodeParms should not contain an Array, " + "when /Filter contains a Name.");
 
-       }
 
-       return this.makeFilter(stream, filter.name, length, params);
 
-     }
 
-     let maybeLength = length;
 
-     if (Array.isArray(filter)) {
 
-       const filterArray = filter;
 
-       const paramsArray = params;
 
-       for (let i = 0, ii = filterArray.length; i < ii; ++i) {
 
-         filter = this.xref.fetchIfRef(filterArray[i]);
 
-         if (!(0, _primitives.isName)(filter)) {
 
-           throw new _util.FormatError(`Bad filter name "${filter}"`);
 
-         }
 
-         params = null;
 
-         if (Array.isArray(paramsArray) && i in paramsArray) {
 
-           params = this.xref.fetchIfRef(paramsArray[i]);
 
-         }
 
-         stream = this.makeFilter(stream, filter.name, maybeLength, params);
 
-         maybeLength = null;
 
-       }
 
-     }
 
-     return stream;
 
-   }
 
-   makeFilter(stream, name, maybeLength, params) {
 
-     if (maybeLength === 0) {
 
-       (0, _util.warn)(`Empty "${name}" stream.`);
 
-       return new _stream.NullStream();
 
-     }
 
-     try {
 
-       const xrefStreamStats = this.xref.stats.streamTypes;
 
-       if (name === "FlateDecode" || name === "Fl") {
 
-         xrefStreamStats[_util.StreamType.FLATE] = true;
 
-         if (params) {
 
-           return new _stream.PredictorStream(new _stream.FlateStream(stream, maybeLength), maybeLength, params);
 
-         }
 
-         return new _stream.FlateStream(stream, maybeLength);
 
-       }
 
-       if (name === "LZWDecode" || name === "LZW") {
 
-         xrefStreamStats[_util.StreamType.LZW] = true;
 
-         let earlyChange = 1;
 
-         if (params) {
 
-           if (params.has("EarlyChange")) {
 
-             earlyChange = params.get("EarlyChange");
 
-           }
 
-           return new _stream.PredictorStream(new _stream.LZWStream(stream, maybeLength, earlyChange), maybeLength, params);
 
-         }
 
-         return new _stream.LZWStream(stream, maybeLength, earlyChange);
 
-       }
 
-       if (name === "DCTDecode" || name === "DCT") {
 
-         xrefStreamStats[_util.StreamType.DCT] = true;
 
-         return new _jpeg_stream.JpegStream(stream, maybeLength, stream.dict, params);
 
-       }
 
-       if (name === "JPXDecode" || name === "JPX") {
 
-         xrefStreamStats[_util.StreamType.JPX] = true;
 
-         return new _jpx_stream.JpxStream(stream, maybeLength, stream.dict, params);
 
-       }
 
-       if (name === "ASCII85Decode" || name === "A85") {
 
-         xrefStreamStats[_util.StreamType.A85] = true;
 
-         return new _stream.Ascii85Stream(stream, maybeLength);
 
-       }
 
-       if (name === "ASCIIHexDecode" || name === "AHx") {
 
-         xrefStreamStats[_util.StreamType.AHX] = true;
 
-         return new _stream.AsciiHexStream(stream, maybeLength);
 
-       }
 
-       if (name === "CCITTFaxDecode" || name === "CCF") {
 
-         xrefStreamStats[_util.StreamType.CCF] = true;
 
-         return new _ccitt_stream.CCITTFaxStream(stream, maybeLength, params);
 
-       }
 
-       if (name === "RunLengthDecode" || name === "RL") {
 
-         xrefStreamStats[_util.StreamType.RLX] = true;
 
-         return new _stream.RunLengthStream(stream, maybeLength);
 
-       }
 
-       if (name === "JBIG2Decode") {
 
-         xrefStreamStats[_util.StreamType.JBIG] = true;
 
-         return new _jbig2_stream.Jbig2Stream(stream, maybeLength, stream.dict, params);
 
-       }
 
-       (0, _util.warn)(`Filter "${name}" is not supported.`);
 
-       return stream;
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       (0, _util.warn)(`Invalid stream: "${ex}"`);
 
-       return new _stream.NullStream();
 
-     }
 
-   }
 
- }
 
- exports.Parser = Parser;
 
- const specialChars = [1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 2, 0, 0, 2, 2, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
 
- function toHexDigit(ch) {
 
-   if (ch >= 0x30 && ch <= 0x39) {
 
-     return ch & 0x0f;
 
-   }
 
-   if (ch >= 0x41 && ch <= 0x46 || ch >= 0x61 && ch <= 0x66) {
 
-     return (ch & 0x0f) + 9;
 
-   }
 
-   return -1;
 
- }
 
- class Lexer {
 
-   constructor(stream, knownCommands = null) {
 
-     this.stream = stream;
 
-     this.nextChar();
 
-     this.strBuf = [];
 
-     this.knownCommands = knownCommands;
 
-     this._hexStringNumWarn = 0;
 
-     this.beginInlineImagePos = -1;
 
-   }
 
-   nextChar() {
 
-     return this.currentChar = this.stream.getByte();
 
-   }
 
-   peekChar() {
 
-     return this.stream.peekByte();
 
-   }
 
-   getNumber() {
 
-     let ch = this.currentChar;
 
-     let eNotation = false;
 
-     let divideBy = 0;
 
-     let sign = 0;
 
-     if (ch === 0x2d) {
 
-       sign = -1;
 
-       ch = this.nextChar();
 
-       if (ch === 0x2d) {
 
-         ch = this.nextChar();
 
-       }
 
-     } else if (ch === 0x2b) {
 
-       sign = 1;
 
-       ch = this.nextChar();
 
-     }
 
-     if (ch === 0x0a || ch === 0x0d) {
 
-       do {
 
-         ch = this.nextChar();
 
-       } while (ch === 0x0a || ch === 0x0d);
 
-     }
 
-     if (ch === 0x2e) {
 
-       divideBy = 10;
 
-       ch = this.nextChar();
 
-     }
 
-     if (ch < 0x30 || ch > 0x39) {
 
-       if (divideBy === 10 && sign === 0 && ((0, _core_utils.isWhiteSpace)(ch) || ch === -1)) {
 
-         (0, _util.warn)("Lexer.getNumber - treating a single decimal point as zero.");
 
-         return 0;
 
-       }
 
-       throw new _util.FormatError(`Invalid number: ${String.fromCharCode(ch)} (charCode ${ch})`);
 
-     }
 
-     sign = sign || 1;
 
-     let baseValue = ch - 0x30;
 
-     let powerValue = 0;
 
-     let powerValueSign = 1;
 
-     while ((ch = this.nextChar()) >= 0) {
 
-       if (ch >= 0x30 && ch <= 0x39) {
 
-         const currentDigit = ch - 0x30;
 
-         if (eNotation) {
 
-           powerValue = powerValue * 10 + currentDigit;
 
-         } else {
 
-           if (divideBy !== 0) {
 
-             divideBy *= 10;
 
-           }
 
-           baseValue = baseValue * 10 + currentDigit;
 
-         }
 
-       } else if (ch === 0x2e) {
 
-         if (divideBy === 0) {
 
-           divideBy = 1;
 
-         } else {
 
-           break;
 
-         }
 
-       } else if (ch === 0x2d) {
 
-         (0, _util.warn)("Badly formatted number: minus sign in the middle");
 
-       } else if (ch === 0x45 || ch === 0x65) {
 
-         ch = this.peekChar();
 
-         if (ch === 0x2b || ch === 0x2d) {
 
-           powerValueSign = ch === 0x2d ? -1 : 1;
 
-           this.nextChar();
 
-         } else if (ch < 0x30 || ch > 0x39) {
 
-           break;
 
-         }
 
-         eNotation = true;
 
-       } else {
 
-         break;
 
-       }
 
-     }
 
-     if (divideBy !== 0) {
 
-       baseValue /= divideBy;
 
-     }
 
-     if (eNotation) {
 
-       baseValue *= 10 ** (powerValueSign * powerValue);
 
-     }
 
-     return sign * baseValue;
 
-   }
 
-   getString() {
 
-     let numParen = 1;
 
-     let done = false;
 
-     const strBuf = this.strBuf;
 
-     strBuf.length = 0;
 
-     let ch = this.nextChar();
 
-     while (true) {
 
-       let charBuffered = false;
 
-       switch (ch | 0) {
 
-         case -1:
 
-           (0, _util.warn)("Unterminated string");
 
-           done = true;
 
-           break;
 
-         case 0x28:
 
-           ++numParen;
 
-           strBuf.push("(");
 
-           break;
 
-         case 0x29:
 
-           if (--numParen === 0) {
 
-             this.nextChar();
 
-             done = true;
 
-           } else {
 
-             strBuf.push(")");
 
-           }
 
-           break;
 
-         case 0x5c:
 
-           ch = this.nextChar();
 
-           switch (ch) {
 
-             case -1:
 
-               (0, _util.warn)("Unterminated string");
 
-               done = true;
 
-               break;
 
-             case 0x6e:
 
-               strBuf.push("\n");
 
-               break;
 
-             case 0x72:
 
-               strBuf.push("\r");
 
-               break;
 
-             case 0x74:
 
-               strBuf.push("\t");
 
-               break;
 
-             case 0x62:
 
-               strBuf.push("\b");
 
-               break;
 
-             case 0x66:
 
-               strBuf.push("\f");
 
-               break;
 
-             case 0x5c:
 
-             case 0x28:
 
-             case 0x29:
 
-               strBuf.push(String.fromCharCode(ch));
 
-               break;
 
-             case 0x30:
 
-             case 0x31:
 
-             case 0x32:
 
-             case 0x33:
 
-             case 0x34:
 
-             case 0x35:
 
-             case 0x36:
 
-             case 0x37:
 
-               let x = ch & 0x0f;
 
-               ch = this.nextChar();
 
-               charBuffered = true;
 
-               if (ch >= 0x30 && ch <= 0x37) {
 
-                 x = (x << 3) + (ch & 0x0f);
 
-                 ch = this.nextChar();
 
-                 if (ch >= 0x30 && ch <= 0x37) {
 
-                   charBuffered = false;
 
-                   x = (x << 3) + (ch & 0x0f);
 
-                 }
 
-               }
 
-               strBuf.push(String.fromCharCode(x));
 
-               break;
 
-             case 0x0d:
 
-               if (this.peekChar() === 0x0a) {
 
-                 this.nextChar();
 
-               }
 
-               break;
 
-             case 0x0a:
 
-               break;
 
-             default:
 
-               strBuf.push(String.fromCharCode(ch));
 
-               break;
 
-           }
 
-           break;
 
-         default:
 
-           strBuf.push(String.fromCharCode(ch));
 
-           break;
 
-       }
 
-       if (done) {
 
-         break;
 
-       }
 
-       if (!charBuffered) {
 
-         ch = this.nextChar();
 
-       }
 
-     }
 
-     return strBuf.join("");
 
-   }
 
-   getName() {
 
-     let ch, previousCh;
 
-     const strBuf = this.strBuf;
 
-     strBuf.length = 0;
 
-     while ((ch = this.nextChar()) >= 0 && !specialChars[ch]) {
 
-       if (ch === 0x23) {
 
-         ch = this.nextChar();
 
-         if (specialChars[ch]) {
 
-           (0, _util.warn)("Lexer_getName: " + "NUMBER SIGN (#) should be followed by a hexadecimal number.");
 
-           strBuf.push("#");
 
-           break;
 
-         }
 
-         const x = toHexDigit(ch);
 
-         if (x !== -1) {
 
-           previousCh = ch;
 
-           ch = this.nextChar();
 
-           const x2 = toHexDigit(ch);
 
-           if (x2 === -1) {
 
-             (0, _util.warn)(`Lexer_getName: Illegal digit (${String.fromCharCode(ch)}) ` + "in hexadecimal number.");
 
-             strBuf.push("#", String.fromCharCode(previousCh));
 
-             if (specialChars[ch]) {
 
-               break;
 
-             }
 
-             strBuf.push(String.fromCharCode(ch));
 
-             continue;
 
-           }
 
-           strBuf.push(String.fromCharCode(x << 4 | x2));
 
-         } else {
 
-           strBuf.push("#", String.fromCharCode(ch));
 
-         }
 
-       } else {
 
-         strBuf.push(String.fromCharCode(ch));
 
-       }
 
-     }
 
-     if (strBuf.length > 127) {
 
-       (0, _util.warn)(`Name token is longer than allowed by the spec: ${strBuf.length}`);
 
-     }
 
-     return _primitives.Name.get(strBuf.join(""));
 
-   }
 
-   _hexStringWarn(ch) {
 
-     const MAX_HEX_STRING_NUM_WARN = 5;
 
-     if (this._hexStringNumWarn++ === MAX_HEX_STRING_NUM_WARN) {
 
-       (0, _util.warn)("getHexString - ignoring additional invalid characters.");
 
-       return;
 
-     }
 
-     if (this._hexStringNumWarn > MAX_HEX_STRING_NUM_WARN) {
 
-       return;
 
-     }
 
-     (0, _util.warn)(`getHexString - ignoring invalid character: ${ch}`);
 
-   }
 
-   getHexString() {
 
-     const strBuf = this.strBuf;
 
-     strBuf.length = 0;
 
-     let ch = this.currentChar;
 
-     let isFirstHex = true;
 
-     let firstDigit, secondDigit;
 
-     this._hexStringNumWarn = 0;
 
-     while (true) {
 
-       if (ch < 0) {
 
-         (0, _util.warn)("Unterminated hex string");
 
-         break;
 
-       } else if (ch === 0x3e) {
 
-         this.nextChar();
 
-         break;
 
-       } else if (specialChars[ch] === 1) {
 
-         ch = this.nextChar();
 
-         continue;
 
-       } else {
 
-         if (isFirstHex) {
 
-           firstDigit = toHexDigit(ch);
 
-           if (firstDigit === -1) {
 
-             this._hexStringWarn(ch);
 
-             ch = this.nextChar();
 
-             continue;
 
-           }
 
-         } else {
 
-           secondDigit = toHexDigit(ch);
 
-           if (secondDigit === -1) {
 
-             this._hexStringWarn(ch);
 
-             ch = this.nextChar();
 
-             continue;
 
-           }
 
-           strBuf.push(String.fromCharCode(firstDigit << 4 | secondDigit));
 
-         }
 
-         isFirstHex = !isFirstHex;
 
-         ch = this.nextChar();
 
-       }
 
-     }
 
-     return strBuf.join("");
 
-   }
 
-   getObj() {
 
-     let comment = false;
 
-     let ch = this.currentChar;
 
-     while (true) {
 
-       if (ch < 0) {
 
-         return _primitives.EOF;
 
-       }
 
-       if (comment) {
 
-         if (ch === 0x0a || ch === 0x0d) {
 
-           comment = false;
 
-         }
 
-       } else if (ch === 0x25) {
 
-         comment = true;
 
-       } else if (specialChars[ch] !== 1) {
 
-         break;
 
-       }
 
-       ch = this.nextChar();
 
-     }
 
-     switch (ch | 0) {
 
-       case 0x30:
 
-       case 0x31:
 
-       case 0x32:
 
-       case 0x33:
 
-       case 0x34:
 
-       case 0x35:
 
-       case 0x36:
 
-       case 0x37:
 
-       case 0x38:
 
-       case 0x39:
 
-       case 0x2b:
 
-       case 0x2d:
 
-       case 0x2e:
 
-         return this.getNumber();
 
-       case 0x28:
 
-         return this.getString();
 
-       case 0x2f:
 
-         return this.getName();
 
-       case 0x5b:
 
-         this.nextChar();
 
-         return _primitives.Cmd.get("[");
 
-       case 0x5d:
 
-         this.nextChar();
 
-         return _primitives.Cmd.get("]");
 
-       case 0x3c:
 
-         ch = this.nextChar();
 
-         if (ch === 0x3c) {
 
-           this.nextChar();
 
-           return _primitives.Cmd.get("<<");
 
-         }
 
-         return this.getHexString();
 
-       case 0x3e:
 
-         ch = this.nextChar();
 
-         if (ch === 0x3e) {
 
-           this.nextChar();
 
-           return _primitives.Cmd.get(">>");
 
-         }
 
-         return _primitives.Cmd.get(">");
 
-       case 0x7b:
 
-         this.nextChar();
 
-         return _primitives.Cmd.get("{");
 
-       case 0x7d:
 
-         this.nextChar();
 
-         return _primitives.Cmd.get("}");
 
-       case 0x29:
 
-         this.nextChar();
 
-         throw new _util.FormatError(`Illegal character: ${ch}`);
 
-     }
 
-     let str = String.fromCharCode(ch);
 
-     const knownCommands = this.knownCommands;
 
-     let knownCommandFound = knownCommands && knownCommands[str] !== undefined;
 
-     while ((ch = this.nextChar()) >= 0 && !specialChars[ch]) {
 
-       const possibleCommand = str + String.fromCharCode(ch);
 
-       if (knownCommandFound && knownCommands[possibleCommand] === undefined) {
 
-         break;
 
-       }
 
-       if (str.length === 128) {
 
-         throw new _util.FormatError(`Command token too long: ${str.length}`);
 
-       }
 
-       str = possibleCommand;
 
-       knownCommandFound = knownCommands && knownCommands[str] !== undefined;
 
-     }
 
-     if (str === "true") {
 
-       return true;
 
-     }
 
-     if (str === "false") {
 
-       return false;
 
-     }
 
-     if (str === "null") {
 
-       return null;
 
-     }
 
-     if (str === "BI") {
 
-       this.beginInlineImagePos = this.stream.pos;
 
-     }
 
-     return _primitives.Cmd.get(str);
 
-   }
 
-   skipToNextLine() {
 
-     let ch = this.currentChar;
 
-     while (ch >= 0) {
 
-       if (ch === 0x0d) {
 
-         ch = this.nextChar();
 
-         if (ch === 0x0a) {
 
-           this.nextChar();
 
-         }
 
-         break;
 
-       } else if (ch === 0x0a) {
 
-         this.nextChar();
 
-         break;
 
-       }
 
-       ch = this.nextChar();
 
-     }
 
-   }
 
- }
 
- exports.Lexer = Lexer;
 
- class Linearization {
 
-   static create(stream) {
 
-     function getInt(linDict, name, allowZeroValue = false) {
 
-       const obj = linDict.get(name);
 
-       if (Number.isInteger(obj) && (allowZeroValue ? obj >= 0 : obj > 0)) {
 
-         return obj;
 
-       }
 
-       throw new Error(`The "${name}" parameter in the linearization ` + "dictionary is invalid.");
 
-     }
 
-     function getHints(linDict) {
 
-       const hints = linDict.get("H");
 
-       let hintsLength;
 
-       if (Array.isArray(hints) && ((hintsLength = hints.length) === 2 || hintsLength === 4)) {
 
-         for (let index = 0; index < hintsLength; index++) {
 
-           const hint = hints[index];
 
-           if (!(Number.isInteger(hint) && hint > 0)) {
 
-             throw new Error(`Hint (${index}) in the linearization dictionary is invalid.`);
 
-           }
 
-         }
 
-         return hints;
 
-       }
 
-       throw new Error("Hint array in the linearization dictionary is invalid.");
 
-     }
 
-     const parser = new Parser({
 
-       lexer: new Lexer(stream),
 
-       xref: null
 
-     });
 
-     const obj1 = parser.getObj();
 
-     const obj2 = parser.getObj();
 
-     const obj3 = parser.getObj();
 
-     const linDict = parser.getObj();
 
-     let obj, length;
 
-     if (!(Number.isInteger(obj1) && Number.isInteger(obj2) && (0, _primitives.isCmd)(obj3, "obj") && (0, _primitives.isDict)(linDict) && (0, _util.isNum)(obj = linDict.get("Linearized")) && obj > 0)) {
 
-       return null;
 
-     } else if ((length = getInt(linDict, "L")) !== stream.length) {
 
-       throw new Error('The "L" parameter in the linearization dictionary ' + "does not equal the stream length.");
 
-     }
 
-     return {
 
-       length,
 
-       hints: getHints(linDict),
 
-       objectNumberFirst: getInt(linDict, "O"),
 
-       endFirst: getInt(linDict, "E"),
 
-       numPages: getInt(linDict, "N"),
 
-       mainXRefEntriesOffset: getInt(linDict, "T"),
 
-       pageFirst: linDict.has("P") ? getInt(linDict, "P", true) : 0
 
-     };
 
-   }
 
- }
 
- exports.Linearization = Linearization;
 
- /***/ }),
 
- /* 11 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.LZWStream = exports.StringStream = exports.StreamsSequenceStream = exports.Stream = exports.RunLengthStream = exports.PredictorStream = exports.NullStream = exports.FlateStream = exports.DecodeStream = exports.DecryptStream = exports.AsciiHexStream = exports.Ascii85Stream = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var Stream = function StreamClosure() {
 
-   function Stream(arrayBuffer, start, length, dict) {
 
-     this.bytes = arrayBuffer instanceof Uint8Array ? arrayBuffer : new Uint8Array(arrayBuffer);
 
-     this.start = start || 0;
 
-     this.pos = this.start;
 
-     this.end = start + length || this.bytes.length;
 
-     this.dict = dict;
 
-   }
 
-   Stream.prototype = {
 
-     get length() {
 
-       return this.end - this.start;
 
-     },
 
-     get isEmpty() {
 
-       return this.length === 0;
 
-     },
 
-     getByte: function Stream_getByte() {
 
-       if (this.pos >= this.end) {
 
-         return -1;
 
-       }
 
-       return this.bytes[this.pos++];
 
-     },
 
-     getUint16: function Stream_getUint16() {
 
-       var b0 = this.getByte();
 
-       var b1 = this.getByte();
 
-       if (b0 === -1 || b1 === -1) {
 
-         return -1;
 
-       }
 
-       return (b0 << 8) + b1;
 
-     },
 
-     getInt32: function Stream_getInt32() {
 
-       var b0 = this.getByte();
 
-       var b1 = this.getByte();
 
-       var b2 = this.getByte();
 
-       var b3 = this.getByte();
 
-       return (b0 << 24) + (b1 << 16) + (b2 << 8) + b3;
 
-     },
 
-     getBytes(length, forceClamped = false) {
 
-       var bytes = this.bytes;
 
-       var pos = this.pos;
 
-       var strEnd = this.end;
 
-       if (!length) {
 
-         const subarray = bytes.subarray(pos, strEnd);
 
-         return forceClamped ? new Uint8ClampedArray(subarray) : subarray;
 
-       }
 
-       var end = pos + length;
 
-       if (end > strEnd) {
 
-         end = strEnd;
 
-       }
 
-       this.pos = end;
 
-       const subarray = bytes.subarray(pos, end);
 
-       return forceClamped ? new Uint8ClampedArray(subarray) : subarray;
 
-     },
 
-     peekByte: function Stream_peekByte() {
 
-       var peekedByte = this.getByte();
 
-       if (peekedByte !== -1) {
 
-         this.pos--;
 
-       }
 
-       return peekedByte;
 
-     },
 
-     peekBytes(length, forceClamped = false) {
 
-       var bytes = this.getBytes(length, forceClamped);
 
-       this.pos -= bytes.length;
 
-       return bytes;
 
-     },
 
-     getByteRange(begin, end) {
 
-       if (begin < 0) {
 
-         begin = 0;
 
-       }
 
-       if (end > this.end) {
 
-         end = this.end;
 
-       }
 
-       return this.bytes.subarray(begin, end);
 
-     },
 
-     skip: function Stream_skip(n) {
 
-       if (!n) {
 
-         n = 1;
 
-       }
 
-       this.pos += n;
 
-     },
 
-     reset: function Stream_reset() {
 
-       this.pos = this.start;
 
-     },
 
-     moveStart: function Stream_moveStart() {
 
-       this.start = this.pos;
 
-     },
 
-     makeSubStream: function Stream_makeSubStream(start, length, dict) {
 
-       return new Stream(this.bytes.buffer, start, length, dict);
 
-     }
 
-   };
 
-   return Stream;
 
- }();
 
- exports.Stream = Stream;
 
- var StringStream = function StringStreamClosure() {
 
-   function StringStream(str) {
 
-     const bytes = (0, _util.stringToBytes)(str);
 
-     Stream.call(this, bytes);
 
-   }
 
-   StringStream.prototype = Stream.prototype;
 
-   return StringStream;
 
- }();
 
- exports.StringStream = StringStream;
 
- var DecodeStream = function DecodeStreamClosure() {
 
-   var emptyBuffer = new Uint8Array(0);
 
-   function DecodeStream(maybeMinBufferLength) {
 
-     this._rawMinBufferLength = maybeMinBufferLength || 0;
 
-     this.pos = 0;
 
-     this.bufferLength = 0;
 
-     this.eof = false;
 
-     this.buffer = emptyBuffer;
 
-     this.minBufferLength = 512;
 
-     if (maybeMinBufferLength) {
 
-       while (this.minBufferLength < maybeMinBufferLength) {
 
-         this.minBufferLength *= 2;
 
-       }
 
-     }
 
-   }
 
-   DecodeStream.prototype = {
 
-     get isEmpty() {
 
-       while (!this.eof && this.bufferLength === 0) {
 
-         this.readBlock();
 
-       }
 
-       return this.bufferLength === 0;
 
-     },
 
-     ensureBuffer: function DecodeStream_ensureBuffer(requested) {
 
-       var buffer = this.buffer;
 
-       if (requested <= buffer.byteLength) {
 
-         return buffer;
 
-       }
 
-       var size = this.minBufferLength;
 
-       while (size < requested) {
 
-         size *= 2;
 
-       }
 
-       var buffer2 = new Uint8Array(size);
 
-       buffer2.set(buffer);
 
-       return this.buffer = buffer2;
 
-     },
 
-     getByte: function DecodeStream_getByte() {
 
-       var pos = this.pos;
 
-       while (this.bufferLength <= pos) {
 
-         if (this.eof) {
 
-           return -1;
 
-         }
 
-         this.readBlock();
 
-       }
 
-       return this.buffer[this.pos++];
 
-     },
 
-     getUint16: function DecodeStream_getUint16() {
 
-       var b0 = this.getByte();
 
-       var b1 = this.getByte();
 
-       if (b0 === -1 || b1 === -1) {
 
-         return -1;
 
-       }
 
-       return (b0 << 8) + b1;
 
-     },
 
-     getInt32: function DecodeStream_getInt32() {
 
-       var b0 = this.getByte();
 
-       var b1 = this.getByte();
 
-       var b2 = this.getByte();
 
-       var b3 = this.getByte();
 
-       return (b0 << 24) + (b1 << 16) + (b2 << 8) + b3;
 
-     },
 
-     getBytes(length, forceClamped = false) {
 
-       var end,
 
-           pos = this.pos;
 
-       if (length) {
 
-         this.ensureBuffer(pos + length);
 
-         end = pos + length;
 
-         while (!this.eof && this.bufferLength < end) {
 
-           this.readBlock();
 
-         }
 
-         var bufEnd = this.bufferLength;
 
-         if (end > bufEnd) {
 
-           end = bufEnd;
 
-         }
 
-       } else {
 
-         while (!this.eof) {
 
-           this.readBlock();
 
-         }
 
-         end = this.bufferLength;
 
-       }
 
-       this.pos = end;
 
-       const subarray = this.buffer.subarray(pos, end);
 
-       return forceClamped && !(subarray instanceof Uint8ClampedArray) ? new Uint8ClampedArray(subarray) : subarray;
 
-     },
 
-     peekByte: function DecodeStream_peekByte() {
 
-       var peekedByte = this.getByte();
 
-       if (peekedByte !== -1) {
 
-         this.pos--;
 
-       }
 
-       return peekedByte;
 
-     },
 
-     peekBytes(length, forceClamped = false) {
 
-       var bytes = this.getBytes(length, forceClamped);
 
-       this.pos -= bytes.length;
 
-       return bytes;
 
-     },
 
-     makeSubStream: function DecodeStream_makeSubStream(start, length, dict) {
 
-       var end = start + length;
 
-       while (this.bufferLength <= end && !this.eof) {
 
-         this.readBlock();
 
-       }
 
-       return new Stream(this.buffer, start, length, dict);
 
-     },
 
-     getByteRange(begin, end) {
 
-       (0, _util.unreachable)("Should not call DecodeStream.getByteRange");
 
-     },
 
-     skip: function DecodeStream_skip(n) {
 
-       if (!n) {
 
-         n = 1;
 
-       }
 
-       this.pos += n;
 
-     },
 
-     reset: function DecodeStream_reset() {
 
-       this.pos = 0;
 
-     },
 
-     getBaseStreams: function DecodeStream_getBaseStreams() {
 
-       if (this.str && this.str.getBaseStreams) {
 
-         return this.str.getBaseStreams();
 
-       }
 
-       return [];
 
-     }
 
-   };
 
-   return DecodeStream;
 
- }();
 
- exports.DecodeStream = DecodeStream;
 
- var StreamsSequenceStream = function StreamsSequenceStreamClosure() {
 
-   function StreamsSequenceStream(streams) {
 
-     this.streams = streams;
 
-     let maybeLength = 0;
 
-     for (let i = 0, ii = streams.length; i < ii; i++) {
 
-       const stream = streams[i];
 
-       if (stream instanceof DecodeStream) {
 
-         maybeLength += stream._rawMinBufferLength;
 
-       } else {
 
-         maybeLength += stream.length;
 
-       }
 
-     }
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   StreamsSequenceStream.prototype = Object.create(DecodeStream.prototype);
 
-   StreamsSequenceStream.prototype.readBlock = function streamSequenceStreamReadBlock() {
 
-     var streams = this.streams;
 
-     if (streams.length === 0) {
 
-       this.eof = true;
 
-       return;
 
-     }
 
-     var stream = streams.shift();
 
-     var chunk = stream.getBytes();
 
-     var bufferLength = this.bufferLength;
 
-     var newLength = bufferLength + chunk.length;
 
-     var buffer = this.ensureBuffer(newLength);
 
-     buffer.set(chunk, bufferLength);
 
-     this.bufferLength = newLength;
 
-   };
 
-   StreamsSequenceStream.prototype.getBaseStreams = function StreamsSequenceStream_getBaseStreams() {
 
-     var baseStreams = [];
 
-     for (var i = 0, ii = this.streams.length; i < ii; i++) {
 
-       var stream = this.streams[i];
 
-       if (stream.getBaseStreams) {
 
-         baseStreams.push(...stream.getBaseStreams());
 
-       }
 
-     }
 
-     return baseStreams;
 
-   };
 
-   return StreamsSequenceStream;
 
- }();
 
- exports.StreamsSequenceStream = StreamsSequenceStream;
 
- var FlateStream = function FlateStreamClosure() {
 
-   var codeLenCodeMap = new Int32Array([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]);
 
-   var lengthDecode = new Int32Array([0x00003, 0x00004, 0x00005, 0x00006, 0x00007, 0x00008, 0x00009, 0x0000a, 0x1000b, 0x1000d, 0x1000f, 0x10011, 0x20013, 0x20017, 0x2001b, 0x2001f, 0x30023, 0x3002b, 0x30033, 0x3003b, 0x40043, 0x40053, 0x40063, 0x40073, 0x50083, 0x500a3, 0x500c3, 0x500e3, 0x00102, 0x00102, 0x00102]);
 
-   var distDecode = new Int32Array([0x00001, 0x00002, 0x00003, 0x00004, 0x10005, 0x10007, 0x20009, 0x2000d, 0x30011, 0x30019, 0x40021, 0x40031, 0x50041, 0x50061, 0x60081, 0x600c1, 0x70101, 0x70181, 0x80201, 0x80301, 0x90401, 0x90601, 0xa0801, 0xa0c01, 0xb1001, 0xb1801, 0xc2001, 0xc3001, 0xd4001, 0xd6001]);
 
-   var fixedLitCodeTab = [new Int32Array([0x70100, 0x80050, 0x80010, 0x80118, 0x70110, 0x80070, 0x80030, 0x900c0, 0x70108, 0x80060, 0x80020, 0x900a0, 0x80000, 0x80080, 0x80040, 0x900e0, 0x70104, 0x80058, 0x80018, 0x90090, 0x70114, 0x80078, 0x80038, 0x900d0, 0x7010c, 0x80068, 0x80028, 0x900b0, 0x80008, 0x80088, 0x80048, 0x900f0, 0x70102, 0x80054, 0x80014, 0x8011c, 0x70112, 0x80074, 0x80034, 0x900c8, 0x7010a, 0x80064, 0x80024, 0x900a8, 0x80004, 0x80084, 0x80044, 0x900e8, 0x70106, 0x8005c, 0x8001c, 0x90098, 0x70116, 0x8007c, 0x8003c, 0x900d8, 0x7010e, 0x8006c, 0x8002c, 0x900b8, 0x8000c, 0x8008c, 0x8004c, 0x900f8, 0x70101, 0x80052, 0x80012, 0x8011a, 0x70111, 0x80072, 0x80032, 0x900c4, 0x70109, 0x80062, 0x80022, 0x900a4, 0x80002, 0x80082, 0x80042, 0x900e4, 0x70105, 0x8005a, 0x8001a, 0x90094, 0x70115, 0x8007a, 0x8003a, 0x900d4, 0x7010d, 0x8006a, 0x8002a, 0x900b4, 0x8000a, 0x8008a, 0x8004a, 0x900f4, 0x70103, 0x80056, 0x80016, 0x8011e, 0x70113, 0x80076, 0x80036, 0x900cc, 0x7010b, 0x80066, 0x80026, 0x900ac, 0x80006, 0x80086, 0x80046, 0x900ec, 0x70107, 0x8005e, 0x8001e, 0x9009c, 0x70117, 0x8007e, 0x8003e, 0x900dc, 0x7010f, 0x8006e, 0x8002e, 0x900bc, 0x8000e, 0x8008e, 0x8004e, 0x900fc, 0x70100, 0x80051, 0x80011, 0x80119, 0x70110, 0x80071, 0x80031, 0x900c2, 0x70108, 0x80061, 0x80021, 0x900a2, 0x80001, 0x80081, 0x80041, 0x900e2, 0x70104, 0x80059, 0x80019, 0x90092, 0x70114, 0x80079, 0x80039, 0x900d2, 0x7010c, 0x80069, 0x80029, 0x900b2, 0x80009, 0x80089, 0x80049, 0x900f2, 0x70102, 0x80055, 0x80015, 0x8011d, 0x70112, 0x80075, 0x80035, 0x900ca, 0x7010a, 0x80065, 0x80025, 0x900aa, 0x80005, 0x80085, 0x80045, 0x900ea, 0x70106, 0x8005d, 0x8001d, 0x9009a, 0x70116, 0x8007d, 0x8003d, 0x900da, 0x7010e, 0x8006d, 0x8002d, 0x900ba, 0x8000d, 0x8008d, 0x8004d, 0x900fa, 0x70101, 0x80053, 0x80013, 0x8011b, 0x70111, 0x80073, 0x80033, 0x900c6, 0x70109, 0x80063, 0x80023, 0x900a6, 0x80003, 0x80083, 0x80043, 0x900e6, 0x70105, 0x8005b, 0x8001b, 0x90096, 0x70115, 0x8007b, 0x8003b, 0x900d6, 0x7010d, 0x8006b, 0x8002b, 0x900b6, 0x8000b, 0x8008b, 0x8004b, 0x900f6, 0x70103, 0x80057, 0x80017, 0x8011f, 0x70113, 0x80077, 0x80037, 0x900ce, 0x7010b, 0x80067, 0x80027, 0x900ae, 0x80007, 0x80087, 0x80047, 0x900ee, 0x70107, 0x8005f, 0x8001f, 0x9009e, 0x70117, 0x8007f, 0x8003f, 0x900de, 0x7010f, 0x8006f, 0x8002f, 0x900be, 0x8000f, 0x8008f, 0x8004f, 0x900fe, 0x70100, 0x80050, 0x80010, 0x80118, 0x70110, 0x80070, 0x80030, 0x900c1, 0x70108, 0x80060, 0x80020, 0x900a1, 0x80000, 0x80080, 0x80040, 0x900e1, 0x70104, 0x80058, 0x80018, 0x90091, 0x70114, 0x80078, 0x80038, 0x900d1, 0x7010c, 0x80068, 0x80028, 0x900b1, 0x80008, 0x80088, 0x80048, 0x900f1, 0x70102, 0x80054, 0x80014, 0x8011c, 0x70112, 0x80074, 0x80034, 0x900c9, 0x7010a, 0x80064, 0x80024, 0x900a9, 0x80004, 0x80084, 0x80044, 0x900e9, 0x70106, 0x8005c, 0x8001c, 0x90099, 0x70116, 0x8007c, 0x8003c, 0x900d9, 0x7010e, 0x8006c, 0x8002c, 0x900b9, 0x8000c, 0x8008c, 0x8004c, 0x900f9, 0x70101, 0x80052, 0x80012, 0x8011a, 0x70111, 0x80072, 0x80032, 0x900c5, 0x70109, 0x80062, 0x80022, 0x900a5, 0x80002, 0x80082, 0x80042, 0x900e5, 0x70105, 0x8005a, 0x8001a, 0x90095, 0x70115, 0x8007a, 0x8003a, 0x900d5, 0x7010d, 0x8006a, 0x8002a, 0x900b5, 0x8000a, 0x8008a, 0x8004a, 0x900f5, 0x70103, 0x80056, 0x80016, 0x8011e, 0x70113, 0x80076, 0x80036, 0x900cd, 0x7010b, 0x80066, 0x80026, 0x900ad, 0x80006, 0x80086, 0x80046, 0x900ed, 0x70107, 0x8005e, 0x8001e, 0x9009d, 0x70117, 0x8007e, 0x8003e, 0x900dd, 0x7010f, 0x8006e, 0x8002e, 0x900bd, 0x8000e, 0x8008e, 0x8004e, 0x900fd, 0x70100, 0x80051, 0x80011, 0x80119, 0x70110, 0x80071, 0x80031, 0x900c3, 0x70108, 0x80061, 0x80021, 0x900a3, 0x80001, 0x80081, 0x80041, 0x900e3, 0x70104, 0x80059, 0x80019, 0x90093, 0x70114, 0x80079, 0x80039, 0x900d3, 0x7010c, 0x80069, 0x80029, 0x900b3, 0x80009, 0x80089, 0x80049, 0x900f3, 0x70102, 0x80055, 0x80015, 0x8011d, 0x70112, 0x80075, 0x80035, 0x900cb, 0x7010a, 0x80065, 0x80025, 0x900ab, 0x80005, 0x80085, 0x80045, 0x900eb, 0x70106, 0x8005d, 0x8001d, 0x9009b, 0x70116, 0x8007d, 0x8003d, 0x900db, 0x7010e, 0x8006d, 0x8002d, 0x900bb, 0x8000d, 0x8008d, 0x8004d, 0x900fb, 0x70101, 0x80053, 0x80013, 0x8011b, 0x70111, 0x80073, 0x80033, 0x900c7, 0x70109, 0x80063, 0x80023, 0x900a7, 0x80003, 0x80083, 0x80043, 0x900e7, 0x70105, 0x8005b, 0x8001b, 0x90097, 0x70115, 0x8007b, 0x8003b, 0x900d7, 0x7010d, 0x8006b, 0x8002b, 0x900b7, 0x8000b, 0x8008b, 0x8004b, 0x900f7, 0x70103, 0x80057, 0x80017, 0x8011f, 0x70113, 0x80077, 0x80037, 0x900cf, 0x7010b, 0x80067, 0x80027, 0x900af, 0x80007, 0x80087, 0x80047, 0x900ef, 0x70107, 0x8005f, 0x8001f, 0x9009f, 0x70117, 0x8007f, 0x8003f, 0x900df, 0x7010f, 0x8006f, 0x8002f, 0x900bf, 0x8000f, 0x8008f, 0x8004f, 0x900ff]), 9];
 
-   var fixedDistCodeTab = [new Int32Array([0x50000, 0x50010, 0x50008, 0x50018, 0x50004, 0x50014, 0x5000c, 0x5001c, 0x50002, 0x50012, 0x5000a, 0x5001a, 0x50006, 0x50016, 0x5000e, 0x00000, 0x50001, 0x50011, 0x50009, 0x50019, 0x50005, 0x50015, 0x5000d, 0x5001d, 0x50003, 0x50013, 0x5000b, 0x5001b, 0x50007, 0x50017, 0x5000f, 0x00000]), 5];
 
-   function FlateStream(str, maybeLength) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     var cmf = str.getByte();
 
-     var flg = str.getByte();
 
-     if (cmf === -1 || flg === -1) {
 
-       throw new _util.FormatError(`Invalid header in flate stream: ${cmf}, ${flg}`);
 
-     }
 
-     if ((cmf & 0x0f) !== 0x08) {
 
-       throw new _util.FormatError(`Unknown compression method in flate stream: ${cmf}, ${flg}`);
 
-     }
 
-     if (((cmf << 8) + flg) % 31 !== 0) {
 
-       throw new _util.FormatError(`Bad FCHECK in flate stream: ${cmf}, ${flg}`);
 
-     }
 
-     if (flg & 0x20) {
 
-       throw new _util.FormatError(`FDICT bit set in flate stream: ${cmf}, ${flg}`);
 
-     }
 
-     this.codeSize = 0;
 
-     this.codeBuf = 0;
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   FlateStream.prototype = Object.create(DecodeStream.prototype);
 
-   FlateStream.prototype.getBits = function FlateStream_getBits(bits) {
 
-     var str = this.str;
 
-     var codeSize = this.codeSize;
 
-     var codeBuf = this.codeBuf;
 
-     var b;
 
-     while (codeSize < bits) {
 
-       if ((b = str.getByte()) === -1) {
 
-         throw new _util.FormatError("Bad encoding in flate stream");
 
-       }
 
-       codeBuf |= b << codeSize;
 
-       codeSize += 8;
 
-     }
 
-     b = codeBuf & (1 << bits) - 1;
 
-     this.codeBuf = codeBuf >> bits;
 
-     this.codeSize = codeSize -= bits;
 
-     return b;
 
-   };
 
-   FlateStream.prototype.getCode = function FlateStream_getCode(table) {
 
-     var str = this.str;
 
-     var codes = table[0];
 
-     var maxLen = table[1];
 
-     var codeSize = this.codeSize;
 
-     var codeBuf = this.codeBuf;
 
-     var b;
 
-     while (codeSize < maxLen) {
 
-       if ((b = str.getByte()) === -1) {
 
-         break;
 
-       }
 
-       codeBuf |= b << codeSize;
 
-       codeSize += 8;
 
-     }
 
-     var code = codes[codeBuf & (1 << maxLen) - 1];
 
-     var codeLen = code >> 16;
 
-     var codeVal = code & 0xffff;
 
-     if (codeLen < 1 || codeSize < codeLen) {
 
-       throw new _util.FormatError("Bad encoding in flate stream");
 
-     }
 
-     this.codeBuf = codeBuf >> codeLen;
 
-     this.codeSize = codeSize - codeLen;
 
-     return codeVal;
 
-   };
 
-   FlateStream.prototype.generateHuffmanTable = function flateStreamGenerateHuffmanTable(lengths) {
 
-     var n = lengths.length;
 
-     var maxLen = 0;
 
-     var i;
 
-     for (i = 0; i < n; ++i) {
 
-       if (lengths[i] > maxLen) {
 
-         maxLen = lengths[i];
 
-       }
 
-     }
 
-     var size = 1 << maxLen;
 
-     var codes = new Int32Array(size);
 
-     for (var len = 1, code = 0, skip = 2; len <= maxLen; ++len, code <<= 1, skip <<= 1) {
 
-       for (var val = 0; val < n; ++val) {
 
-         if (lengths[val] === len) {
 
-           var code2 = 0;
 
-           var t = code;
 
-           for (i = 0; i < len; ++i) {
 
-             code2 = code2 << 1 | t & 1;
 
-             t >>= 1;
 
-           }
 
-           for (i = code2; i < size; i += skip) {
 
-             codes[i] = len << 16 | val;
 
-           }
 
-           ++code;
 
-         }
 
-       }
 
-     }
 
-     return [codes, maxLen];
 
-   };
 
-   FlateStream.prototype.readBlock = function FlateStream_readBlock() {
 
-     var buffer, len;
 
-     var str = this.str;
 
-     var hdr = this.getBits(3);
 
-     if (hdr & 1) {
 
-       this.eof = true;
 
-     }
 
-     hdr >>= 1;
 
-     if (hdr === 0) {
 
-       var b;
 
-       if ((b = str.getByte()) === -1) {
 
-         throw new _util.FormatError("Bad block header in flate stream");
 
-       }
 
-       var blockLen = b;
 
-       if ((b = str.getByte()) === -1) {
 
-         throw new _util.FormatError("Bad block header in flate stream");
 
-       }
 
-       blockLen |= b << 8;
 
-       if ((b = str.getByte()) === -1) {
 
-         throw new _util.FormatError("Bad block header in flate stream");
 
-       }
 
-       var check = b;
 
-       if ((b = str.getByte()) === -1) {
 
-         throw new _util.FormatError("Bad block header in flate stream");
 
-       }
 
-       check |= b << 8;
 
-       if (check !== (~blockLen & 0xffff) && (blockLen !== 0 || check !== 0)) {
 
-         throw new _util.FormatError("Bad uncompressed block length in flate stream");
 
-       }
 
-       this.codeBuf = 0;
 
-       this.codeSize = 0;
 
-       const bufferLength = this.bufferLength,
 
-             end = bufferLength + blockLen;
 
-       buffer = this.ensureBuffer(end);
 
-       this.bufferLength = end;
 
-       if (blockLen === 0) {
 
-         if (str.peekByte() === -1) {
 
-           this.eof = true;
 
-         }
 
-       } else {
 
-         const block = str.getBytes(blockLen);
 
-         buffer.set(block, bufferLength);
 
-         if (block.length < blockLen) {
 
-           this.eof = true;
 
-         }
 
-       }
 
-       return;
 
-     }
 
-     var litCodeTable;
 
-     var distCodeTable;
 
-     if (hdr === 1) {
 
-       litCodeTable = fixedLitCodeTab;
 
-       distCodeTable = fixedDistCodeTab;
 
-     } else if (hdr === 2) {
 
-       var numLitCodes = this.getBits(5) + 257;
 
-       var numDistCodes = this.getBits(5) + 1;
 
-       var numCodeLenCodes = this.getBits(4) + 4;
 
-       var codeLenCodeLengths = new Uint8Array(codeLenCodeMap.length);
 
-       var i;
 
-       for (i = 0; i < numCodeLenCodes; ++i) {
 
-         codeLenCodeLengths[codeLenCodeMap[i]] = this.getBits(3);
 
-       }
 
-       var codeLenCodeTab = this.generateHuffmanTable(codeLenCodeLengths);
 
-       len = 0;
 
-       i = 0;
 
-       var codes = numLitCodes + numDistCodes;
 
-       var codeLengths = new Uint8Array(codes);
 
-       var bitsLength, bitsOffset, what;
 
-       while (i < codes) {
 
-         var code = this.getCode(codeLenCodeTab);
 
-         if (code === 16) {
 
-           bitsLength = 2;
 
-           bitsOffset = 3;
 
-           what = len;
 
-         } else if (code === 17) {
 
-           bitsLength = 3;
 
-           bitsOffset = 3;
 
-           what = len = 0;
 
-         } else if (code === 18) {
 
-           bitsLength = 7;
 
-           bitsOffset = 11;
 
-           what = len = 0;
 
-         } else {
 
-           codeLengths[i++] = len = code;
 
-           continue;
 
-         }
 
-         var repeatLength = this.getBits(bitsLength) + bitsOffset;
 
-         while (repeatLength-- > 0) {
 
-           codeLengths[i++] = what;
 
-         }
 
-       }
 
-       litCodeTable = this.generateHuffmanTable(codeLengths.subarray(0, numLitCodes));
 
-       distCodeTable = this.generateHuffmanTable(codeLengths.subarray(numLitCodes, codes));
 
-     } else {
 
-       throw new _util.FormatError("Unknown block type in flate stream");
 
-     }
 
-     buffer = this.buffer;
 
-     var limit = buffer ? buffer.length : 0;
 
-     var pos = this.bufferLength;
 
-     while (true) {
 
-       var code1 = this.getCode(litCodeTable);
 
-       if (code1 < 256) {
 
-         if (pos + 1 >= limit) {
 
-           buffer = this.ensureBuffer(pos + 1);
 
-           limit = buffer.length;
 
-         }
 
-         buffer[pos++] = code1;
 
-         continue;
 
-       }
 
-       if (code1 === 256) {
 
-         this.bufferLength = pos;
 
-         return;
 
-       }
 
-       code1 -= 257;
 
-       code1 = lengthDecode[code1];
 
-       var code2 = code1 >> 16;
 
-       if (code2 > 0) {
 
-         code2 = this.getBits(code2);
 
-       }
 
-       len = (code1 & 0xffff) + code2;
 
-       code1 = this.getCode(distCodeTable);
 
-       code1 = distDecode[code1];
 
-       code2 = code1 >> 16;
 
-       if (code2 > 0) {
 
-         code2 = this.getBits(code2);
 
-       }
 
-       var dist = (code1 & 0xffff) + code2;
 
-       if (pos + len >= limit) {
 
-         buffer = this.ensureBuffer(pos + len);
 
-         limit = buffer.length;
 
-       }
 
-       for (var k = 0; k < len; ++k, ++pos) {
 
-         buffer[pos] = buffer[pos - dist];
 
-       }
 
-     }
 
-   };
 
-   return FlateStream;
 
- }();
 
- exports.FlateStream = FlateStream;
 
- var PredictorStream = function PredictorStreamClosure() {
 
-   function PredictorStream(str, maybeLength, params) {
 
-     if (!(0, _primitives.isDict)(params)) {
 
-       return str;
 
-     }
 
-     var predictor = this.predictor = params.get("Predictor") || 1;
 
-     if (predictor <= 1) {
 
-       return str;
 
-     }
 
-     if (predictor !== 2 && (predictor < 10 || predictor > 15)) {
 
-       throw new _util.FormatError(`Unsupported predictor: ${predictor}`);
 
-     }
 
-     if (predictor === 2) {
 
-       this.readBlock = this.readBlockTiff;
 
-     } else {
 
-       this.readBlock = this.readBlockPng;
 
-     }
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     var colors = this.colors = params.get("Colors") || 1;
 
-     var bits = this.bits = params.get("BitsPerComponent") || 8;
 
-     var columns = this.columns = params.get("Columns") || 1;
 
-     this.pixBytes = colors * bits + 7 >> 3;
 
-     this.rowBytes = columns * colors * bits + 7 >> 3;
 
-     DecodeStream.call(this, maybeLength);
 
-     return this;
 
-   }
 
-   PredictorStream.prototype = Object.create(DecodeStream.prototype);
 
-   PredictorStream.prototype.readBlockTiff = function predictorStreamReadBlockTiff() {
 
-     var rowBytes = this.rowBytes;
 
-     var bufferLength = this.bufferLength;
 
-     var buffer = this.ensureBuffer(bufferLength + rowBytes);
 
-     var bits = this.bits;
 
-     var colors = this.colors;
 
-     var rawBytes = this.str.getBytes(rowBytes);
 
-     this.eof = !rawBytes.length;
 
-     if (this.eof) {
 
-       return;
 
-     }
 
-     var inbuf = 0,
 
-         outbuf = 0;
 
-     var inbits = 0,
 
-         outbits = 0;
 
-     var pos = bufferLength;
 
-     var i;
 
-     if (bits === 1 && colors === 1) {
 
-       for (i = 0; i < rowBytes; ++i) {
 
-         var c = rawBytes[i] ^ inbuf;
 
-         c ^= c >> 1;
 
-         c ^= c >> 2;
 
-         c ^= c >> 4;
 
-         inbuf = (c & 1) << 7;
 
-         buffer[pos++] = c;
 
-       }
 
-     } else if (bits === 8) {
 
-       for (i = 0; i < colors; ++i) {
 
-         buffer[pos++] = rawBytes[i];
 
-       }
 
-       for (; i < rowBytes; ++i) {
 
-         buffer[pos] = buffer[pos - colors] + rawBytes[i];
 
-         pos++;
 
-       }
 
-     } else if (bits === 16) {
 
-       var bytesPerPixel = colors * 2;
 
-       for (i = 0; i < bytesPerPixel; ++i) {
 
-         buffer[pos++] = rawBytes[i];
 
-       }
 
-       for (; i < rowBytes; i += 2) {
 
-         var sum = ((rawBytes[i] & 0xff) << 8) + (rawBytes[i + 1] & 0xff) + ((buffer[pos - bytesPerPixel] & 0xff) << 8) + (buffer[pos - bytesPerPixel + 1] & 0xff);
 
-         buffer[pos++] = sum >> 8 & 0xff;
 
-         buffer[pos++] = sum & 0xff;
 
-       }
 
-     } else {
 
-       var compArray = new Uint8Array(colors + 1);
 
-       var bitMask = (1 << bits) - 1;
 
-       var j = 0,
 
-           k = bufferLength;
 
-       var columns = this.columns;
 
-       for (i = 0; i < columns; ++i) {
 
-         for (var kk = 0; kk < colors; ++kk) {
 
-           if (inbits < bits) {
 
-             inbuf = inbuf << 8 | rawBytes[j++] & 0xff;
 
-             inbits += 8;
 
-           }
 
-           compArray[kk] = compArray[kk] + (inbuf >> inbits - bits) & bitMask;
 
-           inbits -= bits;
 
-           outbuf = outbuf << bits | compArray[kk];
 
-           outbits += bits;
 
-           if (outbits >= 8) {
 
-             buffer[k++] = outbuf >> outbits - 8 & 0xff;
 
-             outbits -= 8;
 
-           }
 
-         }
 
-       }
 
-       if (outbits > 0) {
 
-         buffer[k++] = (outbuf << 8 - outbits) + (inbuf & (1 << 8 - outbits) - 1);
 
-       }
 
-     }
 
-     this.bufferLength += rowBytes;
 
-   };
 
-   PredictorStream.prototype.readBlockPng = function predictorStreamReadBlockPng() {
 
-     var rowBytes = this.rowBytes;
 
-     var pixBytes = this.pixBytes;
 
-     var predictor = this.str.getByte();
 
-     var rawBytes = this.str.getBytes(rowBytes);
 
-     this.eof = !rawBytes.length;
 
-     if (this.eof) {
 
-       return;
 
-     }
 
-     var bufferLength = this.bufferLength;
 
-     var buffer = this.ensureBuffer(bufferLength + rowBytes);
 
-     var prevRow = buffer.subarray(bufferLength - rowBytes, bufferLength);
 
-     if (prevRow.length === 0) {
 
-       prevRow = new Uint8Array(rowBytes);
 
-     }
 
-     var i,
 
-         j = bufferLength,
 
-         up,
 
-         c;
 
-     switch (predictor) {
 
-       case 0:
 
-         for (i = 0; i < rowBytes; ++i) {
 
-           buffer[j++] = rawBytes[i];
 
-         }
 
-         break;
 
-       case 1:
 
-         for (i = 0; i < pixBytes; ++i) {
 
-           buffer[j++] = rawBytes[i];
 
-         }
 
-         for (; i < rowBytes; ++i) {
 
-           buffer[j] = buffer[j - pixBytes] + rawBytes[i] & 0xff;
 
-           j++;
 
-         }
 
-         break;
 
-       case 2:
 
-         for (i = 0; i < rowBytes; ++i) {
 
-           buffer[j++] = prevRow[i] + rawBytes[i] & 0xff;
 
-         }
 
-         break;
 
-       case 3:
 
-         for (i = 0; i < pixBytes; ++i) {
 
-           buffer[j++] = (prevRow[i] >> 1) + rawBytes[i];
 
-         }
 
-         for (; i < rowBytes; ++i) {
 
-           buffer[j] = (prevRow[i] + buffer[j - pixBytes] >> 1) + rawBytes[i] & 0xff;
 
-           j++;
 
-         }
 
-         break;
 
-       case 4:
 
-         for (i = 0; i < pixBytes; ++i) {
 
-           up = prevRow[i];
 
-           c = rawBytes[i];
 
-           buffer[j++] = up + c;
 
-         }
 
-         for (; i < rowBytes; ++i) {
 
-           up = prevRow[i];
 
-           var upLeft = prevRow[i - pixBytes];
 
-           var left = buffer[j - pixBytes];
 
-           var p = left + up - upLeft;
 
-           var pa = p - left;
 
-           if (pa < 0) {
 
-             pa = -pa;
 
-           }
 
-           var pb = p - up;
 
-           if (pb < 0) {
 
-             pb = -pb;
 
-           }
 
-           var pc = p - upLeft;
 
-           if (pc < 0) {
 
-             pc = -pc;
 
-           }
 
-           c = rawBytes[i];
 
-           if (pa <= pb && pa <= pc) {
 
-             buffer[j++] = left + c;
 
-           } else if (pb <= pc) {
 
-             buffer[j++] = up + c;
 
-           } else {
 
-             buffer[j++] = upLeft + c;
 
-           }
 
-         }
 
-         break;
 
-       default:
 
-         throw new _util.FormatError(`Unsupported predictor: ${predictor}`);
 
-     }
 
-     this.bufferLength += rowBytes;
 
-   };
 
-   return PredictorStream;
 
- }();
 
- exports.PredictorStream = PredictorStream;
 
- var DecryptStream = function DecryptStreamClosure() {
 
-   function DecryptStream(str, maybeLength, decrypt) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     this.decrypt = decrypt;
 
-     this.nextChunk = null;
 
-     this.initialized = false;
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   var chunkSize = 512;
 
-   DecryptStream.prototype = Object.create(DecodeStream.prototype);
 
-   DecryptStream.prototype.readBlock = function DecryptStream_readBlock() {
 
-     var chunk;
 
-     if (this.initialized) {
 
-       chunk = this.nextChunk;
 
-     } else {
 
-       chunk = this.str.getBytes(chunkSize);
 
-       this.initialized = true;
 
-     }
 
-     if (!chunk || chunk.length === 0) {
 
-       this.eof = true;
 
-       return;
 
-     }
 
-     this.nextChunk = this.str.getBytes(chunkSize);
 
-     var hasMoreData = this.nextChunk && this.nextChunk.length > 0;
 
-     var decrypt = this.decrypt;
 
-     chunk = decrypt(chunk, !hasMoreData);
 
-     var bufferLength = this.bufferLength;
 
-     var i,
 
-         n = chunk.length;
 
-     var buffer = this.ensureBuffer(bufferLength + n);
 
-     for (i = 0; i < n; i++) {
 
-       buffer[bufferLength++] = chunk[i];
 
-     }
 
-     this.bufferLength = bufferLength;
 
-   };
 
-   return DecryptStream;
 
- }();
 
- exports.DecryptStream = DecryptStream;
 
- var Ascii85Stream = function Ascii85StreamClosure() {
 
-   function Ascii85Stream(str, maybeLength) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     this.input = new Uint8Array(5);
 
-     if (maybeLength) {
 
-       maybeLength = 0.8 * maybeLength;
 
-     }
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   Ascii85Stream.prototype = Object.create(DecodeStream.prototype);
 
-   Ascii85Stream.prototype.readBlock = function Ascii85Stream_readBlock() {
 
-     var TILDA_CHAR = 0x7e;
 
-     var Z_LOWER_CHAR = 0x7a;
 
-     var EOF = -1;
 
-     var str = this.str;
 
-     var c = str.getByte();
 
-     while ((0, _core_utils.isWhiteSpace)(c)) {
 
-       c = str.getByte();
 
-     }
 
-     if (c === EOF || c === TILDA_CHAR) {
 
-       this.eof = true;
 
-       return;
 
-     }
 
-     var bufferLength = this.bufferLength,
 
-         buffer;
 
-     var i;
 
-     if (c === Z_LOWER_CHAR) {
 
-       buffer = this.ensureBuffer(bufferLength + 4);
 
-       for (i = 0; i < 4; ++i) {
 
-         buffer[bufferLength + i] = 0;
 
-       }
 
-       this.bufferLength += 4;
 
-     } else {
 
-       var input = this.input;
 
-       input[0] = c;
 
-       for (i = 1; i < 5; ++i) {
 
-         c = str.getByte();
 
-         while ((0, _core_utils.isWhiteSpace)(c)) {
 
-           c = str.getByte();
 
-         }
 
-         input[i] = c;
 
-         if (c === EOF || c === TILDA_CHAR) {
 
-           break;
 
-         }
 
-       }
 
-       buffer = this.ensureBuffer(bufferLength + i - 1);
 
-       this.bufferLength += i - 1;
 
-       if (i < 5) {
 
-         for (; i < 5; ++i) {
 
-           input[i] = 0x21 + 84;
 
-         }
 
-         this.eof = true;
 
-       }
 
-       var t = 0;
 
-       for (i = 0; i < 5; ++i) {
 
-         t = t * 85 + (input[i] - 0x21);
 
-       }
 
-       for (i = 3; i >= 0; --i) {
 
-         buffer[bufferLength + i] = t & 0xff;
 
-         t >>= 8;
 
-       }
 
-     }
 
-   };
 
-   return Ascii85Stream;
 
- }();
 
- exports.Ascii85Stream = Ascii85Stream;
 
- var AsciiHexStream = function AsciiHexStreamClosure() {
 
-   function AsciiHexStream(str, maybeLength) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     this.firstDigit = -1;
 
-     if (maybeLength) {
 
-       maybeLength = 0.5 * maybeLength;
 
-     }
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   AsciiHexStream.prototype = Object.create(DecodeStream.prototype);
 
-   AsciiHexStream.prototype.readBlock = function AsciiHexStream_readBlock() {
 
-     var UPSTREAM_BLOCK_SIZE = 8000;
 
-     var bytes = this.str.getBytes(UPSTREAM_BLOCK_SIZE);
 
-     if (!bytes.length) {
 
-       this.eof = true;
 
-       return;
 
-     }
 
-     var maxDecodeLength = bytes.length + 1 >> 1;
 
-     var buffer = this.ensureBuffer(this.bufferLength + maxDecodeLength);
 
-     var bufferLength = this.bufferLength;
 
-     var firstDigit = this.firstDigit;
 
-     for (var i = 0, ii = bytes.length; i < ii; i++) {
 
-       var ch = bytes[i],
 
-           digit;
 
-       if (ch >= 0x30 && ch <= 0x39) {
 
-         digit = ch & 0x0f;
 
-       } else if (ch >= 0x41 && ch <= 0x46 || ch >= 0x61 && ch <= 0x66) {
 
-         digit = (ch & 0x0f) + 9;
 
-       } else if (ch === 0x3e) {
 
-         this.eof = true;
 
-         break;
 
-       } else {
 
-         continue;
 
-       }
 
-       if (firstDigit < 0) {
 
-         firstDigit = digit;
 
-       } else {
 
-         buffer[bufferLength++] = firstDigit << 4 | digit;
 
-         firstDigit = -1;
 
-       }
 
-     }
 
-     if (firstDigit >= 0 && this.eof) {
 
-       buffer[bufferLength++] = firstDigit << 4;
 
-       firstDigit = -1;
 
-     }
 
-     this.firstDigit = firstDigit;
 
-     this.bufferLength = bufferLength;
 
-   };
 
-   return AsciiHexStream;
 
- }();
 
- exports.AsciiHexStream = AsciiHexStream;
 
- var RunLengthStream = function RunLengthStreamClosure() {
 
-   function RunLengthStream(str, maybeLength) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   RunLengthStream.prototype = Object.create(DecodeStream.prototype);
 
-   RunLengthStream.prototype.readBlock = function RunLengthStream_readBlock() {
 
-     var repeatHeader = this.str.getBytes(2);
 
-     if (!repeatHeader || repeatHeader.length < 2 || repeatHeader[0] === 128) {
 
-       this.eof = true;
 
-       return;
 
-     }
 
-     var buffer;
 
-     var bufferLength = this.bufferLength;
 
-     var n = repeatHeader[0];
 
-     if (n < 128) {
 
-       buffer = this.ensureBuffer(bufferLength + n + 1);
 
-       buffer[bufferLength++] = repeatHeader[1];
 
-       if (n > 0) {
 
-         var source = this.str.getBytes(n);
 
-         buffer.set(source, bufferLength);
 
-         bufferLength += n;
 
-       }
 
-     } else {
 
-       n = 257 - n;
 
-       var b = repeatHeader[1];
 
-       buffer = this.ensureBuffer(bufferLength + n + 1);
 
-       for (var i = 0; i < n; i++) {
 
-         buffer[bufferLength++] = b;
 
-       }
 
-     }
 
-     this.bufferLength = bufferLength;
 
-   };
 
-   return RunLengthStream;
 
- }();
 
- exports.RunLengthStream = RunLengthStream;
 
- var LZWStream = function LZWStreamClosure() {
 
-   function LZWStream(str, maybeLength, earlyChange) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     this.cachedData = 0;
 
-     this.bitsCached = 0;
 
-     var maxLzwDictionarySize = 4096;
 
-     var lzwState = {
 
-       earlyChange,
 
-       codeLength: 9,
 
-       nextCode: 258,
 
-       dictionaryValues: new Uint8Array(maxLzwDictionarySize),
 
-       dictionaryLengths: new Uint16Array(maxLzwDictionarySize),
 
-       dictionaryPrevCodes: new Uint16Array(maxLzwDictionarySize),
 
-       currentSequence: new Uint8Array(maxLzwDictionarySize),
 
-       currentSequenceLength: 0
 
-     };
 
-     for (var i = 0; i < 256; ++i) {
 
-       lzwState.dictionaryValues[i] = i;
 
-       lzwState.dictionaryLengths[i] = 1;
 
-     }
 
-     this.lzwState = lzwState;
 
-     DecodeStream.call(this, maybeLength);
 
-   }
 
-   LZWStream.prototype = Object.create(DecodeStream.prototype);
 
-   LZWStream.prototype.readBits = function LZWStream_readBits(n) {
 
-     var bitsCached = this.bitsCached;
 
-     var cachedData = this.cachedData;
 
-     while (bitsCached < n) {
 
-       var c = this.str.getByte();
 
-       if (c === -1) {
 
-         this.eof = true;
 
-         return null;
 
-       }
 
-       cachedData = cachedData << 8 | c;
 
-       bitsCached += 8;
 
-     }
 
-     this.bitsCached = bitsCached -= n;
 
-     this.cachedData = cachedData;
 
-     this.lastCode = null;
 
-     return cachedData >>> bitsCached & (1 << n) - 1;
 
-   };
 
-   LZWStream.prototype.readBlock = function LZWStream_readBlock() {
 
-     var blockSize = 512;
 
-     var estimatedDecodedSize = blockSize * 2,
 
-         decodedSizeDelta = blockSize;
 
-     var i, j, q;
 
-     var lzwState = this.lzwState;
 
-     if (!lzwState) {
 
-       return;
 
-     }
 
-     var earlyChange = lzwState.earlyChange;
 
-     var nextCode = lzwState.nextCode;
 
-     var dictionaryValues = lzwState.dictionaryValues;
 
-     var dictionaryLengths = lzwState.dictionaryLengths;
 
-     var dictionaryPrevCodes = lzwState.dictionaryPrevCodes;
 
-     var codeLength = lzwState.codeLength;
 
-     var prevCode = lzwState.prevCode;
 
-     var currentSequence = lzwState.currentSequence;
 
-     var currentSequenceLength = lzwState.currentSequenceLength;
 
-     var decodedLength = 0;
 
-     var currentBufferLength = this.bufferLength;
 
-     var buffer = this.ensureBuffer(this.bufferLength + estimatedDecodedSize);
 
-     for (i = 0; i < blockSize; i++) {
 
-       var code = this.readBits(codeLength);
 
-       var hasPrev = currentSequenceLength > 0;
 
-       if (code < 256) {
 
-         currentSequence[0] = code;
 
-         currentSequenceLength = 1;
 
-       } else if (code >= 258) {
 
-         if (code < nextCode) {
 
-           currentSequenceLength = dictionaryLengths[code];
 
-           for (j = currentSequenceLength - 1, q = code; j >= 0; j--) {
 
-             currentSequence[j] = dictionaryValues[q];
 
-             q = dictionaryPrevCodes[q];
 
-           }
 
-         } else {
 
-           currentSequence[currentSequenceLength++] = currentSequence[0];
 
-         }
 
-       } else if (code === 256) {
 
-         codeLength = 9;
 
-         nextCode = 258;
 
-         currentSequenceLength = 0;
 
-         continue;
 
-       } else {
 
-         this.eof = true;
 
-         delete this.lzwState;
 
-         break;
 
-       }
 
-       if (hasPrev) {
 
-         dictionaryPrevCodes[nextCode] = prevCode;
 
-         dictionaryLengths[nextCode] = dictionaryLengths[prevCode] + 1;
 
-         dictionaryValues[nextCode] = currentSequence[0];
 
-         nextCode++;
 
-         codeLength = nextCode + earlyChange & nextCode + earlyChange - 1 ? codeLength : Math.min(Math.log(nextCode + earlyChange) / 0.6931471805599453 + 1, 12) | 0;
 
-       }
 
-       prevCode = code;
 
-       decodedLength += currentSequenceLength;
 
-       if (estimatedDecodedSize < decodedLength) {
 
-         do {
 
-           estimatedDecodedSize += decodedSizeDelta;
 
-         } while (estimatedDecodedSize < decodedLength);
 
-         buffer = this.ensureBuffer(this.bufferLength + estimatedDecodedSize);
 
-       }
 
-       for (j = 0; j < currentSequenceLength; j++) {
 
-         buffer[currentBufferLength++] = currentSequence[j];
 
-       }
 
-     }
 
-     lzwState.nextCode = nextCode;
 
-     lzwState.codeLength = codeLength;
 
-     lzwState.prevCode = prevCode;
 
-     lzwState.currentSequenceLength = currentSequenceLength;
 
-     this.bufferLength = currentBufferLength;
 
-   };
 
-   return LZWStream;
 
- }();
 
- exports.LZWStream = LZWStream;
 
- var NullStream = function NullStreamClosure() {
 
-   function NullStream() {
 
-     Stream.call(this, new Uint8Array(0));
 
-   }
 
-   NullStream.prototype = Stream.prototype;
 
-   return NullStream;
 
- }();
 
- exports.NullStream = NullStream;
 
- /***/ }),
 
- /* 12 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.CCITTFaxStream = void 0;
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _ccitt = __w_pdfjs_require__(13);
 
- var _stream = __w_pdfjs_require__(11);
 
- var CCITTFaxStream = function CCITTFaxStreamClosure() {
 
-   function CCITTFaxStream(str, maybeLength, params) {
 
-     this.str = str;
 
-     this.dict = str.dict;
 
-     if (!(0, _primitives.isDict)(params)) {
 
-       params = _primitives.Dict.empty;
 
-     }
 
-     const source = {
 
-       next() {
 
-         return str.getByte();
 
-       }
 
-     };
 
-     this.ccittFaxDecoder = new _ccitt.CCITTFaxDecoder(source, {
 
-       K: params.get("K"),
 
-       EndOfLine: params.get("EndOfLine"),
 
-       EncodedByteAlign: params.get("EncodedByteAlign"),
 
-       Columns: params.get("Columns"),
 
-       Rows: params.get("Rows"),
 
-       EndOfBlock: params.get("EndOfBlock"),
 
-       BlackIs1: params.get("BlackIs1")
 
-     });
 
-     _stream.DecodeStream.call(this, maybeLength);
 
-   }
 
-   CCITTFaxStream.prototype = Object.create(_stream.DecodeStream.prototype);
 
-   CCITTFaxStream.prototype.readBlock = function () {
 
-     while (!this.eof) {
 
-       const c = this.ccittFaxDecoder.readNextChar();
 
-       if (c === -1) {
 
-         this.eof = true;
 
-         return;
 
-       }
 
-       this.ensureBuffer(this.bufferLength + 1);
 
-       this.buffer[this.bufferLength++] = c;
 
-     }
 
-   };
 
-   return CCITTFaxStream;
 
- }();
 
- exports.CCITTFaxStream = CCITTFaxStream;
 
- /***/ }),
 
- /* 13 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.CCITTFaxDecoder = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- const CCITTFaxDecoder = function CCITTFaxDecoder() {
 
-   const ccittEOL = -2;
 
-   const ccittEOF = -1;
 
-   const twoDimPass = 0;
 
-   const twoDimHoriz = 1;
 
-   const twoDimVert0 = 2;
 
-   const twoDimVertR1 = 3;
 
-   const twoDimVertL1 = 4;
 
-   const twoDimVertR2 = 5;
 
-   const twoDimVertL2 = 6;
 
-   const twoDimVertR3 = 7;
 
-   const twoDimVertL3 = 8;
 
-   const twoDimTable = [[-1, -1], [-1, -1], [7, twoDimVertL3], [7, twoDimVertR3], [6, twoDimVertL2], [6, twoDimVertL2], [6, twoDimVertR2], [6, twoDimVertR2], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [4, twoDimPass], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimHoriz], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertL1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [3, twoDimVertR1], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0], [1, twoDimVert0]];
 
-   const whiteTable1 = [[-1, -1], [12, ccittEOL], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [11, 1792], [11, 1792], [12, 1984], [12, 2048], [12, 2112], [12, 2176], [12, 2240], [12, 2304], [11, 1856], [11, 1856], [11, 1920], [11, 1920], [12, 2368], [12, 2432], [12, 2496], [12, 2560]];
 
-   const whiteTable2 = [[-1, -1], [-1, -1], [-1, -1], [-1, -1], [8, 29], [8, 29], [8, 30], [8, 30], [8, 45], [8, 45], [8, 46], [8, 46], [7, 22], [7, 22], [7, 22], [7, 22], [7, 23], [7, 23], [7, 23], [7, 23], [8, 47], [8, 47], [8, 48], [8, 48], [6, 13], [6, 13], [6, 13], [6, 13], [6, 13], [6, 13], [6, 13], [6, 13], [7, 20], [7, 20], [7, 20], [7, 20], [8, 33], [8, 33], [8, 34], [8, 34], [8, 35], [8, 35], [8, 36], [8, 36], [8, 37], [8, 37], [8, 38], [8, 38], [7, 19], [7, 19], [7, 19], [7, 19], [8, 31], [8, 31], [8, 32], [8, 32], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [6, 12], [6, 12], [6, 12], [6, 12], [6, 12], [6, 12], [6, 12], [6, 12], [8, 53], [8, 53], [8, 54], [8, 54], [7, 26], [7, 26], [7, 26], [7, 26], [8, 39], [8, 39], [8, 40], [8, 40], [8, 41], [8, 41], [8, 42], [8, 42], [8, 43], [8, 43], [8, 44], [8, 44], [7, 21], [7, 21], [7, 21], [7, 21], [7, 28], [7, 28], [7, 28], [7, 28], [8, 61], [8, 61], [8, 62], [8, 62], [8, 63], [8, 63], [8, 0], [8, 0], [8, 320], [8, 320], [8, 384], [8, 384], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 10], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [5, 11], [7, 27], [7, 27], [7, 27], [7, 27], [8, 59], [8, 59], [8, 60], [8, 60], [9, 1472], [9, 1536], [9, 1600], [9, 1728], [7, 18], [7, 18], [7, 18], [7, 18], [7, 24], [7, 24], [7, 24], [7, 24], [8, 49], [8, 49], [8, 50], [8, 50], [8, 51], [8, 51], [8, 52], [8, 52], [7, 25], [7, 25], [7, 25], [7, 25], [8, 55], [8, 55], [8, 56], [8, 56], [8, 57], [8, 57], [8, 58], [8, 58], [6, 192], [6, 192], [6, 192], [6, 192], [6, 192], [6, 192], [6, 192], [6, 192], [6, 1664], [6, 1664], [6, 1664], [6, 1664], [6, 1664], [6, 1664], [6, 1664], [6, 1664], [8, 448], [8, 448], [8, 512], [8, 512], [9, 704], [9, 768], [8, 640], [8, 640], [8, 576], [8, 576], [9, 832], [9, 896], [9, 960], [9, 1024], [9, 1088], [9, 1152], [9, 1216], [9, 1280], [9, 1344], [9, 1408], [7, 256], [7, 256], [7, 256], [7, 256], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 2], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [4, 3], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 128], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 8], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [5, 9], [6, 16], [6, 16], [6, 16], [6, 16], [6, 16], [6, 16], [6, 16], [6, 16], [6, 17], [6, 17], [6, 17], [6, 17], [6, 17], [6, 17], [6, 17], [6, 17], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 4], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [4, 5], [6, 14], [6, 14], [6, 14], [6, 14], [6, 14], [6, 14], [6, 14], [6, 14], [6, 15], [6, 15], [6, 15], [6, 15], [6, 15], [6, 15], [6, 15], [6, 15], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [5, 64], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 6], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7], [4, 7]];
 
-   const blackTable1 = [[-1, -1], [-1, -1], [12, ccittEOL], [12, ccittEOL], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [-1, -1], [11, 1792], [11, 1792], [11, 1792], [11, 1792], [12, 1984], [12, 1984], [12, 2048], [12, 2048], [12, 2112], [12, 2112], [12, 2176], [12, 2176], [12, 2240], [12, 2240], [12, 2304], [12, 2304], [11, 1856], [11, 1856], [11, 1856], [11, 1856], [11, 1920], [11, 1920], [11, 1920], [11, 1920], [12, 2368], [12, 2368], [12, 2432], [12, 2432], [12, 2496], [12, 2496], [12, 2560], [12, 2560], [10, 18], [10, 18], [10, 18], [10, 18], [10, 18], [10, 18], [10, 18], [10, 18], [12, 52], [12, 52], [13, 640], [13, 704], [13, 768], [13, 832], [12, 55], [12, 55], [12, 56], [12, 56], [13, 1280], [13, 1344], [13, 1408], [13, 1472], [12, 59], [12, 59], [12, 60], [12, 60], [13, 1536], [13, 1600], [11, 24], [11, 24], [11, 24], [11, 24], [11, 25], [11, 25], [11, 25], [11, 25], [13, 1664], [13, 1728], [12, 320], [12, 320], [12, 384], [12, 384], [12, 448], [12, 448], [13, 512], [13, 576], [12, 53], [12, 53], [12, 54], [12, 54], [13, 896], [13, 960], [13, 1024], [13, 1088], [13, 1152], [13, 1216], [10, 64], [10, 64], [10, 64], [10, 64], [10, 64], [10, 64], [10, 64], [10, 64]];
 
-   const blackTable2 = [[8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [8, 13], [11, 23], [11, 23], [12, 50], [12, 51], [12, 44], [12, 45], [12, 46], [12, 47], [12, 57], [12, 58], [12, 61], [12, 256], [10, 16], [10, 16], [10, 16], [10, 16], [10, 17], [10, 17], [10, 17], [10, 17], [12, 48], [12, 49], [12, 62], [12, 63], [12, 30], [12, 31], [12, 32], [12, 33], [12, 40], [12, 41], [11, 22], [11, 22], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [8, 14], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 10], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [7, 11], [9, 15], [9, 15], [9, 15], [9, 15], [9, 15], [9, 15], [9, 15], [9, 15], [12, 128], [12, 192], [12, 26], [12, 27], [12, 28], [12, 29], [11, 19], [11, 19], [11, 20], [11, 20], [12, 34], [12, 35], [12, 36], [12, 37], [12, 38], [12, 39], [11, 21], [11, 21], [12, 42], [12, 43], [10, 0], [10, 0], [10, 0], [10, 0], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12], [7, 12]];
 
-   const blackTable3 = [[-1, -1], [-1, -1], [-1, -1], [-1, -1], [6, 9], [6, 8], [5, 7], [5, 7], [4, 6], [4, 6], [4, 6], [4, 6], [4, 5], [4, 5], [4, 5], [4, 5], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 4], [3, 4], [3, 4], [3, 4], [3, 4], [3, 4], [3, 4], [3, 4], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 3], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2], [2, 2]];
 
-   function CCITTFaxDecoder(source, options = {}) {
 
-     if (!source || typeof source.next !== "function") {
 
-       throw new Error('CCITTFaxDecoder - invalid "source" parameter.');
 
-     }
 
-     this.source = source;
 
-     this.eof = false;
 
-     this.encoding = options["K"] || 0;
 
-     this.eoline = options["EndOfLine"] || false;
 
-     this.byteAlign = options["EncodedByteAlign"] || false;
 
-     this.columns = options["Columns"] || 1728;
 
-     this.rows = options["Rows"] || 0;
 
-     let eoblock = options["EndOfBlock"];
 
-     if (eoblock === null || eoblock === undefined) {
 
-       eoblock = true;
 
-     }
 
-     this.eoblock = eoblock;
 
-     this.black = options["BlackIs1"] || false;
 
-     this.codingLine = new Uint32Array(this.columns + 1);
 
-     this.refLine = new Uint32Array(this.columns + 2);
 
-     this.codingLine[0] = this.columns;
 
-     this.codingPos = 0;
 
-     this.row = 0;
 
-     this.nextLine2D = this.encoding < 0;
 
-     this.inputBits = 0;
 
-     this.inputBuf = 0;
 
-     this.outputBits = 0;
 
-     this.rowsDone = false;
 
-     let code1;
 
-     while ((code1 = this._lookBits(12)) === 0) {
 
-       this._eatBits(1);
 
-     }
 
-     if (code1 === 1) {
 
-       this._eatBits(12);
 
-     }
 
-     if (this.encoding > 0) {
 
-       this.nextLine2D = !this._lookBits(1);
 
-       this._eatBits(1);
 
-     }
 
-   }
 
-   CCITTFaxDecoder.prototype = {
 
-     readNextChar() {
 
-       if (this.eof) {
 
-         return -1;
 
-       }
 
-       const refLine = this.refLine;
 
-       const codingLine = this.codingLine;
 
-       const columns = this.columns;
 
-       let refPos, blackPixels, bits, i;
 
-       if (this.outputBits === 0) {
 
-         if (this.rowsDone) {
 
-           this.eof = true;
 
-         }
 
-         if (this.eof) {
 
-           return -1;
 
-         }
 
-         this.err = false;
 
-         let code1, code2, code3;
 
-         if (this.nextLine2D) {
 
-           for (i = 0; codingLine[i] < columns; ++i) {
 
-             refLine[i] = codingLine[i];
 
-           }
 
-           refLine[i++] = columns;
 
-           refLine[i] = columns;
 
-           codingLine[0] = 0;
 
-           this.codingPos = 0;
 
-           refPos = 0;
 
-           blackPixels = 0;
 
-           while (codingLine[this.codingPos] < columns) {
 
-             code1 = this._getTwoDimCode();
 
-             switch (code1) {
 
-               case twoDimPass:
 
-                 this._addPixels(refLine[refPos + 1], blackPixels);
 
-                 if (refLine[refPos + 1] < columns) {
 
-                   refPos += 2;
 
-                 }
 
-                 break;
 
-               case twoDimHoriz:
 
-                 code1 = code2 = 0;
 
-                 if (blackPixels) {
 
-                   do {
 
-                     code1 += code3 = this._getBlackCode();
 
-                   } while (code3 >= 64);
 
-                   do {
 
-                     code2 += code3 = this._getWhiteCode();
 
-                   } while (code3 >= 64);
 
-                 } else {
 
-                   do {
 
-                     code1 += code3 = this._getWhiteCode();
 
-                   } while (code3 >= 64);
 
-                   do {
 
-                     code2 += code3 = this._getBlackCode();
 
-                   } while (code3 >= 64);
 
-                 }
 
-                 this._addPixels(codingLine[this.codingPos] + code1, blackPixels);
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   this._addPixels(codingLine[this.codingPos] + code2, blackPixels ^ 1);
 
-                 }
 
-                 while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                   refPos += 2;
 
-                 }
 
-                 break;
 
-               case twoDimVertR3:
 
-                 this._addPixels(refLine[refPos] + 3, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   ++refPos;
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVertR2:
 
-                 this._addPixels(refLine[refPos] + 2, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   ++refPos;
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVertR1:
 
-                 this._addPixels(refLine[refPos] + 1, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   ++refPos;
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVert0:
 
-                 this._addPixels(refLine[refPos], blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   ++refPos;
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVertL3:
 
-                 this._addPixelsNeg(refLine[refPos] - 3, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   if (refPos > 0) {
 
-                     --refPos;
 
-                   } else {
 
-                     ++refPos;
 
-                   }
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVertL2:
 
-                 this._addPixelsNeg(refLine[refPos] - 2, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   if (refPos > 0) {
 
-                     --refPos;
 
-                   } else {
 
-                     ++refPos;
 
-                   }
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case twoDimVertL1:
 
-                 this._addPixelsNeg(refLine[refPos] - 1, blackPixels);
 
-                 blackPixels ^= 1;
 
-                 if (codingLine[this.codingPos] < columns) {
 
-                   if (refPos > 0) {
 
-                     --refPos;
 
-                   } else {
 
-                     ++refPos;
 
-                   }
 
-                   while (refLine[refPos] <= codingLine[this.codingPos] && refLine[refPos] < columns) {
 
-                     refPos += 2;
 
-                   }
 
-                 }
 
-                 break;
 
-               case ccittEOF:
 
-                 this._addPixels(columns, 0);
 
-                 this.eof = true;
 
-                 break;
 
-               default:
 
-                 (0, _util.info)("bad 2d code");
 
-                 this._addPixels(columns, 0);
 
-                 this.err = true;
 
-             }
 
-           }
 
-         } else {
 
-           codingLine[0] = 0;
 
-           this.codingPos = 0;
 
-           blackPixels = 0;
 
-           while (codingLine[this.codingPos] < columns) {
 
-             code1 = 0;
 
-             if (blackPixels) {
 
-               do {
 
-                 code1 += code3 = this._getBlackCode();
 
-               } while (code3 >= 64);
 
-             } else {
 
-               do {
 
-                 code1 += code3 = this._getWhiteCode();
 
-               } while (code3 >= 64);
 
-             }
 
-             this._addPixels(codingLine[this.codingPos] + code1, blackPixels);
 
-             blackPixels ^= 1;
 
-           }
 
-         }
 
-         let gotEOL = false;
 
-         if (this.byteAlign) {
 
-           this.inputBits &= ~7;
 
-         }
 
-         if (!this.eoblock && this.row === this.rows - 1) {
 
-           this.rowsDone = true;
 
-         } else {
 
-           code1 = this._lookBits(12);
 
-           if (this.eoline) {
 
-             while (code1 !== ccittEOF && code1 !== 1) {
 
-               this._eatBits(1);
 
-               code1 = this._lookBits(12);
 
-             }
 
-           } else {
 
-             while (code1 === 0) {
 
-               this._eatBits(1);
 
-               code1 = this._lookBits(12);
 
-             }
 
-           }
 
-           if (code1 === 1) {
 
-             this._eatBits(12);
 
-             gotEOL = true;
 
-           } else if (code1 === ccittEOF) {
 
-             this.eof = true;
 
-           }
 
-         }
 
-         if (!this.eof && this.encoding > 0 && !this.rowsDone) {
 
-           this.nextLine2D = !this._lookBits(1);
 
-           this._eatBits(1);
 
-         }
 
-         if (this.eoblock && gotEOL && this.byteAlign) {
 
-           code1 = this._lookBits(12);
 
-           if (code1 === 1) {
 
-             this._eatBits(12);
 
-             if (this.encoding > 0) {
 
-               this._lookBits(1);
 
-               this._eatBits(1);
 
-             }
 
-             if (this.encoding >= 0) {
 
-               for (i = 0; i < 4; ++i) {
 
-                 code1 = this._lookBits(12);
 
-                 if (code1 !== 1) {
 
-                   (0, _util.info)("bad rtc code: " + code1);
 
-                 }
 
-                 this._eatBits(12);
 
-                 if (this.encoding > 0) {
 
-                   this._lookBits(1);
 
-                   this._eatBits(1);
 
-                 }
 
-               }
 
-             }
 
-             this.eof = true;
 
-           }
 
-         } else if (this.err && this.eoline) {
 
-           while (true) {
 
-             code1 = this._lookBits(13);
 
-             if (code1 === ccittEOF) {
 
-               this.eof = true;
 
-               return -1;
 
-             }
 
-             if (code1 >> 1 === 1) {
 
-               break;
 
-             }
 
-             this._eatBits(1);
 
-           }
 
-           this._eatBits(12);
 
-           if (this.encoding > 0) {
 
-             this._eatBits(1);
 
-             this.nextLine2D = !(code1 & 1);
 
-           }
 
-         }
 
-         if (codingLine[0] > 0) {
 
-           this.outputBits = codingLine[this.codingPos = 0];
 
-         } else {
 
-           this.outputBits = codingLine[this.codingPos = 1];
 
-         }
 
-         this.row++;
 
-       }
 
-       let c;
 
-       if (this.outputBits >= 8) {
 
-         c = this.codingPos & 1 ? 0 : 0xff;
 
-         this.outputBits -= 8;
 
-         if (this.outputBits === 0 && codingLine[this.codingPos] < columns) {
 
-           this.codingPos++;
 
-           this.outputBits = codingLine[this.codingPos] - codingLine[this.codingPos - 1];
 
-         }
 
-       } else {
 
-         bits = 8;
 
-         c = 0;
 
-         do {
 
-           if (this.outputBits > bits) {
 
-             c <<= bits;
 
-             if (!(this.codingPos & 1)) {
 
-               c |= 0xff >> 8 - bits;
 
-             }
 
-             this.outputBits -= bits;
 
-             bits = 0;
 
-           } else {
 
-             c <<= this.outputBits;
 
-             if (!(this.codingPos & 1)) {
 
-               c |= 0xff >> 8 - this.outputBits;
 
-             }
 
-             bits -= this.outputBits;
 
-             this.outputBits = 0;
 
-             if (codingLine[this.codingPos] < columns) {
 
-               this.codingPos++;
 
-               this.outputBits = codingLine[this.codingPos] - codingLine[this.codingPos - 1];
 
-             } else if (bits > 0) {
 
-               c <<= bits;
 
-               bits = 0;
 
-             }
 
-           }
 
-         } while (bits);
 
-       }
 
-       if (this.black) {
 
-         c ^= 0xff;
 
-       }
 
-       return c;
 
-     },
 
-     _addPixels(a1, blackPixels) {
 
-       const codingLine = this.codingLine;
 
-       let codingPos = this.codingPos;
 
-       if (a1 > codingLine[codingPos]) {
 
-         if (a1 > this.columns) {
 
-           (0, _util.info)("row is wrong length");
 
-           this.err = true;
 
-           a1 = this.columns;
 
-         }
 
-         if (codingPos & 1 ^ blackPixels) {
 
-           ++codingPos;
 
-         }
 
-         codingLine[codingPos] = a1;
 
-       }
 
-       this.codingPos = codingPos;
 
-     },
 
-     _addPixelsNeg(a1, blackPixels) {
 
-       const codingLine = this.codingLine;
 
-       let codingPos = this.codingPos;
 
-       if (a1 > codingLine[codingPos]) {
 
-         if (a1 > this.columns) {
 
-           (0, _util.info)("row is wrong length");
 
-           this.err = true;
 
-           a1 = this.columns;
 
-         }
 
-         if (codingPos & 1 ^ blackPixels) {
 
-           ++codingPos;
 
-         }
 
-         codingLine[codingPos] = a1;
 
-       } else if (a1 < codingLine[codingPos]) {
 
-         if (a1 < 0) {
 
-           (0, _util.info)("invalid code");
 
-           this.err = true;
 
-           a1 = 0;
 
-         }
 
-         while (codingPos > 0 && a1 < codingLine[codingPos - 1]) {
 
-           --codingPos;
 
-         }
 
-         codingLine[codingPos] = a1;
 
-       }
 
-       this.codingPos = codingPos;
 
-     },
 
-     _findTableCode(start, end, table, limit) {
 
-       const limitValue = limit || 0;
 
-       for (let i = start; i <= end; ++i) {
 
-         let code = this._lookBits(i);
 
-         if (code === ccittEOF) {
 
-           return [true, 1, false];
 
-         }
 
-         if (i < end) {
 
-           code <<= end - i;
 
-         }
 
-         if (!limitValue || code >= limitValue) {
 
-           const p = table[code - limitValue];
 
-           if (p[0] === i) {
 
-             this._eatBits(i);
 
-             return [true, p[1], true];
 
-           }
 
-         }
 
-       }
 
-       return [false, 0, false];
 
-     },
 
-     _getTwoDimCode() {
 
-       let code = 0;
 
-       let p;
 
-       if (this.eoblock) {
 
-         code = this._lookBits(7);
 
-         p = twoDimTable[code];
 
-         if (p && p[0] > 0) {
 
-           this._eatBits(p[0]);
 
-           return p[1];
 
-         }
 
-       } else {
 
-         const result = this._findTableCode(1, 7, twoDimTable);
 
-         if (result[0] && result[2]) {
 
-           return result[1];
 
-         }
 
-       }
 
-       (0, _util.info)("Bad two dim code");
 
-       return ccittEOF;
 
-     },
 
-     _getWhiteCode() {
 
-       let code = 0;
 
-       let p;
 
-       if (this.eoblock) {
 
-         code = this._lookBits(12);
 
-         if (code === ccittEOF) {
 
-           return 1;
 
-         }
 
-         if (code >> 5 === 0) {
 
-           p = whiteTable1[code];
 
-         } else {
 
-           p = whiteTable2[code >> 3];
 
-         }
 
-         if (p[0] > 0) {
 
-           this._eatBits(p[0]);
 
-           return p[1];
 
-         }
 
-       } else {
 
-         let result = this._findTableCode(1, 9, whiteTable2);
 
-         if (result[0]) {
 
-           return result[1];
 
-         }
 
-         result = this._findTableCode(11, 12, whiteTable1);
 
-         if (result[0]) {
 
-           return result[1];
 
-         }
 
-       }
 
-       (0, _util.info)("bad white code");
 
-       this._eatBits(1);
 
-       return 1;
 
-     },
 
-     _getBlackCode() {
 
-       let code, p;
 
-       if (this.eoblock) {
 
-         code = this._lookBits(13);
 
-         if (code === ccittEOF) {
 
-           return 1;
 
-         }
 
-         if (code >> 7 === 0) {
 
-           p = blackTable1[code];
 
-         } else if (code >> 9 === 0 && code >> 7 !== 0) {
 
-           p = blackTable2[(code >> 1) - 64];
 
-         } else {
 
-           p = blackTable3[code >> 7];
 
-         }
 
-         if (p[0] > 0) {
 
-           this._eatBits(p[0]);
 
-           return p[1];
 
-         }
 
-       } else {
 
-         let result = this._findTableCode(2, 6, blackTable3);
 
-         if (result[0]) {
 
-           return result[1];
 
-         }
 
-         result = this._findTableCode(7, 12, blackTable2, 64);
 
-         if (result[0]) {
 
-           return result[1];
 
-         }
 
-         result = this._findTableCode(10, 13, blackTable1);
 
-         if (result[0]) {
 
-           return result[1];
 
-         }
 
-       }
 
-       (0, _util.info)("bad black code");
 
-       this._eatBits(1);
 
-       return 1;
 
-     },
 
-     _lookBits(n) {
 
-       let c;
 
-       while (this.inputBits < n) {
 
-         if ((c = this.source.next()) === -1) {
 
-           if (this.inputBits === 0) {
 
-             return ccittEOF;
 
-           }
 
-           return this.inputBuf << n - this.inputBits & 0xffff >> 16 - n;
 
-         }
 
-         this.inputBuf = this.inputBuf << 8 | c;
 
-         this.inputBits += 8;
 
-       }
 
-       return this.inputBuf >> this.inputBits - n & 0xffff >> 16 - n;
 
-     },
 
-     _eatBits(n) {
 
-       if ((this.inputBits -= n) < 0) {
 
-         this.inputBits = 0;
 
-       }
 
-     }
 
-   };
 
-   return CCITTFaxDecoder;
 
- }();
 
- exports.CCITTFaxDecoder = CCITTFaxDecoder;
 
- /***/ }),
 
- /* 14 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.Jbig2Stream = void 0;
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _jbig = __w_pdfjs_require__(15);
 
- var _util = __w_pdfjs_require__(2);
 
- const Jbig2Stream = function Jbig2StreamClosure() {
 
-   function Jbig2Stream(stream, maybeLength, dict, params) {
 
-     this.stream = stream;
 
-     this.maybeLength = maybeLength;
 
-     this.dict = dict;
 
-     this.params = params;
 
-     _stream.DecodeStream.call(this, maybeLength);
 
-   }
 
-   Jbig2Stream.prototype = Object.create(_stream.DecodeStream.prototype);
 
-   Object.defineProperty(Jbig2Stream.prototype, "bytes", {
 
-     get() {
 
-       return (0, _util.shadow)(this, "bytes", this.stream.getBytes(this.maybeLength));
 
-     },
 
-     configurable: true
 
-   });
 
-   Jbig2Stream.prototype.ensureBuffer = function (requested) {};
 
-   Jbig2Stream.prototype.readBlock = function () {
 
-     if (this.eof) {
 
-       return;
 
-     }
 
-     const jbig2Image = new _jbig.Jbig2Image();
 
-     const chunks = [];
 
-     if ((0, _primitives.isDict)(this.params)) {
 
-       const globalsStream = this.params.get("JBIG2Globals");
 
-       if ((0, _primitives.isStream)(globalsStream)) {
 
-         const globals = globalsStream.getBytes();
 
-         chunks.push({
 
-           data: globals,
 
-           start: 0,
 
-           end: globals.length
 
-         });
 
-       }
 
-     }
 
-     chunks.push({
 
-       data: this.bytes,
 
-       start: 0,
 
-       end: this.bytes.length
 
-     });
 
-     const data = jbig2Image.parseChunks(chunks);
 
-     const dataLength = data.length;
 
-     for (let i = 0; i < dataLength; i++) {
 
-       data[i] ^= 0xff;
 
-     }
 
-     this.buffer = data;
 
-     this.bufferLength = dataLength;
 
-     this.eof = true;
 
-   };
 
-   return Jbig2Stream;
 
- }();
 
- exports.Jbig2Stream = Jbig2Stream;
 
- /***/ }),
 
- /* 15 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.Jbig2Image = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _arithmetic_decoder = __w_pdfjs_require__(16);
 
- var _ccitt = __w_pdfjs_require__(13);
 
- class Jbig2Error extends _util.BaseException {
 
-   constructor(msg) {
 
-     super(`JBIG2 error: ${msg}`);
 
-   }
 
- }
 
- var Jbig2Image = function Jbig2ImageClosure() {
 
-   function ContextCache() {}
 
-   ContextCache.prototype = {
 
-     getContexts(id) {
 
-       if (id in this) {
 
-         return this[id];
 
-       }
 
-       return this[id] = new Int8Array(1 << 16);
 
-     }
 
-   };
 
-   function DecodingContext(data, start, end) {
 
-     this.data = data;
 
-     this.start = start;
 
-     this.end = end;
 
-   }
 
-   DecodingContext.prototype = {
 
-     get decoder() {
 
-       var decoder = new _arithmetic_decoder.ArithmeticDecoder(this.data, this.start, this.end);
 
-       return (0, _util.shadow)(this, "decoder", decoder);
 
-     },
 
-     get contextCache() {
 
-       var cache = new ContextCache();
 
-       return (0, _util.shadow)(this, "contextCache", cache);
 
-     }
 
-   };
 
-   function decodeInteger(contextCache, procedure, decoder) {
 
-     var contexts = contextCache.getContexts(procedure);
 
-     var prev = 1;
 
-     function readBits(length) {
 
-       var v = 0;
 
-       for (var i = 0; i < length; i++) {
 
-         var bit = decoder.readBit(contexts, prev);
 
-         prev = prev < 256 ? prev << 1 | bit : (prev << 1 | bit) & 511 | 256;
 
-         v = v << 1 | bit;
 
-       }
 
-       return v >>> 0;
 
-     }
 
-     var sign = readBits(1);
 
-     var value = readBits(1) ? readBits(1) ? readBits(1) ? readBits(1) ? readBits(1) ? readBits(32) + 4436 : readBits(12) + 340 : readBits(8) + 84 : readBits(6) + 20 : readBits(4) + 4 : readBits(2);
 
-     if (sign === 0) {
 
-       return value;
 
-     } else if (value > 0) {
 
-       return -value;
 
-     }
 
-     return null;
 
-   }
 
-   function decodeIAID(contextCache, decoder, codeLength) {
 
-     var contexts = contextCache.getContexts("IAID");
 
-     var prev = 1;
 
-     for (var i = 0; i < codeLength; i++) {
 
-       var bit = decoder.readBit(contexts, prev);
 
-       prev = prev << 1 | bit;
 
-     }
 
-     if (codeLength < 31) {
 
-       return prev & (1 << codeLength) - 1;
 
-     }
 
-     return prev & 0x7fffffff;
 
-   }
 
-   var SegmentTypes = ["SymbolDictionary", null, null, null, "IntermediateTextRegion", null, "ImmediateTextRegion", "ImmediateLosslessTextRegion", null, null, null, null, null, null, null, null, "PatternDictionary", null, null, null, "IntermediateHalftoneRegion", null, "ImmediateHalftoneRegion", "ImmediateLosslessHalftoneRegion", null, null, null, null, null, null, null, null, null, null, null, null, "IntermediateGenericRegion", null, "ImmediateGenericRegion", "ImmediateLosslessGenericRegion", "IntermediateGenericRefinementRegion", null, "ImmediateGenericRefinementRegion", "ImmediateLosslessGenericRefinementRegion", null, null, null, null, "PageInformation", "EndOfPage", "EndOfStripe", "EndOfFile", "Profiles", "Tables", null, null, null, null, null, null, null, null, "Extension"];
 
-   var CodingTemplates = [[{
 
-     x: -1,
 
-     y: -2
 
-   }, {
 
-     x: 0,
 
-     y: -2
 
-   }, {
 
-     x: 1,
 
-     y: -2
 
-   }, {
 
-     x: -2,
 
-     y: -1
 
-   }, {
 
-     x: -1,
 
-     y: -1
 
-   }, {
 
-     x: 0,
 
-     y: -1
 
-   }, {
 
-     x: 1,
 
-     y: -1
 
-   }, {
 
-     x: 2,
 
-     y: -1
 
-   }, {
 
-     x: -4,
 
-     y: 0
 
-   }, {
 
-     x: -3,
 
-     y: 0
 
-   }, {
 
-     x: -2,
 
-     y: 0
 
-   }, {
 
-     x: -1,
 
-     y: 0
 
-   }], [{
 
-     x: -1,
 
-     y: -2
 
-   }, {
 
-     x: 0,
 
-     y: -2
 
-   }, {
 
-     x: 1,
 
-     y: -2
 
-   }, {
 
-     x: 2,
 
-     y: -2
 
-   }, {
 
-     x: -2,
 
-     y: -1
 
-   }, {
 
-     x: -1,
 
-     y: -1
 
-   }, {
 
-     x: 0,
 
-     y: -1
 
-   }, {
 
-     x: 1,
 
-     y: -1
 
-   }, {
 
-     x: 2,
 
-     y: -1
 
-   }, {
 
-     x: -3,
 
-     y: 0
 
-   }, {
 
-     x: -2,
 
-     y: 0
 
-   }, {
 
-     x: -1,
 
-     y: 0
 
-   }], [{
 
-     x: -1,
 
-     y: -2
 
-   }, {
 
-     x: 0,
 
-     y: -2
 
-   }, {
 
-     x: 1,
 
-     y: -2
 
-   }, {
 
-     x: -2,
 
-     y: -1
 
-   }, {
 
-     x: -1,
 
-     y: -1
 
-   }, {
 
-     x: 0,
 
-     y: -1
 
-   }, {
 
-     x: 1,
 
-     y: -1
 
-   }, {
 
-     x: -2,
 
-     y: 0
 
-   }, {
 
-     x: -1,
 
-     y: 0
 
-   }], [{
 
-     x: -3,
 
-     y: -1
 
-   }, {
 
-     x: -2,
 
-     y: -1
 
-   }, {
 
-     x: -1,
 
-     y: -1
 
-   }, {
 
-     x: 0,
 
-     y: -1
 
-   }, {
 
-     x: 1,
 
-     y: -1
 
-   }, {
 
-     x: -4,
 
-     y: 0
 
-   }, {
 
-     x: -3,
 
-     y: 0
 
-   }, {
 
-     x: -2,
 
-     y: 0
 
-   }, {
 
-     x: -1,
 
-     y: 0
 
-   }]];
 
-   var RefinementTemplates = [{
 
-     coding: [{
 
-       x: 0,
 
-       y: -1
 
-     }, {
 
-       x: 1,
 
-       y: -1
 
-     }, {
 
-       x: -1,
 
-       y: 0
 
-     }],
 
-     reference: [{
 
-       x: 0,
 
-       y: -1
 
-     }, {
 
-       x: 1,
 
-       y: -1
 
-     }, {
 
-       x: -1,
 
-       y: 0
 
-     }, {
 
-       x: 0,
 
-       y: 0
 
-     }, {
 
-       x: 1,
 
-       y: 0
 
-     }, {
 
-       x: -1,
 
-       y: 1
 
-     }, {
 
-       x: 0,
 
-       y: 1
 
-     }, {
 
-       x: 1,
 
-       y: 1
 
-     }]
 
-   }, {
 
-     coding: [{
 
-       x: -1,
 
-       y: -1
 
-     }, {
 
-       x: 0,
 
-       y: -1
 
-     }, {
 
-       x: 1,
 
-       y: -1
 
-     }, {
 
-       x: -1,
 
-       y: 0
 
-     }],
 
-     reference: [{
 
-       x: 0,
 
-       y: -1
 
-     }, {
 
-       x: -1,
 
-       y: 0
 
-     }, {
 
-       x: 0,
 
-       y: 0
 
-     }, {
 
-       x: 1,
 
-       y: 0
 
-     }, {
 
-       x: 0,
 
-       y: 1
 
-     }, {
 
-       x: 1,
 
-       y: 1
 
-     }]
 
-   }];
 
-   var ReusedContexts = [0x9b25, 0x0795, 0x00e5, 0x0195];
 
-   var RefinementReusedContexts = [0x0020, 0x0008];
 
-   function decodeBitmapTemplate0(width, height, decodingContext) {
 
-     var decoder = decodingContext.decoder;
 
-     var contexts = decodingContext.contextCache.getContexts("GB");
 
-     var contextLabel,
 
-         i,
 
-         j,
 
-         pixel,
 
-         row,
 
-         row1,
 
-         row2,
 
-         bitmap = [];
 
-     var OLD_PIXEL_MASK = 0x7bf7;
 
-     for (i = 0; i < height; i++) {
 
-       row = bitmap[i] = new Uint8Array(width);
 
-       row1 = i < 1 ? row : bitmap[i - 1];
 
-       row2 = i < 2 ? row : bitmap[i - 2];
 
-       contextLabel = row2[0] << 13 | row2[1] << 12 | row2[2] << 11 | row1[0] << 7 | row1[1] << 6 | row1[2] << 5 | row1[3] << 4;
 
-       for (j = 0; j < width; j++) {
 
-         row[j] = pixel = decoder.readBit(contexts, contextLabel);
 
-         contextLabel = (contextLabel & OLD_PIXEL_MASK) << 1 | (j + 3 < width ? row2[j + 3] << 11 : 0) | (j + 4 < width ? row1[j + 4] << 4 : 0) | pixel;
 
-       }
 
-     }
 
-     return bitmap;
 
-   }
 
-   function decodeBitmap(mmr, width, height, templateIndex, prediction, skip, at, decodingContext) {
 
-     if (mmr) {
 
-       const input = new Reader(decodingContext.data, decodingContext.start, decodingContext.end);
 
-       return decodeMMRBitmap(input, width, height, false);
 
-     }
 
-     if (templateIndex === 0 && !skip && !prediction && at.length === 4 && at[0].x === 3 && at[0].y === -1 && at[1].x === -3 && at[1].y === -1 && at[2].x === 2 && at[2].y === -2 && at[3].x === -2 && at[3].y === -2) {
 
-       return decodeBitmapTemplate0(width, height, decodingContext);
 
-     }
 
-     var useskip = !!skip;
 
-     var template = CodingTemplates[templateIndex].concat(at);
 
-     template.sort(function (a, b) {
 
-       return a.y - b.y || a.x - b.x;
 
-     });
 
-     var templateLength = template.length;
 
-     var templateX = new Int8Array(templateLength);
 
-     var templateY = new Int8Array(templateLength);
 
-     var changingTemplateEntries = [];
 
-     var reuseMask = 0,
 
-         minX = 0,
 
-         maxX = 0,
 
-         minY = 0;
 
-     var c, k;
 
-     for (k = 0; k < templateLength; k++) {
 
-       templateX[k] = template[k].x;
 
-       templateY[k] = template[k].y;
 
-       minX = Math.min(minX, template[k].x);
 
-       maxX = Math.max(maxX, template[k].x);
 
-       minY = Math.min(minY, template[k].y);
 
-       if (k < templateLength - 1 && template[k].y === template[k + 1].y && template[k].x === template[k + 1].x - 1) {
 
-         reuseMask |= 1 << templateLength - 1 - k;
 
-       } else {
 
-         changingTemplateEntries.push(k);
 
-       }
 
-     }
 
-     var changingEntriesLength = changingTemplateEntries.length;
 
-     var changingTemplateX = new Int8Array(changingEntriesLength);
 
-     var changingTemplateY = new Int8Array(changingEntriesLength);
 
-     var changingTemplateBit = new Uint16Array(changingEntriesLength);
 
-     for (c = 0; c < changingEntriesLength; c++) {
 
-       k = changingTemplateEntries[c];
 
-       changingTemplateX[c] = template[k].x;
 
-       changingTemplateY[c] = template[k].y;
 
-       changingTemplateBit[c] = 1 << templateLength - 1 - k;
 
-     }
 
-     var sbb_left = -minX;
 
-     var sbb_top = -minY;
 
-     var sbb_right = width - maxX;
 
-     var pseudoPixelContext = ReusedContexts[templateIndex];
 
-     var row = new Uint8Array(width);
 
-     var bitmap = [];
 
-     var decoder = decodingContext.decoder;
 
-     var contexts = decodingContext.contextCache.getContexts("GB");
 
-     var ltp = 0,
 
-         j,
 
-         i0,
 
-         j0,
 
-         contextLabel = 0,
 
-         bit,
 
-         shift;
 
-     for (var i = 0; i < height; i++) {
 
-       if (prediction) {
 
-         var sltp = decoder.readBit(contexts, pseudoPixelContext);
 
-         ltp ^= sltp;
 
-         if (ltp) {
 
-           bitmap.push(row);
 
-           continue;
 
-         }
 
-       }
 
-       row = new Uint8Array(row);
 
-       bitmap.push(row);
 
-       for (j = 0; j < width; j++) {
 
-         if (useskip && skip[i][j]) {
 
-           row[j] = 0;
 
-           continue;
 
-         }
 
-         if (j >= sbb_left && j < sbb_right && i >= sbb_top) {
 
-           contextLabel = contextLabel << 1 & reuseMask;
 
-           for (k = 0; k < changingEntriesLength; k++) {
 
-             i0 = i + changingTemplateY[k];
 
-             j0 = j + changingTemplateX[k];
 
-             bit = bitmap[i0][j0];
 
-             if (bit) {
 
-               bit = changingTemplateBit[k];
 
-               contextLabel |= bit;
 
-             }
 
-           }
 
-         } else {
 
-           contextLabel = 0;
 
-           shift = templateLength - 1;
 
-           for (k = 0; k < templateLength; k++, shift--) {
 
-             j0 = j + templateX[k];
 
-             if (j0 >= 0 && j0 < width) {
 
-               i0 = i + templateY[k];
 
-               if (i0 >= 0) {
 
-                 bit = bitmap[i0][j0];
 
-                 if (bit) {
 
-                   contextLabel |= bit << shift;
 
-                 }
 
-               }
 
-             }
 
-           }
 
-         }
 
-         var pixel = decoder.readBit(contexts, contextLabel);
 
-         row[j] = pixel;
 
-       }
 
-     }
 
-     return bitmap;
 
-   }
 
-   function decodeRefinement(width, height, templateIndex, referenceBitmap, offsetX, offsetY, prediction, at, decodingContext) {
 
-     var codingTemplate = RefinementTemplates[templateIndex].coding;
 
-     if (templateIndex === 0) {
 
-       codingTemplate = codingTemplate.concat([at[0]]);
 
-     }
 
-     var codingTemplateLength = codingTemplate.length;
 
-     var codingTemplateX = new Int32Array(codingTemplateLength);
 
-     var codingTemplateY = new Int32Array(codingTemplateLength);
 
-     var k;
 
-     for (k = 0; k < codingTemplateLength; k++) {
 
-       codingTemplateX[k] = codingTemplate[k].x;
 
-       codingTemplateY[k] = codingTemplate[k].y;
 
-     }
 
-     var referenceTemplate = RefinementTemplates[templateIndex].reference;
 
-     if (templateIndex === 0) {
 
-       referenceTemplate = referenceTemplate.concat([at[1]]);
 
-     }
 
-     var referenceTemplateLength = referenceTemplate.length;
 
-     var referenceTemplateX = new Int32Array(referenceTemplateLength);
 
-     var referenceTemplateY = new Int32Array(referenceTemplateLength);
 
-     for (k = 0; k < referenceTemplateLength; k++) {
 
-       referenceTemplateX[k] = referenceTemplate[k].x;
 
-       referenceTemplateY[k] = referenceTemplate[k].y;
 
-     }
 
-     var referenceWidth = referenceBitmap[0].length;
 
-     var referenceHeight = referenceBitmap.length;
 
-     var pseudoPixelContext = RefinementReusedContexts[templateIndex];
 
-     var bitmap = [];
 
-     var decoder = decodingContext.decoder;
 
-     var contexts = decodingContext.contextCache.getContexts("GR");
 
-     var ltp = 0;
 
-     for (var i = 0; i < height; i++) {
 
-       if (prediction) {
 
-         var sltp = decoder.readBit(contexts, pseudoPixelContext);
 
-         ltp ^= sltp;
 
-         if (ltp) {
 
-           throw new Jbig2Error("prediction is not supported");
 
-         }
 
-       }
 
-       var row = new Uint8Array(width);
 
-       bitmap.push(row);
 
-       for (var j = 0; j < width; j++) {
 
-         var i0, j0;
 
-         var contextLabel = 0;
 
-         for (k = 0; k < codingTemplateLength; k++) {
 
-           i0 = i + codingTemplateY[k];
 
-           j0 = j + codingTemplateX[k];
 
-           if (i0 < 0 || j0 < 0 || j0 >= width) {
 
-             contextLabel <<= 1;
 
-           } else {
 
-             contextLabel = contextLabel << 1 | bitmap[i0][j0];
 
-           }
 
-         }
 
-         for (k = 0; k < referenceTemplateLength; k++) {
 
-           i0 = i + referenceTemplateY[k] - offsetY;
 
-           j0 = j + referenceTemplateX[k] - offsetX;
 
-           if (i0 < 0 || i0 >= referenceHeight || j0 < 0 || j0 >= referenceWidth) {
 
-             contextLabel <<= 1;
 
-           } else {
 
-             contextLabel = contextLabel << 1 | referenceBitmap[i0][j0];
 
-           }
 
-         }
 
-         var pixel = decoder.readBit(contexts, contextLabel);
 
-         row[j] = pixel;
 
-       }
 
-     }
 
-     return bitmap;
 
-   }
 
-   function decodeSymbolDictionary(huffman, refinement, symbols, numberOfNewSymbols, numberOfExportedSymbols, huffmanTables, templateIndex, at, refinementTemplateIndex, refinementAt, decodingContext, huffmanInput) {
 
-     if (huffman && refinement) {
 
-       throw new Jbig2Error("symbol refinement with Huffman is not supported");
 
-     }
 
-     var newSymbols = [];
 
-     var currentHeight = 0;
 
-     var symbolCodeLength = (0, _core_utils.log2)(symbols.length + numberOfNewSymbols);
 
-     var decoder = decodingContext.decoder;
 
-     var contextCache = decodingContext.contextCache;
 
-     let tableB1, symbolWidths;
 
-     if (huffman) {
 
-       tableB1 = getStandardTable(1);
 
-       symbolWidths = [];
 
-       symbolCodeLength = Math.max(symbolCodeLength, 1);
 
-     }
 
-     while (newSymbols.length < numberOfNewSymbols) {
 
-       var deltaHeight = huffman ? huffmanTables.tableDeltaHeight.decode(huffmanInput) : decodeInteger(contextCache, "IADH", decoder);
 
-       currentHeight += deltaHeight;
 
-       let currentWidth = 0,
 
-           totalWidth = 0;
 
-       const firstSymbol = huffman ? symbolWidths.length : 0;
 
-       while (true) {
 
-         var deltaWidth = huffman ? huffmanTables.tableDeltaWidth.decode(huffmanInput) : decodeInteger(contextCache, "IADW", decoder);
 
-         if (deltaWidth === null) {
 
-           break;
 
-         }
 
-         currentWidth += deltaWidth;
 
-         totalWidth += currentWidth;
 
-         var bitmap;
 
-         if (refinement) {
 
-           var numberOfInstances = decodeInteger(contextCache, "IAAI", decoder);
 
-           if (numberOfInstances > 1) {
 
-             bitmap = decodeTextRegion(huffman, refinement, currentWidth, currentHeight, 0, numberOfInstances, 1, symbols.concat(newSymbols), symbolCodeLength, 0, 0, 1, 0, huffmanTables, refinementTemplateIndex, refinementAt, decodingContext, 0, huffmanInput);
 
-           } else {
 
-             var symbolId = decodeIAID(contextCache, decoder, symbolCodeLength);
 
-             var rdx = decodeInteger(contextCache, "IARDX", decoder);
 
-             var rdy = decodeInteger(contextCache, "IARDY", decoder);
 
-             var symbol = symbolId < symbols.length ? symbols[symbolId] : newSymbols[symbolId - symbols.length];
 
-             bitmap = decodeRefinement(currentWidth, currentHeight, refinementTemplateIndex, symbol, rdx, rdy, false, refinementAt, decodingContext);
 
-           }
 
-           newSymbols.push(bitmap);
 
-         } else if (huffman) {
 
-           symbolWidths.push(currentWidth);
 
-         } else {
 
-           bitmap = decodeBitmap(false, currentWidth, currentHeight, templateIndex, false, null, at, decodingContext);
 
-           newSymbols.push(bitmap);
 
-         }
 
-       }
 
-       if (huffman && !refinement) {
 
-         const bitmapSize = huffmanTables.tableBitmapSize.decode(huffmanInput);
 
-         huffmanInput.byteAlign();
 
-         let collectiveBitmap;
 
-         if (bitmapSize === 0) {
 
-           collectiveBitmap = readUncompressedBitmap(huffmanInput, totalWidth, currentHeight);
 
-         } else {
 
-           const originalEnd = huffmanInput.end;
 
-           const bitmapEnd = huffmanInput.position + bitmapSize;
 
-           huffmanInput.end = bitmapEnd;
 
-           collectiveBitmap = decodeMMRBitmap(huffmanInput, totalWidth, currentHeight, false);
 
-           huffmanInput.end = originalEnd;
 
-           huffmanInput.position = bitmapEnd;
 
-         }
 
-         const numberOfSymbolsDecoded = symbolWidths.length;
 
-         if (firstSymbol === numberOfSymbolsDecoded - 1) {
 
-           newSymbols.push(collectiveBitmap);
 
-         } else {
 
-           let i,
 
-               y,
 
-               xMin = 0,
 
-               xMax,
 
-               bitmapWidth,
 
-               symbolBitmap;
 
-           for (i = firstSymbol; i < numberOfSymbolsDecoded; i++) {
 
-             bitmapWidth = symbolWidths[i];
 
-             xMax = xMin + bitmapWidth;
 
-             symbolBitmap = [];
 
-             for (y = 0; y < currentHeight; y++) {
 
-               symbolBitmap.push(collectiveBitmap[y].subarray(xMin, xMax));
 
-             }
 
-             newSymbols.push(symbolBitmap);
 
-             xMin = xMax;
 
-           }
 
-         }
 
-       }
 
-     }
 
-     var exportedSymbols = [];
 
-     var flags = [],
 
-         currentFlag = false;
 
-     var totalSymbolsLength = symbols.length + numberOfNewSymbols;
 
-     while (flags.length < totalSymbolsLength) {
 
-       var runLength = huffman ? tableB1.decode(huffmanInput) : decodeInteger(contextCache, "IAEX", decoder);
 
-       while (runLength--) {
 
-         flags.push(currentFlag);
 
-       }
 
-       currentFlag = !currentFlag;
 
-     }
 
-     for (var i = 0, ii = symbols.length; i < ii; i++) {
 
-       if (flags[i]) {
 
-         exportedSymbols.push(symbols[i]);
 
-       }
 
-     }
 
-     for (var j = 0; j < numberOfNewSymbols; i++, j++) {
 
-       if (flags[i]) {
 
-         exportedSymbols.push(newSymbols[j]);
 
-       }
 
-     }
 
-     return exportedSymbols;
 
-   }
 
-   function decodeTextRegion(huffman, refinement, width, height, defaultPixelValue, numberOfSymbolInstances, stripSize, inputSymbols, symbolCodeLength, transposed, dsOffset, referenceCorner, combinationOperator, huffmanTables, refinementTemplateIndex, refinementAt, decodingContext, logStripSize, huffmanInput) {
 
-     if (huffman && refinement) {
 
-       throw new Jbig2Error("refinement with Huffman is not supported");
 
-     }
 
-     var bitmap = [];
 
-     var i, row;
 
-     for (i = 0; i < height; i++) {
 
-       row = new Uint8Array(width);
 
-       if (defaultPixelValue) {
 
-         for (var j = 0; j < width; j++) {
 
-           row[j] = defaultPixelValue;
 
-         }
 
-       }
 
-       bitmap.push(row);
 
-     }
 
-     var decoder = decodingContext.decoder;
 
-     var contextCache = decodingContext.contextCache;
 
-     var stripT = huffman ? -huffmanTables.tableDeltaT.decode(huffmanInput) : -decodeInteger(contextCache, "IADT", decoder);
 
-     var firstS = 0;
 
-     i = 0;
 
-     while (i < numberOfSymbolInstances) {
 
-       var deltaT = huffman ? huffmanTables.tableDeltaT.decode(huffmanInput) : decodeInteger(contextCache, "IADT", decoder);
 
-       stripT += deltaT;
 
-       var deltaFirstS = huffman ? huffmanTables.tableFirstS.decode(huffmanInput) : decodeInteger(contextCache, "IAFS", decoder);
 
-       firstS += deltaFirstS;
 
-       var currentS = firstS;
 
-       do {
 
-         let currentT = 0;
 
-         if (stripSize > 1) {
 
-           currentT = huffman ? huffmanInput.readBits(logStripSize) : decodeInteger(contextCache, "IAIT", decoder);
 
-         }
 
-         var t = stripSize * stripT + currentT;
 
-         var symbolId = huffman ? huffmanTables.symbolIDTable.decode(huffmanInput) : decodeIAID(contextCache, decoder, symbolCodeLength);
 
-         var applyRefinement = refinement && (huffman ? huffmanInput.readBit() : decodeInteger(contextCache, "IARI", decoder));
 
-         var symbolBitmap = inputSymbols[symbolId];
 
-         var symbolWidth = symbolBitmap[0].length;
 
-         var symbolHeight = symbolBitmap.length;
 
-         if (applyRefinement) {
 
-           var rdw = decodeInteger(contextCache, "IARDW", decoder);
 
-           var rdh = decodeInteger(contextCache, "IARDH", decoder);
 
-           var rdx = decodeInteger(contextCache, "IARDX", decoder);
 
-           var rdy = decodeInteger(contextCache, "IARDY", decoder);
 
-           symbolWidth += rdw;
 
-           symbolHeight += rdh;
 
-           symbolBitmap = decodeRefinement(symbolWidth, symbolHeight, refinementTemplateIndex, symbolBitmap, (rdw >> 1) + rdx, (rdh >> 1) + rdy, false, refinementAt, decodingContext);
 
-         }
 
-         var offsetT = t - (referenceCorner & 1 ? 0 : symbolHeight - 1);
 
-         var offsetS = currentS - (referenceCorner & 2 ? symbolWidth - 1 : 0);
 
-         var s2, t2, symbolRow;
 
-         if (transposed) {
 
-           for (s2 = 0; s2 < symbolHeight; s2++) {
 
-             row = bitmap[offsetS + s2];
 
-             if (!row) {
 
-               continue;
 
-             }
 
-             symbolRow = symbolBitmap[s2];
 
-             var maxWidth = Math.min(width - offsetT, symbolWidth);
 
-             switch (combinationOperator) {
 
-               case 0:
 
-                 for (t2 = 0; t2 < maxWidth; t2++) {
 
-                   row[offsetT + t2] |= symbolRow[t2];
 
-                 }
 
-                 break;
 
-               case 2:
 
-                 for (t2 = 0; t2 < maxWidth; t2++) {
 
-                   row[offsetT + t2] ^= symbolRow[t2];
 
-                 }
 
-                 break;
 
-               default:
 
-                 throw new Jbig2Error(`operator ${combinationOperator} is not supported`);
 
-             }
 
-           }
 
-           currentS += symbolHeight - 1;
 
-         } else {
 
-           for (t2 = 0; t2 < symbolHeight; t2++) {
 
-             row = bitmap[offsetT + t2];
 
-             if (!row) {
 
-               continue;
 
-             }
 
-             symbolRow = symbolBitmap[t2];
 
-             switch (combinationOperator) {
 
-               case 0:
 
-                 for (s2 = 0; s2 < symbolWidth; s2++) {
 
-                   row[offsetS + s2] |= symbolRow[s2];
 
-                 }
 
-                 break;
 
-               case 2:
 
-                 for (s2 = 0; s2 < symbolWidth; s2++) {
 
-                   row[offsetS + s2] ^= symbolRow[s2];
 
-                 }
 
-                 break;
 
-               default:
 
-                 throw new Jbig2Error(`operator ${combinationOperator} is not supported`);
 
-             }
 
-           }
 
-           currentS += symbolWidth - 1;
 
-         }
 
-         i++;
 
-         var deltaS = huffman ? huffmanTables.tableDeltaS.decode(huffmanInput) : decodeInteger(contextCache, "IADS", decoder);
 
-         if (deltaS === null) {
 
-           break;
 
-         }
 
-         currentS += deltaS + dsOffset;
 
-       } while (true);
 
-     }
 
-     return bitmap;
 
-   }
 
-   function decodePatternDictionary(mmr, patternWidth, patternHeight, maxPatternIndex, template, decodingContext) {
 
-     const at = [];
 
-     if (!mmr) {
 
-       at.push({
 
-         x: -patternWidth,
 
-         y: 0
 
-       });
 
-       if (template === 0) {
 
-         at.push({
 
-           x: -3,
 
-           y: -1
 
-         });
 
-         at.push({
 
-           x: 2,
 
-           y: -2
 
-         });
 
-         at.push({
 
-           x: -2,
 
-           y: -2
 
-         });
 
-       }
 
-     }
 
-     const collectiveWidth = (maxPatternIndex + 1) * patternWidth;
 
-     const collectiveBitmap = decodeBitmap(mmr, collectiveWidth, patternHeight, template, false, null, at, decodingContext);
 
-     const patterns = [];
 
-     for (let i = 0; i <= maxPatternIndex; i++) {
 
-       const patternBitmap = [];
 
-       const xMin = patternWidth * i;
 
-       const xMax = xMin + patternWidth;
 
-       for (let y = 0; y < patternHeight; y++) {
 
-         patternBitmap.push(collectiveBitmap[y].subarray(xMin, xMax));
 
-       }
 
-       patterns.push(patternBitmap);
 
-     }
 
-     return patterns;
 
-   }
 
-   function decodeHalftoneRegion(mmr, patterns, template, regionWidth, regionHeight, defaultPixelValue, enableSkip, combinationOperator, gridWidth, gridHeight, gridOffsetX, gridOffsetY, gridVectorX, gridVectorY, decodingContext) {
 
-     const skip = null;
 
-     if (enableSkip) {
 
-       throw new Jbig2Error("skip is not supported");
 
-     }
 
-     if (combinationOperator !== 0) {
 
-       throw new Jbig2Error("operator " + combinationOperator + " is not supported in halftone region");
 
-     }
 
-     const regionBitmap = [];
 
-     let i, j, row;
 
-     for (i = 0; i < regionHeight; i++) {
 
-       row = new Uint8Array(regionWidth);
 
-       if (defaultPixelValue) {
 
-         for (j = 0; j < regionWidth; j++) {
 
-           row[j] = defaultPixelValue;
 
-         }
 
-       }
 
-       regionBitmap.push(row);
 
-     }
 
-     const numberOfPatterns = patterns.length;
 
-     const pattern0 = patterns[0];
 
-     const patternWidth = pattern0[0].length,
 
-           patternHeight = pattern0.length;
 
-     const bitsPerValue = (0, _core_utils.log2)(numberOfPatterns);
 
-     const at = [];
 
-     if (!mmr) {
 
-       at.push({
 
-         x: template <= 1 ? 3 : 2,
 
-         y: -1
 
-       });
 
-       if (template === 0) {
 
-         at.push({
 
-           x: -3,
 
-           y: -1
 
-         });
 
-         at.push({
 
-           x: 2,
 
-           y: -2
 
-         });
 
-         at.push({
 
-           x: -2,
 
-           y: -2
 
-         });
 
-       }
 
-     }
 
-     const grayScaleBitPlanes = [];
 
-     let mmrInput, bitmap;
 
-     if (mmr) {
 
-       mmrInput = new Reader(decodingContext.data, decodingContext.start, decodingContext.end);
 
-     }
 
-     for (i = bitsPerValue - 1; i >= 0; i--) {
 
-       if (mmr) {
 
-         bitmap = decodeMMRBitmap(mmrInput, gridWidth, gridHeight, true);
 
-       } else {
 
-         bitmap = decodeBitmap(false, gridWidth, gridHeight, template, false, skip, at, decodingContext);
 
-       }
 
-       grayScaleBitPlanes[i] = bitmap;
 
-     }
 
-     let mg, ng, bit, patternIndex, patternBitmap, x, y, patternRow, regionRow;
 
-     for (mg = 0; mg < gridHeight; mg++) {
 
-       for (ng = 0; ng < gridWidth; ng++) {
 
-         bit = 0;
 
-         patternIndex = 0;
 
-         for (j = bitsPerValue - 1; j >= 0; j--) {
 
-           bit = grayScaleBitPlanes[j][mg][ng] ^ bit;
 
-           patternIndex |= bit << j;
 
-         }
 
-         patternBitmap = patterns[patternIndex];
 
-         x = gridOffsetX + mg * gridVectorY + ng * gridVectorX >> 8;
 
-         y = gridOffsetY + mg * gridVectorX - ng * gridVectorY >> 8;
 
-         if (x >= 0 && x + patternWidth <= regionWidth && y >= 0 && y + patternHeight <= regionHeight) {
 
-           for (i = 0; i < patternHeight; i++) {
 
-             regionRow = regionBitmap[y + i];
 
-             patternRow = patternBitmap[i];
 
-             for (j = 0; j < patternWidth; j++) {
 
-               regionRow[x + j] |= patternRow[j];
 
-             }
 
-           }
 
-         } else {
 
-           let regionX, regionY;
 
-           for (i = 0; i < patternHeight; i++) {
 
-             regionY = y + i;
 
-             if (regionY < 0 || regionY >= regionHeight) {
 
-               continue;
 
-             }
 
-             regionRow = regionBitmap[regionY];
 
-             patternRow = patternBitmap[i];
 
-             for (j = 0; j < patternWidth; j++) {
 
-               regionX = x + j;
 
-               if (regionX >= 0 && regionX < regionWidth) {
 
-                 regionRow[regionX] |= patternRow[j];
 
-               }
 
-             }
 
-           }
 
-         }
 
-       }
 
-     }
 
-     return regionBitmap;
 
-   }
 
-   function readSegmentHeader(data, start) {
 
-     var segmentHeader = {};
 
-     segmentHeader.number = (0, _core_utils.readUint32)(data, start);
 
-     var flags = data[start + 4];
 
-     var segmentType = flags & 0x3f;
 
-     if (!SegmentTypes[segmentType]) {
 
-       throw new Jbig2Error("invalid segment type: " + segmentType);
 
-     }
 
-     segmentHeader.type = segmentType;
 
-     segmentHeader.typeName = SegmentTypes[segmentType];
 
-     segmentHeader.deferredNonRetain = !!(flags & 0x80);
 
-     var pageAssociationFieldSize = !!(flags & 0x40);
 
-     var referredFlags = data[start + 5];
 
-     var referredToCount = referredFlags >> 5 & 7;
 
-     var retainBits = [referredFlags & 31];
 
-     var position = start + 6;
 
-     if (referredFlags === 7) {
 
-       referredToCount = (0, _core_utils.readUint32)(data, position - 1) & 0x1fffffff;
 
-       position += 3;
 
-       var bytes = referredToCount + 7 >> 3;
 
-       retainBits[0] = data[position++];
 
-       while (--bytes > 0) {
 
-         retainBits.push(data[position++]);
 
-       }
 
-     } else if (referredFlags === 5 || referredFlags === 6) {
 
-       throw new Jbig2Error("invalid referred-to flags");
 
-     }
 
-     segmentHeader.retainBits = retainBits;
 
-     let referredToSegmentNumberSize = 4;
 
-     if (segmentHeader.number <= 256) {
 
-       referredToSegmentNumberSize = 1;
 
-     } else if (segmentHeader.number <= 65536) {
 
-       referredToSegmentNumberSize = 2;
 
-     }
 
-     var referredTo = [];
 
-     var i, ii;
 
-     for (i = 0; i < referredToCount; i++) {
 
-       let number;
 
-       if (referredToSegmentNumberSize === 1) {
 
-         number = data[position];
 
-       } else if (referredToSegmentNumberSize === 2) {
 
-         number = (0, _core_utils.readUint16)(data, position);
 
-       } else {
 
-         number = (0, _core_utils.readUint32)(data, position);
 
-       }
 
-       referredTo.push(number);
 
-       position += referredToSegmentNumberSize;
 
-     }
 
-     segmentHeader.referredTo = referredTo;
 
-     if (!pageAssociationFieldSize) {
 
-       segmentHeader.pageAssociation = data[position++];
 
-     } else {
 
-       segmentHeader.pageAssociation = (0, _core_utils.readUint32)(data, position);
 
-       position += 4;
 
-     }
 
-     segmentHeader.length = (0, _core_utils.readUint32)(data, position);
 
-     position += 4;
 
-     if (segmentHeader.length === 0xffffffff) {
 
-       if (segmentType === 38) {
 
-         var genericRegionInfo = readRegionSegmentInformation(data, position);
 
-         var genericRegionSegmentFlags = data[position + RegionSegmentInformationFieldLength];
 
-         var genericRegionMmr = !!(genericRegionSegmentFlags & 1);
 
-         var searchPatternLength = 6;
 
-         var searchPattern = new Uint8Array(searchPatternLength);
 
-         if (!genericRegionMmr) {
 
-           searchPattern[0] = 0xff;
 
-           searchPattern[1] = 0xac;
 
-         }
 
-         searchPattern[2] = genericRegionInfo.height >>> 24 & 0xff;
 
-         searchPattern[3] = genericRegionInfo.height >> 16 & 0xff;
 
-         searchPattern[4] = genericRegionInfo.height >> 8 & 0xff;
 
-         searchPattern[5] = genericRegionInfo.height & 0xff;
 
-         for (i = position, ii = data.length; i < ii; i++) {
 
-           var j = 0;
 
-           while (j < searchPatternLength && searchPattern[j] === data[i + j]) {
 
-             j++;
 
-           }
 
-           if (j === searchPatternLength) {
 
-             segmentHeader.length = i + searchPatternLength;
 
-             break;
 
-           }
 
-         }
 
-         if (segmentHeader.length === 0xffffffff) {
 
-           throw new Jbig2Error("segment end was not found");
 
-         }
 
-       } else {
 
-         throw new Jbig2Error("invalid unknown segment length");
 
-       }
 
-     }
 
-     segmentHeader.headerEnd = position;
 
-     return segmentHeader;
 
-   }
 
-   function readSegments(header, data, start, end) {
 
-     var segments = [];
 
-     var position = start;
 
-     while (position < end) {
 
-       var segmentHeader = readSegmentHeader(data, position);
 
-       position = segmentHeader.headerEnd;
 
-       var segment = {
 
-         header: segmentHeader,
 
-         data
 
-       };
 
-       if (!header.randomAccess) {
 
-         segment.start = position;
 
-         position += segmentHeader.length;
 
-         segment.end = position;
 
-       }
 
-       segments.push(segment);
 
-       if (segmentHeader.type === 51) {
 
-         break;
 
-       }
 
-     }
 
-     if (header.randomAccess) {
 
-       for (var i = 0, ii = segments.length; i < ii; i++) {
 
-         segments[i].start = position;
 
-         position += segments[i].header.length;
 
-         segments[i].end = position;
 
-       }
 
-     }
 
-     return segments;
 
-   }
 
-   function readRegionSegmentInformation(data, start) {
 
-     return {
 
-       width: (0, _core_utils.readUint32)(data, start),
 
-       height: (0, _core_utils.readUint32)(data, start + 4),
 
-       x: (0, _core_utils.readUint32)(data, start + 8),
 
-       y: (0, _core_utils.readUint32)(data, start + 12),
 
-       combinationOperator: data[start + 16] & 7
 
-     };
 
-   }
 
-   var RegionSegmentInformationFieldLength = 17;
 
-   function processSegment(segment, visitor) {
 
-     var header = segment.header;
 
-     var data = segment.data,
 
-         position = segment.start,
 
-         end = segment.end;
 
-     var args, at, i, atLength;
 
-     switch (header.type) {
 
-       case 0:
 
-         var dictionary = {};
 
-         var dictionaryFlags = (0, _core_utils.readUint16)(data, position);
 
-         dictionary.huffman = !!(dictionaryFlags & 1);
 
-         dictionary.refinement = !!(dictionaryFlags & 2);
 
-         dictionary.huffmanDHSelector = dictionaryFlags >> 2 & 3;
 
-         dictionary.huffmanDWSelector = dictionaryFlags >> 4 & 3;
 
-         dictionary.bitmapSizeSelector = dictionaryFlags >> 6 & 1;
 
-         dictionary.aggregationInstancesSelector = dictionaryFlags >> 7 & 1;
 
-         dictionary.bitmapCodingContextUsed = !!(dictionaryFlags & 256);
 
-         dictionary.bitmapCodingContextRetained = !!(dictionaryFlags & 512);
 
-         dictionary.template = dictionaryFlags >> 10 & 3;
 
-         dictionary.refinementTemplate = dictionaryFlags >> 12 & 1;
 
-         position += 2;
 
-         if (!dictionary.huffman) {
 
-           atLength = dictionary.template === 0 ? 4 : 1;
 
-           at = [];
 
-           for (i = 0; i < atLength; i++) {
 
-             at.push({
 
-               x: (0, _core_utils.readInt8)(data, position),
 
-               y: (0, _core_utils.readInt8)(data, position + 1)
 
-             });
 
-             position += 2;
 
-           }
 
-           dictionary.at = at;
 
-         }
 
-         if (dictionary.refinement && !dictionary.refinementTemplate) {
 
-           at = [];
 
-           for (i = 0; i < 2; i++) {
 
-             at.push({
 
-               x: (0, _core_utils.readInt8)(data, position),
 
-               y: (0, _core_utils.readInt8)(data, position + 1)
 
-             });
 
-             position += 2;
 
-           }
 
-           dictionary.refinementAt = at;
 
-         }
 
-         dictionary.numberOfExportedSymbols = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         dictionary.numberOfNewSymbols = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         args = [dictionary, header.number, header.referredTo, data, position, end];
 
-         break;
 
-       case 6:
 
-       case 7:
 
-         var textRegion = {};
 
-         textRegion.info = readRegionSegmentInformation(data, position);
 
-         position += RegionSegmentInformationFieldLength;
 
-         var textRegionSegmentFlags = (0, _core_utils.readUint16)(data, position);
 
-         position += 2;
 
-         textRegion.huffman = !!(textRegionSegmentFlags & 1);
 
-         textRegion.refinement = !!(textRegionSegmentFlags & 2);
 
-         textRegion.logStripSize = textRegionSegmentFlags >> 2 & 3;
 
-         textRegion.stripSize = 1 << textRegion.logStripSize;
 
-         textRegion.referenceCorner = textRegionSegmentFlags >> 4 & 3;
 
-         textRegion.transposed = !!(textRegionSegmentFlags & 64);
 
-         textRegion.combinationOperator = textRegionSegmentFlags >> 7 & 3;
 
-         textRegion.defaultPixelValue = textRegionSegmentFlags >> 9 & 1;
 
-         textRegion.dsOffset = textRegionSegmentFlags << 17 >> 27;
 
-         textRegion.refinementTemplate = textRegionSegmentFlags >> 15 & 1;
 
-         if (textRegion.huffman) {
 
-           var textRegionHuffmanFlags = (0, _core_utils.readUint16)(data, position);
 
-           position += 2;
 
-           textRegion.huffmanFS = textRegionHuffmanFlags & 3;
 
-           textRegion.huffmanDS = textRegionHuffmanFlags >> 2 & 3;
 
-           textRegion.huffmanDT = textRegionHuffmanFlags >> 4 & 3;
 
-           textRegion.huffmanRefinementDW = textRegionHuffmanFlags >> 6 & 3;
 
-           textRegion.huffmanRefinementDH = textRegionHuffmanFlags >> 8 & 3;
 
-           textRegion.huffmanRefinementDX = textRegionHuffmanFlags >> 10 & 3;
 
-           textRegion.huffmanRefinementDY = textRegionHuffmanFlags >> 12 & 3;
 
-           textRegion.huffmanRefinementSizeSelector = !!(textRegionHuffmanFlags & 0x4000);
 
-         }
 
-         if (textRegion.refinement && !textRegion.refinementTemplate) {
 
-           at = [];
 
-           for (i = 0; i < 2; i++) {
 
-             at.push({
 
-               x: (0, _core_utils.readInt8)(data, position),
 
-               y: (0, _core_utils.readInt8)(data, position + 1)
 
-             });
 
-             position += 2;
 
-           }
 
-           textRegion.refinementAt = at;
 
-         }
 
-         textRegion.numberOfSymbolInstances = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         args = [textRegion, header.referredTo, data, position, end];
 
-         break;
 
-       case 16:
 
-         const patternDictionary = {};
 
-         const patternDictionaryFlags = data[position++];
 
-         patternDictionary.mmr = !!(patternDictionaryFlags & 1);
 
-         patternDictionary.template = patternDictionaryFlags >> 1 & 3;
 
-         patternDictionary.patternWidth = data[position++];
 
-         patternDictionary.patternHeight = data[position++];
 
-         patternDictionary.maxPatternIndex = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         args = [patternDictionary, header.number, data, position, end];
 
-         break;
 
-       case 22:
 
-       case 23:
 
-         const halftoneRegion = {};
 
-         halftoneRegion.info = readRegionSegmentInformation(data, position);
 
-         position += RegionSegmentInformationFieldLength;
 
-         const halftoneRegionFlags = data[position++];
 
-         halftoneRegion.mmr = !!(halftoneRegionFlags & 1);
 
-         halftoneRegion.template = halftoneRegionFlags >> 1 & 3;
 
-         halftoneRegion.enableSkip = !!(halftoneRegionFlags & 8);
 
-         halftoneRegion.combinationOperator = halftoneRegionFlags >> 4 & 7;
 
-         halftoneRegion.defaultPixelValue = halftoneRegionFlags >> 7 & 1;
 
-         halftoneRegion.gridWidth = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         halftoneRegion.gridHeight = (0, _core_utils.readUint32)(data, position);
 
-         position += 4;
 
-         halftoneRegion.gridOffsetX = (0, _core_utils.readUint32)(data, position) & 0xffffffff;
 
-         position += 4;
 
-         halftoneRegion.gridOffsetY = (0, _core_utils.readUint32)(data, position) & 0xffffffff;
 
-         position += 4;
 
-         halftoneRegion.gridVectorX = (0, _core_utils.readUint16)(data, position);
 
-         position += 2;
 
-         halftoneRegion.gridVectorY = (0, _core_utils.readUint16)(data, position);
 
-         position += 2;
 
-         args = [halftoneRegion, header.referredTo, data, position, end];
 
-         break;
 
-       case 38:
 
-       case 39:
 
-         var genericRegion = {};
 
-         genericRegion.info = readRegionSegmentInformation(data, position);
 
-         position += RegionSegmentInformationFieldLength;
 
-         var genericRegionSegmentFlags = data[position++];
 
-         genericRegion.mmr = !!(genericRegionSegmentFlags & 1);
 
-         genericRegion.template = genericRegionSegmentFlags >> 1 & 3;
 
-         genericRegion.prediction = !!(genericRegionSegmentFlags & 8);
 
-         if (!genericRegion.mmr) {
 
-           atLength = genericRegion.template === 0 ? 4 : 1;
 
-           at = [];
 
-           for (i = 0; i < atLength; i++) {
 
-             at.push({
 
-               x: (0, _core_utils.readInt8)(data, position),
 
-               y: (0, _core_utils.readInt8)(data, position + 1)
 
-             });
 
-             position += 2;
 
-           }
 
-           genericRegion.at = at;
 
-         }
 
-         args = [genericRegion, data, position, end];
 
-         break;
 
-       case 48:
 
-         var pageInfo = {
 
-           width: (0, _core_utils.readUint32)(data, position),
 
-           height: (0, _core_utils.readUint32)(data, position + 4),
 
-           resolutionX: (0, _core_utils.readUint32)(data, position + 8),
 
-           resolutionY: (0, _core_utils.readUint32)(data, position + 12)
 
-         };
 
-         if (pageInfo.height === 0xffffffff) {
 
-           delete pageInfo.height;
 
-         }
 
-         var pageSegmentFlags = data[position + 16];
 
-         (0, _core_utils.readUint16)(data, position + 17);
 
-         pageInfo.lossless = !!(pageSegmentFlags & 1);
 
-         pageInfo.refinement = !!(pageSegmentFlags & 2);
 
-         pageInfo.defaultPixelValue = pageSegmentFlags >> 2 & 1;
 
-         pageInfo.combinationOperator = pageSegmentFlags >> 3 & 3;
 
-         pageInfo.requiresBuffer = !!(pageSegmentFlags & 32);
 
-         pageInfo.combinationOperatorOverride = !!(pageSegmentFlags & 64);
 
-         args = [pageInfo];
 
-         break;
 
-       case 49:
 
-         break;
 
-       case 50:
 
-         break;
 
-       case 51:
 
-         break;
 
-       case 53:
 
-         args = [header.number, data, position, end];
 
-         break;
 
-       case 62:
 
-         break;
 
-       default:
 
-         throw new Jbig2Error(`segment type ${header.typeName}(${header.type})` + " is not implemented");
 
-     }
 
-     var callbackName = "on" + header.typeName;
 
-     if (callbackName in visitor) {
 
-       visitor[callbackName].apply(visitor, args);
 
-     }
 
-   }
 
-   function processSegments(segments, visitor) {
 
-     for (var i = 0, ii = segments.length; i < ii; i++) {
 
-       processSegment(segments[i], visitor);
 
-     }
 
-   }
 
-   function parseJbig2Chunks(chunks) {
 
-     var visitor = new SimpleSegmentVisitor();
 
-     for (var i = 0, ii = chunks.length; i < ii; i++) {
 
-       var chunk = chunks[i];
 
-       var segments = readSegments({}, chunk.data, chunk.start, chunk.end);
 
-       processSegments(segments, visitor);
 
-     }
 
-     return visitor.buffer;
 
-   }
 
-   function parseJbig2(data) {
 
-     const end = data.length;
 
-     let position = 0;
 
-     if (data[position] !== 0x97 || data[position + 1] !== 0x4a || data[position + 2] !== 0x42 || data[position + 3] !== 0x32 || data[position + 4] !== 0x0d || data[position + 5] !== 0x0a || data[position + 6] !== 0x1a || data[position + 7] !== 0x0a) {
 
-       throw new Jbig2Error("parseJbig2 - invalid header.");
 
-     }
 
-     const header = Object.create(null);
 
-     position += 8;
 
-     const flags = data[position++];
 
-     header.randomAccess = !(flags & 1);
 
-     if (!(flags & 2)) {
 
-       header.numberOfPages = (0, _core_utils.readUint32)(data, position);
 
-       position += 4;
 
-     }
 
-     const segments = readSegments(header, data, position, end);
 
-     const visitor = new SimpleSegmentVisitor();
 
-     processSegments(segments, visitor);
 
-     const {
 
-       width,
 
-       height
 
-     } = visitor.currentPageInfo;
 
-     const bitPacked = visitor.buffer;
 
-     const imgData = new Uint8ClampedArray(width * height);
 
-     let q = 0,
 
-         k = 0;
 
-     for (let i = 0; i < height; i++) {
 
-       let mask = 0,
 
-           buffer;
 
-       for (let j = 0; j < width; j++) {
 
-         if (!mask) {
 
-           mask = 128;
 
-           buffer = bitPacked[k++];
 
-         }
 
-         imgData[q++] = buffer & mask ? 0 : 255;
 
-         mask >>= 1;
 
-       }
 
-     }
 
-     return {
 
-       imgData,
 
-       width,
 
-       height
 
-     };
 
-   }
 
-   function SimpleSegmentVisitor() {}
 
-   SimpleSegmentVisitor.prototype = {
 
-     onPageInformation: function SimpleSegmentVisitor_onPageInformation(info) {
 
-       this.currentPageInfo = info;
 
-       var rowSize = info.width + 7 >> 3;
 
-       var buffer = new Uint8ClampedArray(rowSize * info.height);
 
-       if (info.defaultPixelValue) {
 
-         for (var i = 0, ii = buffer.length; i < ii; i++) {
 
-           buffer[i] = 0xff;
 
-         }
 
-       }
 
-       this.buffer = buffer;
 
-     },
 
-     drawBitmap: function SimpleSegmentVisitor_drawBitmap(regionInfo, bitmap) {
 
-       var pageInfo = this.currentPageInfo;
 
-       var width = regionInfo.width,
 
-           height = regionInfo.height;
 
-       var rowSize = pageInfo.width + 7 >> 3;
 
-       var combinationOperator = pageInfo.combinationOperatorOverride ? regionInfo.combinationOperator : pageInfo.combinationOperator;
 
-       var buffer = this.buffer;
 
-       var mask0 = 128 >> (regionInfo.x & 7);
 
-       var offset0 = regionInfo.y * rowSize + (regionInfo.x >> 3);
 
-       var i, j, mask, offset;
 
-       switch (combinationOperator) {
 
-         case 0:
 
-           for (i = 0; i < height; i++) {
 
-             mask = mask0;
 
-             offset = offset0;
 
-             for (j = 0; j < width; j++) {
 
-               if (bitmap[i][j]) {
 
-                 buffer[offset] |= mask;
 
-               }
 
-               mask >>= 1;
 
-               if (!mask) {
 
-                 mask = 128;
 
-                 offset++;
 
-               }
 
-             }
 
-             offset0 += rowSize;
 
-           }
 
-           break;
 
-         case 2:
 
-           for (i = 0; i < height; i++) {
 
-             mask = mask0;
 
-             offset = offset0;
 
-             for (j = 0; j < width; j++) {
 
-               if (bitmap[i][j]) {
 
-                 buffer[offset] ^= mask;
 
-               }
 
-               mask >>= 1;
 
-               if (!mask) {
 
-                 mask = 128;
 
-                 offset++;
 
-               }
 
-             }
 
-             offset0 += rowSize;
 
-           }
 
-           break;
 
-         default:
 
-           throw new Jbig2Error(`operator ${combinationOperator} is not supported`);
 
-       }
 
-     },
 
-     onImmediateGenericRegion: function SimpleSegmentVisitor_onImmediateGenericRegion(region, data, start, end) {
 
-       var regionInfo = region.info;
 
-       var decodingContext = new DecodingContext(data, start, end);
 
-       var bitmap = decodeBitmap(region.mmr, regionInfo.width, regionInfo.height, region.template, region.prediction, null, region.at, decodingContext);
 
-       this.drawBitmap(regionInfo, bitmap);
 
-     },
 
-     onImmediateLosslessGenericRegion: function SimpleSegmentVisitor_onImmediateLosslessGenericRegion() {
 
-       this.onImmediateGenericRegion.apply(this, arguments);
 
-     },
 
-     onSymbolDictionary: function SimpleSegmentVisitor_onSymbolDictionary(dictionary, currentSegment, referredSegments, data, start, end) {
 
-       let huffmanTables, huffmanInput;
 
-       if (dictionary.huffman) {
 
-         huffmanTables = getSymbolDictionaryHuffmanTables(dictionary, referredSegments, this.customTables);
 
-         huffmanInput = new Reader(data, start, end);
 
-       }
 
-       var symbols = this.symbols;
 
-       if (!symbols) {
 
-         this.symbols = symbols = {};
 
-       }
 
-       var inputSymbols = [];
 
-       for (var i = 0, ii = referredSegments.length; i < ii; i++) {
 
-         const referredSymbols = symbols[referredSegments[i]];
 
-         if (referredSymbols) {
 
-           inputSymbols = inputSymbols.concat(referredSymbols);
 
-         }
 
-       }
 
-       var decodingContext = new DecodingContext(data, start, end);
 
-       symbols[currentSegment] = decodeSymbolDictionary(dictionary.huffman, dictionary.refinement, inputSymbols, dictionary.numberOfNewSymbols, dictionary.numberOfExportedSymbols, huffmanTables, dictionary.template, dictionary.at, dictionary.refinementTemplate, dictionary.refinementAt, decodingContext, huffmanInput);
 
-     },
 
-     onImmediateTextRegion: function SimpleSegmentVisitor_onImmediateTextRegion(region, referredSegments, data, start, end) {
 
-       var regionInfo = region.info;
 
-       let huffmanTables, huffmanInput;
 
-       var symbols = this.symbols;
 
-       var inputSymbols = [];
 
-       for (var i = 0, ii = referredSegments.length; i < ii; i++) {
 
-         const referredSymbols = symbols[referredSegments[i]];
 
-         if (referredSymbols) {
 
-           inputSymbols = inputSymbols.concat(referredSymbols);
 
-         }
 
-       }
 
-       var symbolCodeLength = (0, _core_utils.log2)(inputSymbols.length);
 
-       if (region.huffman) {
 
-         huffmanInput = new Reader(data, start, end);
 
-         huffmanTables = getTextRegionHuffmanTables(region, referredSegments, this.customTables, inputSymbols.length, huffmanInput);
 
-       }
 
-       var decodingContext = new DecodingContext(data, start, end);
 
-       var bitmap = decodeTextRegion(region.huffman, region.refinement, regionInfo.width, regionInfo.height, region.defaultPixelValue, region.numberOfSymbolInstances, region.stripSize, inputSymbols, symbolCodeLength, region.transposed, region.dsOffset, region.referenceCorner, region.combinationOperator, huffmanTables, region.refinementTemplate, region.refinementAt, decodingContext, region.logStripSize, huffmanInput);
 
-       this.drawBitmap(regionInfo, bitmap);
 
-     },
 
-     onImmediateLosslessTextRegion: function SimpleSegmentVisitor_onImmediateLosslessTextRegion() {
 
-       this.onImmediateTextRegion.apply(this, arguments);
 
-     },
 
-     onPatternDictionary(dictionary, currentSegment, data, start, end) {
 
-       let patterns = this.patterns;
 
-       if (!patterns) {
 
-         this.patterns = patterns = {};
 
-       }
 
-       const decodingContext = new DecodingContext(data, start, end);
 
-       patterns[currentSegment] = decodePatternDictionary(dictionary.mmr, dictionary.patternWidth, dictionary.patternHeight, dictionary.maxPatternIndex, dictionary.template, decodingContext);
 
-     },
 
-     onImmediateHalftoneRegion(region, referredSegments, data, start, end) {
 
-       const patterns = this.patterns[referredSegments[0]];
 
-       const regionInfo = region.info;
 
-       const decodingContext = new DecodingContext(data, start, end);
 
-       const bitmap = decodeHalftoneRegion(region.mmr, patterns, region.template, regionInfo.width, regionInfo.height, region.defaultPixelValue, region.enableSkip, region.combinationOperator, region.gridWidth, region.gridHeight, region.gridOffsetX, region.gridOffsetY, region.gridVectorX, region.gridVectorY, decodingContext);
 
-       this.drawBitmap(regionInfo, bitmap);
 
-     },
 
-     onImmediateLosslessHalftoneRegion() {
 
-       this.onImmediateHalftoneRegion.apply(this, arguments);
 
-     },
 
-     onTables(currentSegment, data, start, end) {
 
-       let customTables = this.customTables;
 
-       if (!customTables) {
 
-         this.customTables = customTables = {};
 
-       }
 
-       customTables[currentSegment] = decodeTablesSegment(data, start, end);
 
-     }
 
-   };
 
-   function HuffmanLine(lineData) {
 
-     if (lineData.length === 2) {
 
-       this.isOOB = true;
 
-       this.rangeLow = 0;
 
-       this.prefixLength = lineData[0];
 
-       this.rangeLength = 0;
 
-       this.prefixCode = lineData[1];
 
-       this.isLowerRange = false;
 
-     } else {
 
-       this.isOOB = false;
 
-       this.rangeLow = lineData[0];
 
-       this.prefixLength = lineData[1];
 
-       this.rangeLength = lineData[2];
 
-       this.prefixCode = lineData[3];
 
-       this.isLowerRange = lineData[4] === "lower";
 
-     }
 
-   }
 
-   function HuffmanTreeNode(line) {
 
-     this.children = [];
 
-     if (line) {
 
-       this.isLeaf = true;
 
-       this.rangeLength = line.rangeLength;
 
-       this.rangeLow = line.rangeLow;
 
-       this.isLowerRange = line.isLowerRange;
 
-       this.isOOB = line.isOOB;
 
-     } else {
 
-       this.isLeaf = false;
 
-     }
 
-   }
 
-   HuffmanTreeNode.prototype = {
 
-     buildTree(line, shift) {
 
-       const bit = line.prefixCode >> shift & 1;
 
-       if (shift <= 0) {
 
-         this.children[bit] = new HuffmanTreeNode(line);
 
-       } else {
 
-         let node = this.children[bit];
 
-         if (!node) {
 
-           this.children[bit] = node = new HuffmanTreeNode(null);
 
-         }
 
-         node.buildTree(line, shift - 1);
 
-       }
 
-     },
 
-     decodeNode(reader) {
 
-       if (this.isLeaf) {
 
-         if (this.isOOB) {
 
-           return null;
 
-         }
 
-         const htOffset = reader.readBits(this.rangeLength);
 
-         return this.rangeLow + (this.isLowerRange ? -htOffset : htOffset);
 
-       }
 
-       const node = this.children[reader.readBit()];
 
-       if (!node) {
 
-         throw new Jbig2Error("invalid Huffman data");
 
-       }
 
-       return node.decodeNode(reader);
 
-     }
 
-   };
 
-   function HuffmanTable(lines, prefixCodesDone) {
 
-     if (!prefixCodesDone) {
 
-       this.assignPrefixCodes(lines);
 
-     }
 
-     this.rootNode = new HuffmanTreeNode(null);
 
-     for (let i = 0, ii = lines.length; i < ii; i++) {
 
-       const line = lines[i];
 
-       if (line.prefixLength > 0) {
 
-         this.rootNode.buildTree(line, line.prefixLength - 1);
 
-       }
 
-     }
 
-   }
 
-   HuffmanTable.prototype = {
 
-     decode(reader) {
 
-       return this.rootNode.decodeNode(reader);
 
-     },
 
-     assignPrefixCodes(lines) {
 
-       const linesLength = lines.length;
 
-       let prefixLengthMax = 0;
 
-       for (let i = 0; i < linesLength; i++) {
 
-         prefixLengthMax = Math.max(prefixLengthMax, lines[i].prefixLength);
 
-       }
 
-       const histogram = new Uint32Array(prefixLengthMax + 1);
 
-       for (let i = 0; i < linesLength; i++) {
 
-         histogram[lines[i].prefixLength]++;
 
-       }
 
-       let currentLength = 1,
 
-           firstCode = 0,
 
-           currentCode,
 
-           currentTemp,
 
-           line;
 
-       histogram[0] = 0;
 
-       while (currentLength <= prefixLengthMax) {
 
-         firstCode = firstCode + histogram[currentLength - 1] << 1;
 
-         currentCode = firstCode;
 
-         currentTemp = 0;
 
-         while (currentTemp < linesLength) {
 
-           line = lines[currentTemp];
 
-           if (line.prefixLength === currentLength) {
 
-             line.prefixCode = currentCode;
 
-             currentCode++;
 
-           }
 
-           currentTemp++;
 
-         }
 
-         currentLength++;
 
-       }
 
-     }
 
-   };
 
-   function decodeTablesSegment(data, start, end) {
 
-     const flags = data[start];
 
-     const lowestValue = (0, _core_utils.readUint32)(data, start + 1) & 0xffffffff;
 
-     const highestValue = (0, _core_utils.readUint32)(data, start + 5) & 0xffffffff;
 
-     const reader = new Reader(data, start + 9, end);
 
-     const prefixSizeBits = (flags >> 1 & 7) + 1;
 
-     const rangeSizeBits = (flags >> 4 & 7) + 1;
 
-     const lines = [];
 
-     let prefixLength,
 
-         rangeLength,
 
-         currentRangeLow = lowestValue;
 
-     do {
 
-       prefixLength = reader.readBits(prefixSizeBits);
 
-       rangeLength = reader.readBits(rangeSizeBits);
 
-       lines.push(new HuffmanLine([currentRangeLow, prefixLength, rangeLength, 0]));
 
-       currentRangeLow += 1 << rangeLength;
 
-     } while (currentRangeLow < highestValue);
 
-     prefixLength = reader.readBits(prefixSizeBits);
 
-     lines.push(new HuffmanLine([lowestValue - 1, prefixLength, 32, 0, "lower"]));
 
-     prefixLength = reader.readBits(prefixSizeBits);
 
-     lines.push(new HuffmanLine([highestValue, prefixLength, 32, 0]));
 
-     if (flags & 1) {
 
-       prefixLength = reader.readBits(prefixSizeBits);
 
-       lines.push(new HuffmanLine([prefixLength, 0]));
 
-     }
 
-     return new HuffmanTable(lines, false);
 
-   }
 
-   const standardTablesCache = {};
 
-   function getStandardTable(number) {
 
-     let table = standardTablesCache[number];
 
-     if (table) {
 
-       return table;
 
-     }
 
-     let lines;
 
-     switch (number) {
 
-       case 1:
 
-         lines = [[0, 1, 4, 0x0], [16, 2, 8, 0x2], [272, 3, 16, 0x6], [65808, 3, 32, 0x7]];
 
-         break;
 
-       case 2:
 
-         lines = [[0, 1, 0, 0x0], [1, 2, 0, 0x2], [2, 3, 0, 0x6], [3, 4, 3, 0xe], [11, 5, 6, 0x1e], [75, 6, 32, 0x3e], [6, 0x3f]];
 
-         break;
 
-       case 3:
 
-         lines = [[-256, 8, 8, 0xfe], [0, 1, 0, 0x0], [1, 2, 0, 0x2], [2, 3, 0, 0x6], [3, 4, 3, 0xe], [11, 5, 6, 0x1e], [-257, 8, 32, 0xff, "lower"], [75, 7, 32, 0x7e], [6, 0x3e]];
 
-         break;
 
-       case 4:
 
-         lines = [[1, 1, 0, 0x0], [2, 2, 0, 0x2], [3, 3, 0, 0x6], [4, 4, 3, 0xe], [12, 5, 6, 0x1e], [76, 5, 32, 0x1f]];
 
-         break;
 
-       case 5:
 
-         lines = [[-255, 7, 8, 0x7e], [1, 1, 0, 0x0], [2, 2, 0, 0x2], [3, 3, 0, 0x6], [4, 4, 3, 0xe], [12, 5, 6, 0x1e], [-256, 7, 32, 0x7f, "lower"], [76, 6, 32, 0x3e]];
 
-         break;
 
-       case 6:
 
-         lines = [[-2048, 5, 10, 0x1c], [-1024, 4, 9, 0x8], [-512, 4, 8, 0x9], [-256, 4, 7, 0xa], [-128, 5, 6, 0x1d], [-64, 5, 5, 0x1e], [-32, 4, 5, 0xb], [0, 2, 7, 0x0], [128, 3, 7, 0x2], [256, 3, 8, 0x3], [512, 4, 9, 0xc], [1024, 4, 10, 0xd], [-2049, 6, 32, 0x3e, "lower"], [2048, 6, 32, 0x3f]];
 
-         break;
 
-       case 7:
 
-         lines = [[-1024, 4, 9, 0x8], [-512, 3, 8, 0x0], [-256, 4, 7, 0x9], [-128, 5, 6, 0x1a], [-64, 5, 5, 0x1b], [-32, 4, 5, 0xa], [0, 4, 5, 0xb], [32, 5, 5, 0x1c], [64, 5, 6, 0x1d], [128, 4, 7, 0xc], [256, 3, 8, 0x1], [512, 3, 9, 0x2], [1024, 3, 10, 0x3], [-1025, 5, 32, 0x1e, "lower"], [2048, 5, 32, 0x1f]];
 
-         break;
 
-       case 8:
 
-         lines = [[-15, 8, 3, 0xfc], [-7, 9, 1, 0x1fc], [-5, 8, 1, 0xfd], [-3, 9, 0, 0x1fd], [-2, 7, 0, 0x7c], [-1, 4, 0, 0xa], [0, 2, 1, 0x0], [2, 5, 0, 0x1a], [3, 6, 0, 0x3a], [4, 3, 4, 0x4], [20, 6, 1, 0x3b], [22, 4, 4, 0xb], [38, 4, 5, 0xc], [70, 5, 6, 0x1b], [134, 5, 7, 0x1c], [262, 6, 7, 0x3c], [390, 7, 8, 0x7d], [646, 6, 10, 0x3d], [-16, 9, 32, 0x1fe, "lower"], [1670, 9, 32, 0x1ff], [2, 0x1]];
 
-         break;
 
-       case 9:
 
-         lines = [[-31, 8, 4, 0xfc], [-15, 9, 2, 0x1fc], [-11, 8, 2, 0xfd], [-7, 9, 1, 0x1fd], [-5, 7, 1, 0x7c], [-3, 4, 1, 0xa], [-1, 3, 1, 0x2], [1, 3, 1, 0x3], [3, 5, 1, 0x1a], [5, 6, 1, 0x3a], [7, 3, 5, 0x4], [39, 6, 2, 0x3b], [43, 4, 5, 0xb], [75, 4, 6, 0xc], [139, 5, 7, 0x1b], [267, 5, 8, 0x1c], [523, 6, 8, 0x3c], [779, 7, 9, 0x7d], [1291, 6, 11, 0x3d], [-32, 9, 32, 0x1fe, "lower"], [3339, 9, 32, 0x1ff], [2, 0x0]];
 
-         break;
 
-       case 10:
 
-         lines = [[-21, 7, 4, 0x7a], [-5, 8, 0, 0xfc], [-4, 7, 0, 0x7b], [-3, 5, 0, 0x18], [-2, 2, 2, 0x0], [2, 5, 0, 0x19], [3, 6, 0, 0x36], [4, 7, 0, 0x7c], [5, 8, 0, 0xfd], [6, 2, 6, 0x1], [70, 5, 5, 0x1a], [102, 6, 5, 0x37], [134, 6, 6, 0x38], [198, 6, 7, 0x39], [326, 6, 8, 0x3a], [582, 6, 9, 0x3b], [1094, 6, 10, 0x3c], [2118, 7, 11, 0x7d], [-22, 8, 32, 0xfe, "lower"], [4166, 8, 32, 0xff], [2, 0x2]];
 
-         break;
 
-       case 11:
 
-         lines = [[1, 1, 0, 0x0], [2, 2, 1, 0x2], [4, 4, 0, 0xc], [5, 4, 1, 0xd], [7, 5, 1, 0x1c], [9, 5, 2, 0x1d], [13, 6, 2, 0x3c], [17, 7, 2, 0x7a], [21, 7, 3, 0x7b], [29, 7, 4, 0x7c], [45, 7, 5, 0x7d], [77, 7, 6, 0x7e], [141, 7, 32, 0x7f]];
 
-         break;
 
-       case 12:
 
-         lines = [[1, 1, 0, 0x0], [2, 2, 0, 0x2], [3, 3, 1, 0x6], [5, 5, 0, 0x1c], [6, 5, 1, 0x1d], [8, 6, 1, 0x3c], [10, 7, 0, 0x7a], [11, 7, 1, 0x7b], [13, 7, 2, 0x7c], [17, 7, 3, 0x7d], [25, 7, 4, 0x7e], [41, 8, 5, 0xfe], [73, 8, 32, 0xff]];
 
-         break;
 
-       case 13:
 
-         lines = [[1, 1, 0, 0x0], [2, 3, 0, 0x4], [3, 4, 0, 0xc], [4, 5, 0, 0x1c], [5, 4, 1, 0xd], [7, 3, 3, 0x5], [15, 6, 1, 0x3a], [17, 6, 2, 0x3b], [21, 6, 3, 0x3c], [29, 6, 4, 0x3d], [45, 6, 5, 0x3e], [77, 7, 6, 0x7e], [141, 7, 32, 0x7f]];
 
-         break;
 
-       case 14:
 
-         lines = [[-2, 3, 0, 0x4], [-1, 3, 0, 0x5], [0, 1, 0, 0x0], [1, 3, 0, 0x6], [2, 3, 0, 0x7]];
 
-         break;
 
-       case 15:
 
-         lines = [[-24, 7, 4, 0x7c], [-8, 6, 2, 0x3c], [-4, 5, 1, 0x1c], [-2, 4, 0, 0xc], [-1, 3, 0, 0x4], [0, 1, 0, 0x0], [1, 3, 0, 0x5], [2, 4, 0, 0xd], [3, 5, 1, 0x1d], [5, 6, 2, 0x3d], [9, 7, 4, 0x7d], [-25, 7, 32, 0x7e, "lower"], [25, 7, 32, 0x7f]];
 
-         break;
 
-       default:
 
-         throw new Jbig2Error(`standard table B.${number} does not exist`);
 
-     }
 
-     for (let i = 0, ii = lines.length; i < ii; i++) {
 
-       lines[i] = new HuffmanLine(lines[i]);
 
-     }
 
-     table = new HuffmanTable(lines, true);
 
-     standardTablesCache[number] = table;
 
-     return table;
 
-   }
 
-   function Reader(data, start, end) {
 
-     this.data = data;
 
-     this.start = start;
 
-     this.end = end;
 
-     this.position = start;
 
-     this.shift = -1;
 
-     this.currentByte = 0;
 
-   }
 
-   Reader.prototype = {
 
-     readBit() {
 
-       if (this.shift < 0) {
 
-         if (this.position >= this.end) {
 
-           throw new Jbig2Error("end of data while reading bit");
 
-         }
 
-         this.currentByte = this.data[this.position++];
 
-         this.shift = 7;
 
-       }
 
-       const bit = this.currentByte >> this.shift & 1;
 
-       this.shift--;
 
-       return bit;
 
-     },
 
-     readBits(numBits) {
 
-       let result = 0,
 
-           i;
 
-       for (i = numBits - 1; i >= 0; i--) {
 
-         result |= this.readBit() << i;
 
-       }
 
-       return result;
 
-     },
 
-     byteAlign() {
 
-       this.shift = -1;
 
-     },
 
-     next() {
 
-       if (this.position >= this.end) {
 
-         return -1;
 
-       }
 
-       return this.data[this.position++];
 
-     }
 
-   };
 
-   function getCustomHuffmanTable(index, referredTo, customTables) {
 
-     let currentIndex = 0;
 
-     for (let i = 0, ii = referredTo.length; i < ii; i++) {
 
-       const table = customTables[referredTo[i]];
 
-       if (table) {
 
-         if (index === currentIndex) {
 
-           return table;
 
-         }
 
-         currentIndex++;
 
-       }
 
-     }
 
-     throw new Jbig2Error("can't find custom Huffman table");
 
-   }
 
-   function getTextRegionHuffmanTables(textRegion, referredTo, customTables, numberOfSymbols, reader) {
 
-     const codes = [];
 
-     for (let i = 0; i <= 34; i++) {
 
-       const codeLength = reader.readBits(4);
 
-       codes.push(new HuffmanLine([i, codeLength, 0, 0]));
 
-     }
 
-     const runCodesTable = new HuffmanTable(codes, false);
 
-     codes.length = 0;
 
-     for (let i = 0; i < numberOfSymbols;) {
 
-       const codeLength = runCodesTable.decode(reader);
 
-       if (codeLength >= 32) {
 
-         let repeatedLength, numberOfRepeats, j;
 
-         switch (codeLength) {
 
-           case 32:
 
-             if (i === 0) {
 
-               throw new Jbig2Error("no previous value in symbol ID table");
 
-             }
 
-             numberOfRepeats = reader.readBits(2) + 3;
 
-             repeatedLength = codes[i - 1].prefixLength;
 
-             break;
 
-           case 33:
 
-             numberOfRepeats = reader.readBits(3) + 3;
 
-             repeatedLength = 0;
 
-             break;
 
-           case 34:
 
-             numberOfRepeats = reader.readBits(7) + 11;
 
-             repeatedLength = 0;
 
-             break;
 
-           default:
 
-             throw new Jbig2Error("invalid code length in symbol ID table");
 
-         }
 
-         for (j = 0; j < numberOfRepeats; j++) {
 
-           codes.push(new HuffmanLine([i, repeatedLength, 0, 0]));
 
-           i++;
 
-         }
 
-       } else {
 
-         codes.push(new HuffmanLine([i, codeLength, 0, 0]));
 
-         i++;
 
-       }
 
-     }
 
-     reader.byteAlign();
 
-     const symbolIDTable = new HuffmanTable(codes, false);
 
-     let customIndex = 0,
 
-         tableFirstS,
 
-         tableDeltaS,
 
-         tableDeltaT;
 
-     switch (textRegion.huffmanFS) {
 
-       case 0:
 
-       case 1:
 
-         tableFirstS = getStandardTable(textRegion.huffmanFS + 6);
 
-         break;
 
-       case 3:
 
-         tableFirstS = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-         customIndex++;
 
-         break;
 
-       default:
 
-         throw new Jbig2Error("invalid Huffman FS selector");
 
-     }
 
-     switch (textRegion.huffmanDS) {
 
-       case 0:
 
-       case 1:
 
-       case 2:
 
-         tableDeltaS = getStandardTable(textRegion.huffmanDS + 8);
 
-         break;
 
-       case 3:
 
-         tableDeltaS = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-         customIndex++;
 
-         break;
 
-       default:
 
-         throw new Jbig2Error("invalid Huffman DS selector");
 
-     }
 
-     switch (textRegion.huffmanDT) {
 
-       case 0:
 
-       case 1:
 
-       case 2:
 
-         tableDeltaT = getStandardTable(textRegion.huffmanDT + 11);
 
-         break;
 
-       case 3:
 
-         tableDeltaT = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-         customIndex++;
 
-         break;
 
-       default:
 
-         throw new Jbig2Error("invalid Huffman DT selector");
 
-     }
 
-     if (textRegion.refinement) {
 
-       throw new Jbig2Error("refinement with Huffman is not supported");
 
-     }
 
-     return {
 
-       symbolIDTable,
 
-       tableFirstS,
 
-       tableDeltaS,
 
-       tableDeltaT
 
-     };
 
-   }
 
-   function getSymbolDictionaryHuffmanTables(dictionary, referredTo, customTables) {
 
-     let customIndex = 0,
 
-         tableDeltaHeight,
 
-         tableDeltaWidth;
 
-     switch (dictionary.huffmanDHSelector) {
 
-       case 0:
 
-       case 1:
 
-         tableDeltaHeight = getStandardTable(dictionary.huffmanDHSelector + 4);
 
-         break;
 
-       case 3:
 
-         tableDeltaHeight = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-         customIndex++;
 
-         break;
 
-       default:
 
-         throw new Jbig2Error("invalid Huffman DH selector");
 
-     }
 
-     switch (dictionary.huffmanDWSelector) {
 
-       case 0:
 
-       case 1:
 
-         tableDeltaWidth = getStandardTable(dictionary.huffmanDWSelector + 2);
 
-         break;
 
-       case 3:
 
-         tableDeltaWidth = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-         customIndex++;
 
-         break;
 
-       default:
 
-         throw new Jbig2Error("invalid Huffman DW selector");
 
-     }
 
-     let tableBitmapSize, tableAggregateInstances;
 
-     if (dictionary.bitmapSizeSelector) {
 
-       tableBitmapSize = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-       customIndex++;
 
-     } else {
 
-       tableBitmapSize = getStandardTable(1);
 
-     }
 
-     if (dictionary.aggregationInstancesSelector) {
 
-       tableAggregateInstances = getCustomHuffmanTable(customIndex, referredTo, customTables);
 
-     } else {
 
-       tableAggregateInstances = getStandardTable(1);
 
-     }
 
-     return {
 
-       tableDeltaHeight,
 
-       tableDeltaWidth,
 
-       tableBitmapSize,
 
-       tableAggregateInstances
 
-     };
 
-   }
 
-   function readUncompressedBitmap(reader, width, height) {
 
-     const bitmap = [];
 
-     for (let y = 0; y < height; y++) {
 
-       const row = new Uint8Array(width);
 
-       bitmap.push(row);
 
-       for (let x = 0; x < width; x++) {
 
-         row[x] = reader.readBit();
 
-       }
 
-       reader.byteAlign();
 
-     }
 
-     return bitmap;
 
-   }
 
-   function decodeMMRBitmap(input, width, height, endOfBlock) {
 
-     const params = {
 
-       K: -1,
 
-       Columns: width,
 
-       Rows: height,
 
-       BlackIs1: true,
 
-       EndOfBlock: endOfBlock
 
-     };
 
-     const decoder = new _ccitt.CCITTFaxDecoder(input, params);
 
-     const bitmap = [];
 
-     let currentByte,
 
-         eof = false;
 
-     for (let y = 0; y < height; y++) {
 
-       const row = new Uint8Array(width);
 
-       bitmap.push(row);
 
-       let shift = -1;
 
-       for (let x = 0; x < width; x++) {
 
-         if (shift < 0) {
 
-           currentByte = decoder.readNextChar();
 
-           if (currentByte === -1) {
 
-             currentByte = 0;
 
-             eof = true;
 
-           }
 
-           shift = 7;
 
-         }
 
-         row[x] = currentByte >> shift & 1;
 
-         shift--;
 
-       }
 
-     }
 
-     if (endOfBlock && !eof) {
 
-       const lookForEOFLimit = 5;
 
-       for (let i = 0; i < lookForEOFLimit; i++) {
 
-         if (decoder.readNextChar() === -1) {
 
-           break;
 
-         }
 
-       }
 
-     }
 
-     return bitmap;
 
-   }
 
-   function Jbig2Image() {}
 
-   Jbig2Image.prototype = {
 
-     parseChunks(chunks) {
 
-       return parseJbig2Chunks(chunks);
 
-     },
 
-     parse(data) {
 
-       const {
 
-         imgData,
 
-         width,
 
-         height
 
-       } = parseJbig2(data);
 
-       this.width = width;
 
-       this.height = height;
 
-       return imgData;
 
-     }
 
-   };
 
-   return Jbig2Image;
 
- }();
 
- exports.Jbig2Image = Jbig2Image;
 
- /***/ }),
 
- /* 16 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.ArithmeticDecoder = void 0;
 
- const QeTable = [{
 
-   qe: 0x5601,
 
-   nmps: 1,
 
-   nlps: 1,
 
-   switchFlag: 1
 
- }, {
 
-   qe: 0x3401,
 
-   nmps: 2,
 
-   nlps: 6,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1801,
 
-   nmps: 3,
 
-   nlps: 9,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0ac1,
 
-   nmps: 4,
 
-   nlps: 12,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0521,
 
-   nmps: 5,
 
-   nlps: 29,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0221,
 
-   nmps: 38,
 
-   nlps: 33,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x5601,
 
-   nmps: 7,
 
-   nlps: 6,
 
-   switchFlag: 1
 
- }, {
 
-   qe: 0x5401,
 
-   nmps: 8,
 
-   nlps: 14,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x4801,
 
-   nmps: 9,
 
-   nlps: 14,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x3801,
 
-   nmps: 10,
 
-   nlps: 14,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x3001,
 
-   nmps: 11,
 
-   nlps: 17,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x2401,
 
-   nmps: 12,
 
-   nlps: 18,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1c01,
 
-   nmps: 13,
 
-   nlps: 20,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1601,
 
-   nmps: 29,
 
-   nlps: 21,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x5601,
 
-   nmps: 15,
 
-   nlps: 14,
 
-   switchFlag: 1
 
- }, {
 
-   qe: 0x5401,
 
-   nmps: 16,
 
-   nlps: 14,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x5101,
 
-   nmps: 17,
 
-   nlps: 15,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x4801,
 
-   nmps: 18,
 
-   nlps: 16,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x3801,
 
-   nmps: 19,
 
-   nlps: 17,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x3401,
 
-   nmps: 20,
 
-   nlps: 18,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x3001,
 
-   nmps: 21,
 
-   nlps: 19,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x2801,
 
-   nmps: 22,
 
-   nlps: 19,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x2401,
 
-   nmps: 23,
 
-   nlps: 20,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x2201,
 
-   nmps: 24,
 
-   nlps: 21,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1c01,
 
-   nmps: 25,
 
-   nlps: 22,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1801,
 
-   nmps: 26,
 
-   nlps: 23,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1601,
 
-   nmps: 27,
 
-   nlps: 24,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1401,
 
-   nmps: 28,
 
-   nlps: 25,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1201,
 
-   nmps: 29,
 
-   nlps: 26,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x1101,
 
-   nmps: 30,
 
-   nlps: 27,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0ac1,
 
-   nmps: 31,
 
-   nlps: 28,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x09c1,
 
-   nmps: 32,
 
-   nlps: 29,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x08a1,
 
-   nmps: 33,
 
-   nlps: 30,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0521,
 
-   nmps: 34,
 
-   nlps: 31,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0441,
 
-   nmps: 35,
 
-   nlps: 32,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x02a1,
 
-   nmps: 36,
 
-   nlps: 33,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0221,
 
-   nmps: 37,
 
-   nlps: 34,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0141,
 
-   nmps: 38,
 
-   nlps: 35,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0111,
 
-   nmps: 39,
 
-   nlps: 36,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0085,
 
-   nmps: 40,
 
-   nlps: 37,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0049,
 
-   nmps: 41,
 
-   nlps: 38,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0025,
 
-   nmps: 42,
 
-   nlps: 39,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0015,
 
-   nmps: 43,
 
-   nlps: 40,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0009,
 
-   nmps: 44,
 
-   nlps: 41,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0005,
 
-   nmps: 45,
 
-   nlps: 42,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x0001,
 
-   nmps: 45,
 
-   nlps: 43,
 
-   switchFlag: 0
 
- }, {
 
-   qe: 0x5601,
 
-   nmps: 46,
 
-   nlps: 46,
 
-   switchFlag: 0
 
- }];
 
- class ArithmeticDecoder {
 
-   constructor(data, start, end) {
 
-     this.data = data;
 
-     this.bp = start;
 
-     this.dataEnd = end;
 
-     this.chigh = data[start];
 
-     this.clow = 0;
 
-     this.byteIn();
 
-     this.chigh = this.chigh << 7 & 0xffff | this.clow >> 9 & 0x7f;
 
-     this.clow = this.clow << 7 & 0xffff;
 
-     this.ct -= 7;
 
-     this.a = 0x8000;
 
-   }
 
-   byteIn() {
 
-     const data = this.data;
 
-     let bp = this.bp;
 
-     if (data[bp] === 0xff) {
 
-       if (data[bp + 1] > 0x8f) {
 
-         this.clow += 0xff00;
 
-         this.ct = 8;
 
-       } else {
 
-         bp++;
 
-         this.clow += data[bp] << 9;
 
-         this.ct = 7;
 
-         this.bp = bp;
 
-       }
 
-     } else {
 
-       bp++;
 
-       this.clow += bp < this.dataEnd ? data[bp] << 8 : 0xff00;
 
-       this.ct = 8;
 
-       this.bp = bp;
 
-     }
 
-     if (this.clow > 0xffff) {
 
-       this.chigh += this.clow >> 16;
 
-       this.clow &= 0xffff;
 
-     }
 
-   }
 
-   readBit(contexts, pos) {
 
-     let cx_index = contexts[pos] >> 1,
 
-         cx_mps = contexts[pos] & 1;
 
-     const qeTableIcx = QeTable[cx_index];
 
-     const qeIcx = qeTableIcx.qe;
 
-     let d;
 
-     let a = this.a - qeIcx;
 
-     if (this.chigh < qeIcx) {
 
-       if (a < qeIcx) {
 
-         a = qeIcx;
 
-         d = cx_mps;
 
-         cx_index = qeTableIcx.nmps;
 
-       } else {
 
-         a = qeIcx;
 
-         d = 1 ^ cx_mps;
 
-         if (qeTableIcx.switchFlag === 1) {
 
-           cx_mps = d;
 
-         }
 
-         cx_index = qeTableIcx.nlps;
 
-       }
 
-     } else {
 
-       this.chigh -= qeIcx;
 
-       if ((a & 0x8000) !== 0) {
 
-         this.a = a;
 
-         return cx_mps;
 
-       }
 
-       if (a < qeIcx) {
 
-         d = 1 ^ cx_mps;
 
-         if (qeTableIcx.switchFlag === 1) {
 
-           cx_mps = d;
 
-         }
 
-         cx_index = qeTableIcx.nlps;
 
-       } else {
 
-         d = cx_mps;
 
-         cx_index = qeTableIcx.nmps;
 
-       }
 
-     }
 
-     do {
 
-       if (this.ct === 0) {
 
-         this.byteIn();
 
-       }
 
-       a <<= 1;
 
-       this.chigh = this.chigh << 1 & 0xffff | this.clow >> 15 & 1;
 
-       this.clow = this.clow << 1 & 0xffff;
 
-       this.ct--;
 
-     } while ((a & 0x8000) === 0);
 
-     this.a = a;
 
-     contexts[pos] = cx_index << 1 | cx_mps;
 
-     return d;
 
-   }
 
- }
 
- exports.ArithmeticDecoder = ArithmeticDecoder;
 
- /***/ }),
 
- /* 17 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.JpegStream = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _jpg = __w_pdfjs_require__(18);
 
- const JpegStream = function JpegStreamClosure() {
 
-   function JpegStream(stream, maybeLength, dict, params) {
 
-     let ch;
 
-     while ((ch = stream.getByte()) !== -1) {
 
-       if (ch === 0xff) {
 
-         stream.skip(-1);
 
-         break;
 
-       }
 
-     }
 
-     this.stream = stream;
 
-     this.maybeLength = maybeLength;
 
-     this.dict = dict;
 
-     this.params = params;
 
-     _stream.DecodeStream.call(this, maybeLength);
 
-   }
 
-   JpegStream.prototype = Object.create(_stream.DecodeStream.prototype);
 
-   Object.defineProperty(JpegStream.prototype, "bytes", {
 
-     get: function JpegStream_bytes() {
 
-       return (0, _util.shadow)(this, "bytes", this.stream.getBytes(this.maybeLength));
 
-     },
 
-     configurable: true
 
-   });
 
-   JpegStream.prototype.ensureBuffer = function (requested) {};
 
-   JpegStream.prototype.readBlock = function () {
 
-     if (this.eof) {
 
-       return;
 
-     }
 
-     const jpegOptions = {
 
-       decodeTransform: undefined,
 
-       colorTransform: undefined
 
-     };
 
-     const decodeArr = this.dict.getArray("Decode", "D");
 
-     if (this.forceRGB && Array.isArray(decodeArr)) {
 
-       const bitsPerComponent = this.dict.get("BitsPerComponent") || 8;
 
-       const decodeArrLength = decodeArr.length;
 
-       const transform = new Int32Array(decodeArrLength);
 
-       let transformNeeded = false;
 
-       const maxValue = (1 << bitsPerComponent) - 1;
 
-       for (let i = 0; i < decodeArrLength; i += 2) {
 
-         transform[i] = (decodeArr[i + 1] - decodeArr[i]) * 256 | 0;
 
-         transform[i + 1] = decodeArr[i] * maxValue | 0;
 
-         if (transform[i] !== 256 || transform[i + 1] !== 0) {
 
-           transformNeeded = true;
 
-         }
 
-       }
 
-       if (transformNeeded) {
 
-         jpegOptions.decodeTransform = transform;
 
-       }
 
-     }
 
-     if ((0, _primitives.isDict)(this.params)) {
 
-       const colorTransform = this.params.get("ColorTransform");
 
-       if (Number.isInteger(colorTransform)) {
 
-         jpegOptions.colorTransform = colorTransform;
 
-       }
 
-     }
 
-     const jpegImage = new _jpg.JpegImage(jpegOptions);
 
-     jpegImage.parse(this.bytes);
 
-     const data = jpegImage.getData({
 
-       width: this.drawWidth,
 
-       height: this.drawHeight,
 
-       forceRGB: this.forceRGB,
 
-       isSourcePDF: true
 
-     });
 
-     this.buffer = data;
 
-     this.bufferLength = data.length;
 
-     this.eof = true;
 
-   };
 
-   Object.defineProperty(JpegStream.prototype, "maybeValidDimensions", {
 
-     get: function JpegStream_maybeValidDimensions() {
 
-       const {
 
-         dict,
 
-         stream
 
-       } = this;
 
-       const dictHeight = dict.get("Height", "H");
 
-       const startPos = stream.pos;
 
-       let validDimensions = true,
 
-           foundSOF = false,
 
-           b;
 
-       while ((b = stream.getByte()) !== -1) {
 
-         if (b !== 0xff) {
 
-           continue;
 
-         }
 
-         switch (stream.getByte()) {
 
-           case 0xc0:
 
-           case 0xc1:
 
-           case 0xc2:
 
-             foundSOF = true;
 
-             stream.pos += 2;
 
-             stream.pos += 1;
 
-             const scanLines = stream.getUint16();
 
-             if (scanLines === dictHeight) {
 
-               break;
 
-             }
 
-             if (scanLines === 0) {
 
-               validDimensions = false;
 
-               break;
 
-             }
 
-             if (scanLines > dictHeight * 10) {
 
-               validDimensions = false;
 
-               break;
 
-             }
 
-             break;
 
-           case 0xc3:
 
-           case 0xc5:
 
-           case 0xc6:
 
-           case 0xc7:
 
-           case 0xc9:
 
-           case 0xca:
 
-           case 0xcb:
 
-           case 0xcd:
 
-           case 0xce:
 
-           case 0xcf:
 
-             foundSOF = true;
 
-             break;
 
-           case 0xc4:
 
-           case 0xcc:
 
-           case 0xda:
 
-           case 0xdb:
 
-           case 0xdc:
 
-           case 0xdd:
 
-           case 0xde:
 
-           case 0xdf:
 
-           case 0xe0:
 
-           case 0xe1:
 
-           case 0xe2:
 
-           case 0xe3:
 
-           case 0xe4:
 
-           case 0xe5:
 
-           case 0xe6:
 
-           case 0xe7:
 
-           case 0xe8:
 
-           case 0xe9:
 
-           case 0xea:
 
-           case 0xeb:
 
-           case 0xec:
 
-           case 0xed:
 
-           case 0xee:
 
-           case 0xef:
 
-           case 0xfe:
 
-             const markerLength = stream.getUint16();
 
-             if (markerLength > 2) {
 
-               stream.skip(markerLength - 2);
 
-             } else {
 
-               stream.skip(-2);
 
-             }
 
-             break;
 
-           case 0xff:
 
-             stream.skip(-1);
 
-             break;
 
-           case 0xd9:
 
-             foundSOF = true;
 
-             break;
 
-         }
 
-         if (foundSOF) {
 
-           break;
 
-         }
 
-       }
 
-       stream.pos = startPos;
 
-       return (0, _util.shadow)(this, "maybeValidDimensions", validDimensions);
 
-     },
 
-     configurable: true
 
-   });
 
-   JpegStream.prototype.getIR = function (forceDataSchema = false) {
 
-     return (0, _util.createObjectURL)(this.bytes, "image/jpeg", forceDataSchema);
 
-   };
 
-   return JpegStream;
 
- }();
 
- exports.JpegStream = JpegStream;
 
- /***/ }),
 
- /* 18 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.JpegImage = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- class JpegError extends _util.BaseException {
 
-   constructor(msg) {
 
-     super(`JPEG error: ${msg}`);
 
-   }
 
- }
 
- class DNLMarkerError extends _util.BaseException {
 
-   constructor(message, scanLines) {
 
-     super(message);
 
-     this.scanLines = scanLines;
 
-   }
 
- }
 
- class EOIMarkerError extends _util.BaseException {}
 
- var JpegImage = function JpegImageClosure() {
 
-   var dctZigZag = new Uint8Array([0, 1, 8, 16, 9, 2, 3, 10, 17, 24, 32, 25, 18, 11, 4, 5, 12, 19, 26, 33, 40, 48, 41, 34, 27, 20, 13, 6, 7, 14, 21, 28, 35, 42, 49, 56, 57, 50, 43, 36, 29, 22, 15, 23, 30, 37, 44, 51, 58, 59, 52, 45, 38, 31, 39, 46, 53, 60, 61, 54, 47, 55, 62, 63]);
 
-   var dctCos1 = 4017;
 
-   var dctSin1 = 799;
 
-   var dctCos3 = 3406;
 
-   var dctSin3 = 2276;
 
-   var dctCos6 = 1567;
 
-   var dctSin6 = 3784;
 
-   var dctSqrt2 = 5793;
 
-   var dctSqrt1d2 = 2896;
 
-   function JpegImage({
 
-     decodeTransform = null,
 
-     colorTransform = -1
 
-   } = {}) {
 
-     this._decodeTransform = decodeTransform;
 
-     this._colorTransform = colorTransform;
 
-   }
 
-   function buildHuffmanTable(codeLengths, values) {
 
-     var k = 0,
 
-         code = [],
 
-         i,
 
-         j,
 
-         length = 16;
 
-     while (length > 0 && !codeLengths[length - 1]) {
 
-       length--;
 
-     }
 
-     code.push({
 
-       children: [],
 
-       index: 0
 
-     });
 
-     var p = code[0],
 
-         q;
 
-     for (i = 0; i < length; i++) {
 
-       for (j = 0; j < codeLengths[i]; j++) {
 
-         p = code.pop();
 
-         p.children[p.index] = values[k];
 
-         while (p.index > 0) {
 
-           p = code.pop();
 
-         }
 
-         p.index++;
 
-         code.push(p);
 
-         while (code.length <= i) {
 
-           code.push(q = {
 
-             children: [],
 
-             index: 0
 
-           });
 
-           p.children[p.index] = q.children;
 
-           p = q;
 
-         }
 
-         k++;
 
-       }
 
-       if (i + 1 < length) {
 
-         code.push(q = {
 
-           children: [],
 
-           index: 0
 
-         });
 
-         p.children[p.index] = q.children;
 
-         p = q;
 
-       }
 
-     }
 
-     return code[0].children;
 
-   }
 
-   function getBlockBufferOffset(component, row, col) {
 
-     return 64 * ((component.blocksPerLine + 1) * row + col);
 
-   }
 
-   function decodeScan(data, offset, frame, components, resetInterval, spectralStart, spectralEnd, successivePrev, successive, parseDNLMarker = false) {
 
-     var mcusPerLine = frame.mcusPerLine;
 
-     var progressive = frame.progressive;
 
-     var startOffset = offset,
 
-         bitsData = 0,
 
-         bitsCount = 0;
 
-     function readBit() {
 
-       if (bitsCount > 0) {
 
-         bitsCount--;
 
-         return bitsData >> bitsCount & 1;
 
-       }
 
-       bitsData = data[offset++];
 
-       if (bitsData === 0xff) {
 
-         var nextByte = data[offset++];
 
-         if (nextByte) {
 
-           if (nextByte === 0xdc && parseDNLMarker) {
 
-             offset += 2;
 
-             const scanLines = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             if (scanLines > 0 && scanLines !== frame.scanLines) {
 
-               throw new DNLMarkerError("Found DNL marker (0xFFDC) while parsing scan data", scanLines);
 
-             }
 
-           } else if (nextByte === 0xd9) {
 
-             if (parseDNLMarker) {
 
-               const maybeScanLines = blockRow * 8;
 
-               if (maybeScanLines > 0 && maybeScanLines < frame.scanLines / 10) {
 
-                 throw new DNLMarkerError("Found EOI marker (0xFFD9) while parsing scan data, " + "possibly caused by incorrect `scanLines` parameter", maybeScanLines);
 
-               }
 
-             }
 
-             throw new EOIMarkerError("Found EOI marker (0xFFD9) while parsing scan data");
 
-           }
 
-           throw new JpegError(`unexpected marker ${(bitsData << 8 | nextByte).toString(16)}`);
 
-         }
 
-       }
 
-       bitsCount = 7;
 
-       return bitsData >>> 7;
 
-     }
 
-     function decodeHuffman(tree) {
 
-       var node = tree;
 
-       while (true) {
 
-         node = node[readBit()];
 
-         switch (typeof node) {
 
-           case "number":
 
-             return node;
 
-           case "object":
 
-             continue;
 
-         }
 
-         throw new JpegError("invalid huffman sequence");
 
-       }
 
-     }
 
-     function receive(length) {
 
-       var n = 0;
 
-       while (length > 0) {
 
-         n = n << 1 | readBit();
 
-         length--;
 
-       }
 
-       return n;
 
-     }
 
-     function receiveAndExtend(length) {
 
-       if (length === 1) {
 
-         return readBit() === 1 ? 1 : -1;
 
-       }
 
-       var n = receive(length);
 
-       if (n >= 1 << length - 1) {
 
-         return n;
 
-       }
 
-       return n + (-1 << length) + 1;
 
-     }
 
-     function decodeBaseline(component, offset) {
 
-       var t = decodeHuffman(component.huffmanTableDC);
 
-       var diff = t === 0 ? 0 : receiveAndExtend(t);
 
-       component.blockData[offset] = component.pred += diff;
 
-       var k = 1;
 
-       while (k < 64) {
 
-         var rs = decodeHuffman(component.huffmanTableAC);
 
-         var s = rs & 15,
 
-             r = rs >> 4;
 
-         if (s === 0) {
 
-           if (r < 15) {
 
-             break;
 
-           }
 
-           k += 16;
 
-           continue;
 
-         }
 
-         k += r;
 
-         var z = dctZigZag[k];
 
-         component.blockData[offset + z] = receiveAndExtend(s);
 
-         k++;
 
-       }
 
-     }
 
-     function decodeDCFirst(component, offset) {
 
-       var t = decodeHuffman(component.huffmanTableDC);
 
-       var diff = t === 0 ? 0 : receiveAndExtend(t) << successive;
 
-       component.blockData[offset] = component.pred += diff;
 
-     }
 
-     function decodeDCSuccessive(component, offset) {
 
-       component.blockData[offset] |= readBit() << successive;
 
-     }
 
-     var eobrun = 0;
 
-     function decodeACFirst(component, offset) {
 
-       if (eobrun > 0) {
 
-         eobrun--;
 
-         return;
 
-       }
 
-       var k = spectralStart,
 
-           e = spectralEnd;
 
-       while (k <= e) {
 
-         var rs = decodeHuffman(component.huffmanTableAC);
 
-         var s = rs & 15,
 
-             r = rs >> 4;
 
-         if (s === 0) {
 
-           if (r < 15) {
 
-             eobrun = receive(r) + (1 << r) - 1;
 
-             break;
 
-           }
 
-           k += 16;
 
-           continue;
 
-         }
 
-         k += r;
 
-         var z = dctZigZag[k];
 
-         component.blockData[offset + z] = receiveAndExtend(s) * (1 << successive);
 
-         k++;
 
-       }
 
-     }
 
-     var successiveACState = 0,
 
-         successiveACNextValue;
 
-     function decodeACSuccessive(component, offset) {
 
-       var k = spectralStart;
 
-       var e = spectralEnd;
 
-       var r = 0;
 
-       var s;
 
-       var rs;
 
-       while (k <= e) {
 
-         const offsetZ = offset + dctZigZag[k];
 
-         const sign = component.blockData[offsetZ] < 0 ? -1 : 1;
 
-         switch (successiveACState) {
 
-           case 0:
 
-             rs = decodeHuffman(component.huffmanTableAC);
 
-             s = rs & 15;
 
-             r = rs >> 4;
 
-             if (s === 0) {
 
-               if (r < 15) {
 
-                 eobrun = receive(r) + (1 << r);
 
-                 successiveACState = 4;
 
-               } else {
 
-                 r = 16;
 
-                 successiveACState = 1;
 
-               }
 
-             } else {
 
-               if (s !== 1) {
 
-                 throw new JpegError("invalid ACn encoding");
 
-               }
 
-               successiveACNextValue = receiveAndExtend(s);
 
-               successiveACState = r ? 2 : 3;
 
-             }
 
-             continue;
 
-           case 1:
 
-           case 2:
 
-             if (component.blockData[offsetZ]) {
 
-               component.blockData[offsetZ] += sign * (readBit() << successive);
 
-             } else {
 
-               r--;
 
-               if (r === 0) {
 
-                 successiveACState = successiveACState === 2 ? 3 : 0;
 
-               }
 
-             }
 
-             break;
 
-           case 3:
 
-             if (component.blockData[offsetZ]) {
 
-               component.blockData[offsetZ] += sign * (readBit() << successive);
 
-             } else {
 
-               component.blockData[offsetZ] = successiveACNextValue << successive;
 
-               successiveACState = 0;
 
-             }
 
-             break;
 
-           case 4:
 
-             if (component.blockData[offsetZ]) {
 
-               component.blockData[offsetZ] += sign * (readBit() << successive);
 
-             }
 
-             break;
 
-         }
 
-         k++;
 
-       }
 
-       if (successiveACState === 4) {
 
-         eobrun--;
 
-         if (eobrun === 0) {
 
-           successiveACState = 0;
 
-         }
 
-       }
 
-     }
 
-     let blockRow = 0;
 
-     function decodeMcu(component, decode, mcu, row, col) {
 
-       var mcuRow = mcu / mcusPerLine | 0;
 
-       var mcuCol = mcu % mcusPerLine;
 
-       blockRow = mcuRow * component.v + row;
 
-       var blockCol = mcuCol * component.h + col;
 
-       var offset = getBlockBufferOffset(component, blockRow, blockCol);
 
-       decode(component, offset);
 
-     }
 
-     function decodeBlock(component, decode, mcu) {
 
-       blockRow = mcu / component.blocksPerLine | 0;
 
-       var blockCol = mcu % component.blocksPerLine;
 
-       var offset = getBlockBufferOffset(component, blockRow, blockCol);
 
-       decode(component, offset);
 
-     }
 
-     var componentsLength = components.length;
 
-     var component, i, j, k, n;
 
-     var decodeFn;
 
-     if (progressive) {
 
-       if (spectralStart === 0) {
 
-         decodeFn = successivePrev === 0 ? decodeDCFirst : decodeDCSuccessive;
 
-       } else {
 
-         decodeFn = successivePrev === 0 ? decodeACFirst : decodeACSuccessive;
 
-       }
 
-     } else {
 
-       decodeFn = decodeBaseline;
 
-     }
 
-     var mcu = 0,
 
-         fileMarker;
 
-     var mcuExpected;
 
-     if (componentsLength === 1) {
 
-       mcuExpected = components[0].blocksPerLine * components[0].blocksPerColumn;
 
-     } else {
 
-       mcuExpected = mcusPerLine * frame.mcusPerColumn;
 
-     }
 
-     var h, v;
 
-     while (mcu < mcuExpected) {
 
-       var mcuToRead = resetInterval ? Math.min(mcuExpected - mcu, resetInterval) : mcuExpected;
 
-       for (i = 0; i < componentsLength; i++) {
 
-         components[i].pred = 0;
 
-       }
 
-       eobrun = 0;
 
-       if (componentsLength === 1) {
 
-         component = components[0];
 
-         for (n = 0; n < mcuToRead; n++) {
 
-           decodeBlock(component, decodeFn, mcu);
 
-           mcu++;
 
-         }
 
-       } else {
 
-         for (n = 0; n < mcuToRead; n++) {
 
-           for (i = 0; i < componentsLength; i++) {
 
-             component = components[i];
 
-             h = component.h;
 
-             v = component.v;
 
-             for (j = 0; j < v; j++) {
 
-               for (k = 0; k < h; k++) {
 
-                 decodeMcu(component, decodeFn, mcu, j, k);
 
-               }
 
-             }
 
-           }
 
-           mcu++;
 
-         }
 
-       }
 
-       bitsCount = 0;
 
-       fileMarker = findNextFileMarker(data, offset);
 
-       if (!fileMarker) {
 
-         break;
 
-       } else if (fileMarker.invalid) {
 
-         (0, _util.warn)("decodeScan - unexpected MCU data, current marker is: " + fileMarker.invalid);
 
-         offset = fileMarker.offset;
 
-       }
 
-       var marker = fileMarker && fileMarker.marker;
 
-       if (!marker || marker <= 0xff00) {
 
-         throw new JpegError("decodeScan - a valid marker was not found.");
 
-       }
 
-       if (marker >= 0xffd0 && marker <= 0xffd7) {
 
-         offset += 2;
 
-       } else {
 
-         break;
 
-       }
 
-     }
 
-     fileMarker = findNextFileMarker(data, offset);
 
-     if (fileMarker && fileMarker.invalid) {
 
-       (0, _util.warn)("decodeScan - unexpected Scan data, current marker is: " + fileMarker.invalid);
 
-       offset = fileMarker.offset;
 
-     }
 
-     return offset - startOffset;
 
-   }
 
-   function quantizeAndInverse(component, blockBufferOffset, p) {
 
-     var qt = component.quantizationTable,
 
-         blockData = component.blockData;
 
-     var v0, v1, v2, v3, v4, v5, v6, v7;
 
-     var p0, p1, p2, p3, p4, p5, p6, p7;
 
-     var t;
 
-     if (!qt) {
 
-       throw new JpegError("missing required Quantization Table.");
 
-     }
 
-     for (var row = 0; row < 64; row += 8) {
 
-       p0 = blockData[blockBufferOffset + row];
 
-       p1 = blockData[blockBufferOffset + row + 1];
 
-       p2 = blockData[blockBufferOffset + row + 2];
 
-       p3 = blockData[blockBufferOffset + row + 3];
 
-       p4 = blockData[blockBufferOffset + row + 4];
 
-       p5 = blockData[blockBufferOffset + row + 5];
 
-       p6 = blockData[blockBufferOffset + row + 6];
 
-       p7 = blockData[blockBufferOffset + row + 7];
 
-       p0 *= qt[row];
 
-       if ((p1 | p2 | p3 | p4 | p5 | p6 | p7) === 0) {
 
-         t = dctSqrt2 * p0 + 512 >> 10;
 
-         p[row] = t;
 
-         p[row + 1] = t;
 
-         p[row + 2] = t;
 
-         p[row + 3] = t;
 
-         p[row + 4] = t;
 
-         p[row + 5] = t;
 
-         p[row + 6] = t;
 
-         p[row + 7] = t;
 
-         continue;
 
-       }
 
-       p1 *= qt[row + 1];
 
-       p2 *= qt[row + 2];
 
-       p3 *= qt[row + 3];
 
-       p4 *= qt[row + 4];
 
-       p5 *= qt[row + 5];
 
-       p6 *= qt[row + 6];
 
-       p7 *= qt[row + 7];
 
-       v0 = dctSqrt2 * p0 + 128 >> 8;
 
-       v1 = dctSqrt2 * p4 + 128 >> 8;
 
-       v2 = p2;
 
-       v3 = p6;
 
-       v4 = dctSqrt1d2 * (p1 - p7) + 128 >> 8;
 
-       v7 = dctSqrt1d2 * (p1 + p7) + 128 >> 8;
 
-       v5 = p3 << 4;
 
-       v6 = p5 << 4;
 
-       v0 = v0 + v1 + 1 >> 1;
 
-       v1 = v0 - v1;
 
-       t = v2 * dctSin6 + v3 * dctCos6 + 128 >> 8;
 
-       v2 = v2 * dctCos6 - v3 * dctSin6 + 128 >> 8;
 
-       v3 = t;
 
-       v4 = v4 + v6 + 1 >> 1;
 
-       v6 = v4 - v6;
 
-       v7 = v7 + v5 + 1 >> 1;
 
-       v5 = v7 - v5;
 
-       v0 = v0 + v3 + 1 >> 1;
 
-       v3 = v0 - v3;
 
-       v1 = v1 + v2 + 1 >> 1;
 
-       v2 = v1 - v2;
 
-       t = v4 * dctSin3 + v7 * dctCos3 + 2048 >> 12;
 
-       v4 = v4 * dctCos3 - v7 * dctSin3 + 2048 >> 12;
 
-       v7 = t;
 
-       t = v5 * dctSin1 + v6 * dctCos1 + 2048 >> 12;
 
-       v5 = v5 * dctCos1 - v6 * dctSin1 + 2048 >> 12;
 
-       v6 = t;
 
-       p[row] = v0 + v7;
 
-       p[row + 7] = v0 - v7;
 
-       p[row + 1] = v1 + v6;
 
-       p[row + 6] = v1 - v6;
 
-       p[row + 2] = v2 + v5;
 
-       p[row + 5] = v2 - v5;
 
-       p[row + 3] = v3 + v4;
 
-       p[row + 4] = v3 - v4;
 
-     }
 
-     for (var col = 0; col < 8; ++col) {
 
-       p0 = p[col];
 
-       p1 = p[col + 8];
 
-       p2 = p[col + 16];
 
-       p3 = p[col + 24];
 
-       p4 = p[col + 32];
 
-       p5 = p[col + 40];
 
-       p6 = p[col + 48];
 
-       p7 = p[col + 56];
 
-       if ((p1 | p2 | p3 | p4 | p5 | p6 | p7) === 0) {
 
-         t = dctSqrt2 * p0 + 8192 >> 14;
 
-         if (t < -2040) {
 
-           t = 0;
 
-         } else if (t >= 2024) {
 
-           t = 255;
 
-         } else {
 
-           t = t + 2056 >> 4;
 
-         }
 
-         blockData[blockBufferOffset + col] = t;
 
-         blockData[blockBufferOffset + col + 8] = t;
 
-         blockData[blockBufferOffset + col + 16] = t;
 
-         blockData[blockBufferOffset + col + 24] = t;
 
-         blockData[blockBufferOffset + col + 32] = t;
 
-         blockData[blockBufferOffset + col + 40] = t;
 
-         blockData[blockBufferOffset + col + 48] = t;
 
-         blockData[blockBufferOffset + col + 56] = t;
 
-         continue;
 
-       }
 
-       v0 = dctSqrt2 * p0 + 2048 >> 12;
 
-       v1 = dctSqrt2 * p4 + 2048 >> 12;
 
-       v2 = p2;
 
-       v3 = p6;
 
-       v4 = dctSqrt1d2 * (p1 - p7) + 2048 >> 12;
 
-       v7 = dctSqrt1d2 * (p1 + p7) + 2048 >> 12;
 
-       v5 = p3;
 
-       v6 = p5;
 
-       v0 = (v0 + v1 + 1 >> 1) + 4112;
 
-       v1 = v0 - v1;
 
-       t = v2 * dctSin6 + v3 * dctCos6 + 2048 >> 12;
 
-       v2 = v2 * dctCos6 - v3 * dctSin6 + 2048 >> 12;
 
-       v3 = t;
 
-       v4 = v4 + v6 + 1 >> 1;
 
-       v6 = v4 - v6;
 
-       v7 = v7 + v5 + 1 >> 1;
 
-       v5 = v7 - v5;
 
-       v0 = v0 + v3 + 1 >> 1;
 
-       v3 = v0 - v3;
 
-       v1 = v1 + v2 + 1 >> 1;
 
-       v2 = v1 - v2;
 
-       t = v4 * dctSin3 + v7 * dctCos3 + 2048 >> 12;
 
-       v4 = v4 * dctCos3 - v7 * dctSin3 + 2048 >> 12;
 
-       v7 = t;
 
-       t = v5 * dctSin1 + v6 * dctCos1 + 2048 >> 12;
 
-       v5 = v5 * dctCos1 - v6 * dctSin1 + 2048 >> 12;
 
-       v6 = t;
 
-       p0 = v0 + v7;
 
-       p7 = v0 - v7;
 
-       p1 = v1 + v6;
 
-       p6 = v1 - v6;
 
-       p2 = v2 + v5;
 
-       p5 = v2 - v5;
 
-       p3 = v3 + v4;
 
-       p4 = v3 - v4;
 
-       if (p0 < 16) {
 
-         p0 = 0;
 
-       } else if (p0 >= 4080) {
 
-         p0 = 255;
 
-       } else {
 
-         p0 >>= 4;
 
-       }
 
-       if (p1 < 16) {
 
-         p1 = 0;
 
-       } else if (p1 >= 4080) {
 
-         p1 = 255;
 
-       } else {
 
-         p1 >>= 4;
 
-       }
 
-       if (p2 < 16) {
 
-         p2 = 0;
 
-       } else if (p2 >= 4080) {
 
-         p2 = 255;
 
-       } else {
 
-         p2 >>= 4;
 
-       }
 
-       if (p3 < 16) {
 
-         p3 = 0;
 
-       } else if (p3 >= 4080) {
 
-         p3 = 255;
 
-       } else {
 
-         p3 >>= 4;
 
-       }
 
-       if (p4 < 16) {
 
-         p4 = 0;
 
-       } else if (p4 >= 4080) {
 
-         p4 = 255;
 
-       } else {
 
-         p4 >>= 4;
 
-       }
 
-       if (p5 < 16) {
 
-         p5 = 0;
 
-       } else if (p5 >= 4080) {
 
-         p5 = 255;
 
-       } else {
 
-         p5 >>= 4;
 
-       }
 
-       if (p6 < 16) {
 
-         p6 = 0;
 
-       } else if (p6 >= 4080) {
 
-         p6 = 255;
 
-       } else {
 
-         p6 >>= 4;
 
-       }
 
-       if (p7 < 16) {
 
-         p7 = 0;
 
-       } else if (p7 >= 4080) {
 
-         p7 = 255;
 
-       } else {
 
-         p7 >>= 4;
 
-       }
 
-       blockData[blockBufferOffset + col] = p0;
 
-       blockData[blockBufferOffset + col + 8] = p1;
 
-       blockData[blockBufferOffset + col + 16] = p2;
 
-       blockData[blockBufferOffset + col + 24] = p3;
 
-       blockData[blockBufferOffset + col + 32] = p4;
 
-       blockData[blockBufferOffset + col + 40] = p5;
 
-       blockData[blockBufferOffset + col + 48] = p6;
 
-       blockData[blockBufferOffset + col + 56] = p7;
 
-     }
 
-   }
 
-   function buildComponentData(frame, component) {
 
-     var blocksPerLine = component.blocksPerLine;
 
-     var blocksPerColumn = component.blocksPerColumn;
 
-     var computationBuffer = new Int16Array(64);
 
-     for (var blockRow = 0; blockRow < blocksPerColumn; blockRow++) {
 
-       for (var blockCol = 0; blockCol < blocksPerLine; blockCol++) {
 
-         var offset = getBlockBufferOffset(component, blockRow, blockCol);
 
-         quantizeAndInverse(component, offset, computationBuffer);
 
-       }
 
-     }
 
-     return component.blockData;
 
-   }
 
-   function findNextFileMarker(data, currentPos, startPos = currentPos) {
 
-     const maxPos = data.length - 1;
 
-     var newPos = startPos < currentPos ? startPos : currentPos;
 
-     if (currentPos >= maxPos) {
 
-       return null;
 
-     }
 
-     var currentMarker = (0, _core_utils.readUint16)(data, currentPos);
 
-     if (currentMarker >= 0xffc0 && currentMarker <= 0xfffe) {
 
-       return {
 
-         invalid: null,
 
-         marker: currentMarker,
 
-         offset: currentPos
 
-       };
 
-     }
 
-     var newMarker = (0, _core_utils.readUint16)(data, newPos);
 
-     while (!(newMarker >= 0xffc0 && newMarker <= 0xfffe)) {
 
-       if (++newPos >= maxPos) {
 
-         return null;
 
-       }
 
-       newMarker = (0, _core_utils.readUint16)(data, newPos);
 
-     }
 
-     return {
 
-       invalid: currentMarker.toString(16),
 
-       marker: newMarker,
 
-       offset: newPos
 
-     };
 
-   }
 
-   JpegImage.prototype = {
 
-     parse(data, {
 
-       dnlScanLines = null
 
-     } = {}) {
 
-       function readDataBlock() {
 
-         const length = (0, _core_utils.readUint16)(data, offset);
 
-         offset += 2;
 
-         let endOffset = offset + length - 2;
 
-         var fileMarker = findNextFileMarker(data, endOffset, offset);
 
-         if (fileMarker && fileMarker.invalid) {
 
-           (0, _util.warn)("readDataBlock - incorrect length, current marker is: " + fileMarker.invalid);
 
-           endOffset = fileMarker.offset;
 
-         }
 
-         var array = data.subarray(offset, endOffset);
 
-         offset += array.length;
 
-         return array;
 
-       }
 
-       function prepareComponents(frame) {
 
-         var mcusPerLine = Math.ceil(frame.samplesPerLine / 8 / frame.maxH);
 
-         var mcusPerColumn = Math.ceil(frame.scanLines / 8 / frame.maxV);
 
-         for (var i = 0; i < frame.components.length; i++) {
 
-           component = frame.components[i];
 
-           var blocksPerLine = Math.ceil(Math.ceil(frame.samplesPerLine / 8) * component.h / frame.maxH);
 
-           var blocksPerColumn = Math.ceil(Math.ceil(frame.scanLines / 8) * component.v / frame.maxV);
 
-           var blocksPerLineForMcu = mcusPerLine * component.h;
 
-           var blocksPerColumnForMcu = mcusPerColumn * component.v;
 
-           var blocksBufferSize = 64 * blocksPerColumnForMcu * (blocksPerLineForMcu + 1);
 
-           component.blockData = new Int16Array(blocksBufferSize);
 
-           component.blocksPerLine = blocksPerLine;
 
-           component.blocksPerColumn = blocksPerColumn;
 
-         }
 
-         frame.mcusPerLine = mcusPerLine;
 
-         frame.mcusPerColumn = mcusPerColumn;
 
-       }
 
-       var offset = 0;
 
-       var jfif = null;
 
-       var adobe = null;
 
-       var frame, resetInterval;
 
-       let numSOSMarkers = 0;
 
-       var quantizationTables = [];
 
-       var huffmanTablesAC = [],
 
-           huffmanTablesDC = [];
 
-       let fileMarker = (0, _core_utils.readUint16)(data, offset);
 
-       offset += 2;
 
-       if (fileMarker !== 0xffd8) {
 
-         throw new JpegError("SOI not found");
 
-       }
 
-       fileMarker = (0, _core_utils.readUint16)(data, offset);
 
-       offset += 2;
 
-       markerLoop: while (fileMarker !== 0xffd9) {
 
-         var i, j, l;
 
-         switch (fileMarker) {
 
-           case 0xffe0:
 
-           case 0xffe1:
 
-           case 0xffe2:
 
-           case 0xffe3:
 
-           case 0xffe4:
 
-           case 0xffe5:
 
-           case 0xffe6:
 
-           case 0xffe7:
 
-           case 0xffe8:
 
-           case 0xffe9:
 
-           case 0xffea:
 
-           case 0xffeb:
 
-           case 0xffec:
 
-           case 0xffed:
 
-           case 0xffee:
 
-           case 0xffef:
 
-           case 0xfffe:
 
-             var appData = readDataBlock();
 
-             if (fileMarker === 0xffe0) {
 
-               if (appData[0] === 0x4a && appData[1] === 0x46 && appData[2] === 0x49 && appData[3] === 0x46 && appData[4] === 0) {
 
-                 jfif = {
 
-                   version: {
 
-                     major: appData[5],
 
-                     minor: appData[6]
 
-                   },
 
-                   densityUnits: appData[7],
 
-                   xDensity: appData[8] << 8 | appData[9],
 
-                   yDensity: appData[10] << 8 | appData[11],
 
-                   thumbWidth: appData[12],
 
-                   thumbHeight: appData[13],
 
-                   thumbData: appData.subarray(14, 14 + 3 * appData[12] * appData[13])
 
-                 };
 
-               }
 
-             }
 
-             if (fileMarker === 0xffee) {
 
-               if (appData[0] === 0x41 && appData[1] === 0x64 && appData[2] === 0x6f && appData[3] === 0x62 && appData[4] === 0x65) {
 
-                 adobe = {
 
-                   version: appData[5] << 8 | appData[6],
 
-                   flags0: appData[7] << 8 | appData[8],
 
-                   flags1: appData[9] << 8 | appData[10],
 
-                   transformCode: appData[11]
 
-                 };
 
-               }
 
-             }
 
-             break;
 
-           case 0xffdb:
 
-             const quantizationTablesLength = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             var quantizationTablesEnd = quantizationTablesLength + offset - 2;
 
-             var z;
 
-             while (offset < quantizationTablesEnd) {
 
-               var quantizationTableSpec = data[offset++];
 
-               var tableData = new Uint16Array(64);
 
-               if (quantizationTableSpec >> 4 === 0) {
 
-                 for (j = 0; j < 64; j++) {
 
-                   z = dctZigZag[j];
 
-                   tableData[z] = data[offset++];
 
-                 }
 
-               } else if (quantizationTableSpec >> 4 === 1) {
 
-                 for (j = 0; j < 64; j++) {
 
-                   z = dctZigZag[j];
 
-                   tableData[z] = (0, _core_utils.readUint16)(data, offset);
 
-                   offset += 2;
 
-                 }
 
-               } else {
 
-                 throw new JpegError("DQT - invalid table spec");
 
-               }
 
-               quantizationTables[quantizationTableSpec & 15] = tableData;
 
-             }
 
-             break;
 
-           case 0xffc0:
 
-           case 0xffc1:
 
-           case 0xffc2:
 
-             if (frame) {
 
-               throw new JpegError("Only single frame JPEGs supported");
 
-             }
 
-             offset += 2;
 
-             frame = {};
 
-             frame.extended = fileMarker === 0xffc1;
 
-             frame.progressive = fileMarker === 0xffc2;
 
-             frame.precision = data[offset++];
 
-             const sofScanLines = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             frame.scanLines = dnlScanLines || sofScanLines;
 
-             frame.samplesPerLine = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             frame.components = [];
 
-             frame.componentIds = {};
 
-             var componentsCount = data[offset++],
 
-                 componentId;
 
-             var maxH = 0,
 
-                 maxV = 0;
 
-             for (i = 0; i < componentsCount; i++) {
 
-               componentId = data[offset];
 
-               var h = data[offset + 1] >> 4;
 
-               var v = data[offset + 1] & 15;
 
-               if (maxH < h) {
 
-                 maxH = h;
 
-               }
 
-               if (maxV < v) {
 
-                 maxV = v;
 
-               }
 
-               var qId = data[offset + 2];
 
-               l = frame.components.push({
 
-                 h,
 
-                 v,
 
-                 quantizationId: qId,
 
-                 quantizationTable: null
 
-               });
 
-               frame.componentIds[componentId] = l - 1;
 
-               offset += 3;
 
-             }
 
-             frame.maxH = maxH;
 
-             frame.maxV = maxV;
 
-             prepareComponents(frame);
 
-             break;
 
-           case 0xffc4:
 
-             const huffmanLength = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             for (i = 2; i < huffmanLength;) {
 
-               var huffmanTableSpec = data[offset++];
 
-               var codeLengths = new Uint8Array(16);
 
-               var codeLengthSum = 0;
 
-               for (j = 0; j < 16; j++, offset++) {
 
-                 codeLengthSum += codeLengths[j] = data[offset];
 
-               }
 
-               var huffmanValues = new Uint8Array(codeLengthSum);
 
-               for (j = 0; j < codeLengthSum; j++, offset++) {
 
-                 huffmanValues[j] = data[offset];
 
-               }
 
-               i += 17 + codeLengthSum;
 
-               (huffmanTableSpec >> 4 === 0 ? huffmanTablesDC : huffmanTablesAC)[huffmanTableSpec & 15] = buildHuffmanTable(codeLengths, huffmanValues);
 
-             }
 
-             break;
 
-           case 0xffdd:
 
-             offset += 2;
 
-             resetInterval = (0, _core_utils.readUint16)(data, offset);
 
-             offset += 2;
 
-             break;
 
-           case 0xffda:
 
-             const parseDNLMarker = ++numSOSMarkers === 1 && !dnlScanLines;
 
-             offset += 2;
 
-             var selectorsCount = data[offset++];
 
-             var components = [],
 
-                 component;
 
-             for (i = 0; i < selectorsCount; i++) {
 
-               var componentIndex = frame.componentIds[data[offset++]];
 
-               component = frame.components[componentIndex];
 
-               var tableSpec = data[offset++];
 
-               component.huffmanTableDC = huffmanTablesDC[tableSpec >> 4];
 
-               component.huffmanTableAC = huffmanTablesAC[tableSpec & 15];
 
-               components.push(component);
 
-             }
 
-             var spectralStart = data[offset++];
 
-             var spectralEnd = data[offset++];
 
-             var successiveApproximation = data[offset++];
 
-             try {
 
-               var processed = decodeScan(data, offset, frame, components, resetInterval, spectralStart, spectralEnd, successiveApproximation >> 4, successiveApproximation & 15, parseDNLMarker);
 
-               offset += processed;
 
-             } catch (ex) {
 
-               if (ex instanceof DNLMarkerError) {
 
-                 (0, _util.warn)(`${ex.message} -- attempting to re-parse the JPEG image.`);
 
-                 return this.parse(data, {
 
-                   dnlScanLines: ex.scanLines
 
-                 });
 
-               } else if (ex instanceof EOIMarkerError) {
 
-                 (0, _util.warn)(`${ex.message} -- ignoring the rest of the image data.`);
 
-                 break markerLoop;
 
-               }
 
-               throw ex;
 
-             }
 
-             break;
 
-           case 0xffdc:
 
-             offset += 4;
 
-             break;
 
-           case 0xffff:
 
-             if (data[offset] !== 0xff) {
 
-               offset--;
 
-             }
 
-             break;
 
-           default:
 
-             const nextFileMarker = findNextFileMarker(data, offset - 2, offset - 3);
 
-             if (nextFileMarker && nextFileMarker.invalid) {
 
-               (0, _util.warn)("JpegImage.parse - unexpected data, current marker is: " + nextFileMarker.invalid);
 
-               offset = nextFileMarker.offset;
 
-               break;
 
-             }
 
-             if (offset >= data.length - 1) {
 
-               (0, _util.warn)("JpegImage.parse - reached the end of the image data " + "without finding an EOI marker (0xFFD9).");
 
-               break markerLoop;
 
-             }
 
-             throw new JpegError("JpegImage.parse - unknown marker: " + fileMarker.toString(16));
 
-         }
 
-         fileMarker = (0, _core_utils.readUint16)(data, offset);
 
-         offset += 2;
 
-       }
 
-       this.width = frame.samplesPerLine;
 
-       this.height = frame.scanLines;
 
-       this.jfif = jfif;
 
-       this.adobe = adobe;
 
-       this.components = [];
 
-       for (i = 0; i < frame.components.length; i++) {
 
-         component = frame.components[i];
 
-         var quantizationTable = quantizationTables[component.quantizationId];
 
-         if (quantizationTable) {
 
-           component.quantizationTable = quantizationTable;
 
-         }
 
-         this.components.push({
 
-           output: buildComponentData(frame, component),
 
-           scaleX: component.h / frame.maxH,
 
-           scaleY: component.v / frame.maxV,
 
-           blocksPerLine: component.blocksPerLine,
 
-           blocksPerColumn: component.blocksPerColumn
 
-         });
 
-       }
 
-       this.numComponents = this.components.length;
 
-       return undefined;
 
-     },
 
-     _getLinearizedBlockData(width, height, isSourcePDF = false) {
 
-       var scaleX = this.width / width,
 
-           scaleY = this.height / height;
 
-       var component, componentScaleX, componentScaleY, blocksPerScanline;
 
-       var x, y, i, j, k;
 
-       var index;
 
-       var offset = 0;
 
-       var output;
 
-       var numComponents = this.components.length;
 
-       var dataLength = width * height * numComponents;
 
-       var data = new Uint8ClampedArray(dataLength);
 
-       var xScaleBlockOffset = new Uint32Array(width);
 
-       var mask3LSB = 0xfffffff8;
 
-       let lastComponentScaleX;
 
-       for (i = 0; i < numComponents; i++) {
 
-         component = this.components[i];
 
-         componentScaleX = component.scaleX * scaleX;
 
-         componentScaleY = component.scaleY * scaleY;
 
-         offset = i;
 
-         output = component.output;
 
-         blocksPerScanline = component.blocksPerLine + 1 << 3;
 
-         if (componentScaleX !== lastComponentScaleX) {
 
-           for (x = 0; x < width; x++) {
 
-             j = 0 | x * componentScaleX;
 
-             xScaleBlockOffset[x] = (j & mask3LSB) << 3 | j & 7;
 
-           }
 
-           lastComponentScaleX = componentScaleX;
 
-         }
 
-         for (y = 0; y < height; y++) {
 
-           j = 0 | y * componentScaleY;
 
-           index = blocksPerScanline * (j & mask3LSB) | (j & 7) << 3;
 
-           for (x = 0; x < width; x++) {
 
-             data[offset] = output[index + xScaleBlockOffset[x]];
 
-             offset += numComponents;
 
-           }
 
-         }
 
-       }
 
-       let transform = this._decodeTransform;
 
-       if (!isSourcePDF && numComponents === 4 && !transform) {
 
-         transform = new Int32Array([-256, 255, -256, 255, -256, 255, -256, 255]);
 
-       }
 
-       if (transform) {
 
-         for (i = 0; i < dataLength;) {
 
-           for (j = 0, k = 0; j < numComponents; j++, i++, k += 2) {
 
-             data[i] = (data[i] * transform[k] >> 8) + transform[k + 1];
 
-           }
 
-         }
 
-       }
 
-       return data;
 
-     },
 
-     get _isColorConversionNeeded() {
 
-       if (this.adobe) {
 
-         return !!this.adobe.transformCode;
 
-       }
 
-       if (this.numComponents === 3) {
 
-         if (this._colorTransform === 0) {
 
-           return false;
 
-         }
 
-         return true;
 
-       }
 
-       if (this._colorTransform === 1) {
 
-         return true;
 
-       }
 
-       return false;
 
-     },
 
-     _convertYccToRgb: function convertYccToRgb(data) {
 
-       var Y, Cb, Cr;
 
-       for (var i = 0, length = data.length; i < length; i += 3) {
 
-         Y = data[i];
 
-         Cb = data[i + 1];
 
-         Cr = data[i + 2];
 
-         data[i] = Y - 179.456 + 1.402 * Cr;
 
-         data[i + 1] = Y + 135.459 - 0.344 * Cb - 0.714 * Cr;
 
-         data[i + 2] = Y - 226.816 + 1.772 * Cb;
 
-       }
 
-       return data;
 
-     },
 
-     _convertYcckToRgb: function convertYcckToRgb(data) {
 
-       var Y, Cb, Cr, k;
 
-       var offset = 0;
 
-       for (var i = 0, length = data.length; i < length; i += 4) {
 
-         Y = data[i];
 
-         Cb = data[i + 1];
 
-         Cr = data[i + 2];
 
-         k = data[i + 3];
 
-         data[offset++] = -122.67195406894 + Cb * (-6.60635669420364e-5 * Cb + 0.000437130475926232 * Cr - 5.4080610064599e-5 * Y + 0.00048449797120281 * k - 0.154362151871126) + Cr * (-0.000957964378445773 * Cr + 0.000817076911346625 * Y - 0.00477271405408747 * k + 1.53380253221734) + Y * (0.000961250184130688 * Y - 0.00266257332283933 * k + 0.48357088451265) + k * (-0.000336197177618394 * k + 0.484791561490776);
 
-         data[offset++] = 107.268039397724 + Cb * (2.19927104525741e-5 * Cb - 0.000640992018297945 * Cr + 0.000659397001245577 * Y + 0.000426105652938837 * k - 0.176491792462875) + Cr * (-0.000778269941513683 * Cr + 0.00130872261408275 * Y + 0.000770482631801132 * k - 0.151051492775562) + Y * (0.00126935368114843 * Y - 0.00265090189010898 * k + 0.25802910206845) + k * (-0.000318913117588328 * k - 0.213742400323665);
 
-         data[offset++] = -20.810012546947 + Cb * (-0.000570115196973677 * Cb - 2.63409051004589e-5 * Cr + 0.0020741088115012 * Y - 0.00288260236853442 * k + 0.814272968359295) + Cr * (-1.53496057440975e-5 * Cr - 0.000132689043961446 * Y + 0.000560833691242812 * k - 0.195152027534049) + Y * (0.00174418132927582 * Y - 0.00255243321439347 * k + 0.116935020465145) + k * (-0.000343531996510555 * k + 0.24165260232407);
 
-       }
 
-       return data.subarray(0, offset);
 
-     },
 
-     _convertYcckToCmyk: function convertYcckToCmyk(data) {
 
-       var Y, Cb, Cr;
 
-       for (var i = 0, length = data.length; i < length; i += 4) {
 
-         Y = data[i];
 
-         Cb = data[i + 1];
 
-         Cr = data[i + 2];
 
-         data[i] = 434.456 - Y - 1.402 * Cr;
 
-         data[i + 1] = 119.541 - Y + 0.344 * Cb + 0.714 * Cr;
 
-         data[i + 2] = 481.816 - Y - 1.772 * Cb;
 
-       }
 
-       return data;
 
-     },
 
-     _convertCmykToRgb: function convertCmykToRgb(data) {
 
-       var c, m, y, k;
 
-       var offset = 0;
 
-       for (var i = 0, length = data.length; i < length; i += 4) {
 
-         c = data[i];
 
-         m = data[i + 1];
 
-         y = data[i + 2];
 
-         k = data[i + 3];
 
-         data[offset++] = 255 + c * (-0.00006747147073602441 * c + 0.0008379262121013727 * m + 0.0002894718188643294 * y + 0.003264231057537806 * k - 1.1185611867203937) + m * (0.000026374107616089405 * m - 0.00008626949158638572 * y - 0.0002748769067499491 * k - 0.02155688794978967) + y * (-0.00003878099212869363 * y - 0.0003267808279485286 * k + 0.0686742238595345) - k * (0.0003361971776183937 * k + 0.7430659151342254);
 
-         data[offset++] = 255 + c * (0.00013596372813588848 * c + 0.000924537132573585 * m + 0.00010567359618683593 * y + 0.0004791864687436512 * k - 0.3109689587515875) + m * (-0.00023545346108370344 * m + 0.0002702845253534714 * y + 0.0020200308977307156 * k - 0.7488052167015494) + y * (0.00006834815998235662 * y + 0.00015168452363460973 * k - 0.09751927774728933) - k * (0.00031891311758832814 * k + 0.7364883807733168);
 
-         data[offset++] = 255 + c * (0.000013598650411385307 * c + 0.00012423956175490851 * m + 0.0004751985097583589 * y - 0.0000036729317476630422 * k - 0.05562186980264034) + m * (0.00016141380598724676 * m + 0.0009692239130725186 * y + 0.0007782692450036253 * k - 0.44015232367526463) + y * (5.068882914068769e-7 * y + 0.0017778369011375071 * k - 0.7591454649749609) - k * (0.0003435319965105553 * k + 0.7063770186160144);
 
-       }
 
-       return data.subarray(0, offset);
 
-     },
 
-     getData({
 
-       width,
 
-       height,
 
-       forceRGB = false,
 
-       isSourcePDF = false
 
-     }) {
 
-       if (this.numComponents > 4) {
 
-         throw new JpegError("Unsupported color mode");
 
-       }
 
-       var data = this._getLinearizedBlockData(width, height, isSourcePDF);
 
-       if (this.numComponents === 1 && forceRGB) {
 
-         var dataLength = data.length;
 
-         var rgbData = new Uint8ClampedArray(dataLength * 3);
 
-         var offset = 0;
 
-         for (var i = 0; i < dataLength; i++) {
 
-           var grayColor = data[i];
 
-           rgbData[offset++] = grayColor;
 
-           rgbData[offset++] = grayColor;
 
-           rgbData[offset++] = grayColor;
 
-         }
 
-         return rgbData;
 
-       } else if (this.numComponents === 3 && this._isColorConversionNeeded) {
 
-         return this._convertYccToRgb(data);
 
-       } else if (this.numComponents === 4) {
 
-         if (this._isColorConversionNeeded) {
 
-           if (forceRGB) {
 
-             return this._convertYcckToRgb(data);
 
-           }
 
-           return this._convertYcckToCmyk(data);
 
-         } else if (forceRGB) {
 
-           return this._convertCmykToRgb(data);
 
-         }
 
-       }
 
-       return data;
 
-     }
 
-   };
 
-   return JpegImage;
 
- }();
 
- exports.JpegImage = JpegImage;
 
- /***/ }),
 
- /* 19 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.JpxStream = void 0;
 
- var _stream = __w_pdfjs_require__(11);
 
- var _jpx = __w_pdfjs_require__(20);
 
- var _util = __w_pdfjs_require__(2);
 
- const JpxStream = function JpxStreamClosure() {
 
-   function JpxStream(stream, maybeLength, dict, params) {
 
-     this.stream = stream;
 
-     this.maybeLength = maybeLength;
 
-     this.dict = dict;
 
-     this.params = params;
 
-     _stream.DecodeStream.call(this, maybeLength);
 
-   }
 
-   JpxStream.prototype = Object.create(_stream.DecodeStream.prototype);
 
-   Object.defineProperty(JpxStream.prototype, "bytes", {
 
-     get: function JpxStream_bytes() {
 
-       return (0, _util.shadow)(this, "bytes", this.stream.getBytes(this.maybeLength));
 
-     },
 
-     configurable: true
 
-   });
 
-   JpxStream.prototype.ensureBuffer = function (requested) {};
 
-   JpxStream.prototype.readBlock = function () {
 
-     if (this.eof) {
 
-       return;
 
-     }
 
-     const jpxImage = new _jpx.JpxImage();
 
-     jpxImage.parse(this.bytes);
 
-     const width = jpxImage.width;
 
-     const height = jpxImage.height;
 
-     const componentsCount = jpxImage.componentsCount;
 
-     const tileCount = jpxImage.tiles.length;
 
-     if (tileCount === 1) {
 
-       this.buffer = jpxImage.tiles[0].items;
 
-     } else {
 
-       const data = new Uint8ClampedArray(width * height * componentsCount);
 
-       for (let k = 0; k < tileCount; k++) {
 
-         const tileComponents = jpxImage.tiles[k];
 
-         const tileWidth = tileComponents.width;
 
-         const tileHeight = tileComponents.height;
 
-         const tileLeft = tileComponents.left;
 
-         const tileTop = tileComponents.top;
 
-         const src = tileComponents.items;
 
-         let srcPosition = 0;
 
-         let dataPosition = (width * tileTop + tileLeft) * componentsCount;
 
-         const imgRowSize = width * componentsCount;
 
-         const tileRowSize = tileWidth * componentsCount;
 
-         for (let j = 0; j < tileHeight; j++) {
 
-           const rowBytes = src.subarray(srcPosition, srcPosition + tileRowSize);
 
-           data.set(rowBytes, dataPosition);
 
-           srcPosition += tileRowSize;
 
-           dataPosition += imgRowSize;
 
-         }
 
-       }
 
-       this.buffer = data;
 
-     }
 
-     this.bufferLength = this.buffer.length;
 
-     this.eof = true;
 
-   };
 
-   return JpxStream;
 
- }();
 
- exports.JpxStream = JpxStream;
 
- /***/ }),
 
- /* 20 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.JpxImage = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _arithmetic_decoder = __w_pdfjs_require__(16);
 
- class JpxError extends _util.BaseException {
 
-   constructor(msg) {
 
-     super(`JPX error: ${msg}`);
 
-   }
 
- }
 
- var JpxImage = function JpxImageClosure() {
 
-   var SubbandsGainLog2 = {
 
-     LL: 0,
 
-     LH: 1,
 
-     HL: 1,
 
-     HH: 2
 
-   };
 
-   function JpxImage() {
 
-     this.failOnCorruptedImage = false;
 
-   }
 
-   JpxImage.prototype = {
 
-     parse: function JpxImage_parse(data) {
 
-       var head = (0, _core_utils.readUint16)(data, 0);
 
-       if (head === 0xff4f) {
 
-         this.parseCodestream(data, 0, data.length);
 
-         return;
 
-       }
 
-       var position = 0,
 
-           length = data.length;
 
-       while (position < length) {
 
-         var headerSize = 8;
 
-         var lbox = (0, _core_utils.readUint32)(data, position);
 
-         var tbox = (0, _core_utils.readUint32)(data, position + 4);
 
-         position += headerSize;
 
-         if (lbox === 1) {
 
-           lbox = (0, _core_utils.readUint32)(data, position) * 4294967296 + (0, _core_utils.readUint32)(data, position + 4);
 
-           position += 8;
 
-           headerSize += 8;
 
-         }
 
-         if (lbox === 0) {
 
-           lbox = length - position + headerSize;
 
-         }
 
-         if (lbox < headerSize) {
 
-           throw new JpxError("Invalid box field size");
 
-         }
 
-         var dataLength = lbox - headerSize;
 
-         var jumpDataLength = true;
 
-         switch (tbox) {
 
-           case 0x6a703268:
 
-             jumpDataLength = false;
 
-             break;
 
-           case 0x636f6c72:
 
-             var method = data[position];
 
-             if (method === 1) {
 
-               var colorspace = (0, _core_utils.readUint32)(data, position + 3);
 
-               switch (colorspace) {
 
-                 case 16:
 
-                 case 17:
 
-                 case 18:
 
-                   break;
 
-                 default:
 
-                   (0, _util.warn)("Unknown colorspace " + colorspace);
 
-                   break;
 
-               }
 
-             } else if (method === 2) {
 
-               (0, _util.info)("ICC profile not supported");
 
-             }
 
-             break;
 
-           case 0x6a703263:
 
-             this.parseCodestream(data, position, position + dataLength);
 
-             break;
 
-           case 0x6a502020:
 
-             if ((0, _core_utils.readUint32)(data, position) !== 0x0d0a870a) {
 
-               (0, _util.warn)("Invalid JP2 signature");
 
-             }
 
-             break;
 
-           case 0x6a501a1a:
 
-           case 0x66747970:
 
-           case 0x72726571:
 
-           case 0x72657320:
 
-           case 0x69686472:
 
-             break;
 
-           default:
 
-             var headerType = String.fromCharCode(tbox >> 24 & 0xff, tbox >> 16 & 0xff, tbox >> 8 & 0xff, tbox & 0xff);
 
-             (0, _util.warn)("Unsupported header type " + tbox + " (" + headerType + ")");
 
-             break;
 
-         }
 
-         if (jumpDataLength) {
 
-           position += dataLength;
 
-         }
 
-       }
 
-     },
 
-     parseImageProperties: function JpxImage_parseImageProperties(stream) {
 
-       var newByte = stream.getByte();
 
-       while (newByte >= 0) {
 
-         var oldByte = newByte;
 
-         newByte = stream.getByte();
 
-         var code = oldByte << 8 | newByte;
 
-         if (code === 0xff51) {
 
-           stream.skip(4);
 
-           var Xsiz = stream.getInt32() >>> 0;
 
-           var Ysiz = stream.getInt32() >>> 0;
 
-           var XOsiz = stream.getInt32() >>> 0;
 
-           var YOsiz = stream.getInt32() >>> 0;
 
-           stream.skip(16);
 
-           var Csiz = stream.getUint16();
 
-           this.width = Xsiz - XOsiz;
 
-           this.height = Ysiz - YOsiz;
 
-           this.componentsCount = Csiz;
 
-           this.bitsPerComponent = 8;
 
-           return;
 
-         }
 
-       }
 
-       throw new JpxError("No size marker found in JPX stream");
 
-     },
 
-     parseCodestream: function JpxImage_parseCodestream(data, start, end) {
 
-       var context = {};
 
-       var doNotRecover = false;
 
-       try {
 
-         var position = start;
 
-         while (position + 1 < end) {
 
-           var code = (0, _core_utils.readUint16)(data, position);
 
-           position += 2;
 
-           var length = 0,
 
-               j,
 
-               sqcd,
 
-               spqcds,
 
-               spqcdSize,
 
-               scalarExpounded,
 
-               tile;
 
-           switch (code) {
 
-             case 0xff4f:
 
-               context.mainHeader = true;
 
-               break;
 
-             case 0xffd9:
 
-               break;
 
-             case 0xff51:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               var siz = {};
 
-               siz.Xsiz = (0, _core_utils.readUint32)(data, position + 4);
 
-               siz.Ysiz = (0, _core_utils.readUint32)(data, position + 8);
 
-               siz.XOsiz = (0, _core_utils.readUint32)(data, position + 12);
 
-               siz.YOsiz = (0, _core_utils.readUint32)(data, position + 16);
 
-               siz.XTsiz = (0, _core_utils.readUint32)(data, position + 20);
 
-               siz.YTsiz = (0, _core_utils.readUint32)(data, position + 24);
 
-               siz.XTOsiz = (0, _core_utils.readUint32)(data, position + 28);
 
-               siz.YTOsiz = (0, _core_utils.readUint32)(data, position + 32);
 
-               var componentsCount = (0, _core_utils.readUint16)(data, position + 36);
 
-               siz.Csiz = componentsCount;
 
-               var components = [];
 
-               j = position + 38;
 
-               for (var i = 0; i < componentsCount; i++) {
 
-                 var component = {
 
-                   precision: (data[j] & 0x7f) + 1,
 
-                   isSigned: !!(data[j] & 0x80),
 
-                   XRsiz: data[j + 1],
 
-                   YRsiz: data[j + 2]
 
-                 };
 
-                 j += 3;
 
-                 calculateComponentDimensions(component, siz);
 
-                 components.push(component);
 
-               }
 
-               context.SIZ = siz;
 
-               context.components = components;
 
-               calculateTileGrids(context, components);
 
-               context.QCC = [];
 
-               context.COC = [];
 
-               break;
 
-             case 0xff5c:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               var qcd = {};
 
-               j = position + 2;
 
-               sqcd = data[j++];
 
-               switch (sqcd & 0x1f) {
 
-                 case 0:
 
-                   spqcdSize = 8;
 
-                   scalarExpounded = true;
 
-                   break;
 
-                 case 1:
 
-                   spqcdSize = 16;
 
-                   scalarExpounded = false;
 
-                   break;
 
-                 case 2:
 
-                   spqcdSize = 16;
 
-                   scalarExpounded = true;
 
-                   break;
 
-                 default:
 
-                   throw new Error("Invalid SQcd value " + sqcd);
 
-               }
 
-               qcd.noQuantization = spqcdSize === 8;
 
-               qcd.scalarExpounded = scalarExpounded;
 
-               qcd.guardBits = sqcd >> 5;
 
-               spqcds = [];
 
-               while (j < length + position) {
 
-                 var spqcd = {};
 
-                 if (spqcdSize === 8) {
 
-                   spqcd.epsilon = data[j++] >> 3;
 
-                   spqcd.mu = 0;
 
-                 } else {
 
-                   spqcd.epsilon = data[j] >> 3;
 
-                   spqcd.mu = (data[j] & 0x7) << 8 | data[j + 1];
 
-                   j += 2;
 
-                 }
 
-                 spqcds.push(spqcd);
 
-               }
 
-               qcd.SPqcds = spqcds;
 
-               if (context.mainHeader) {
 
-                 context.QCD = qcd;
 
-               } else {
 
-                 context.currentTile.QCD = qcd;
 
-                 context.currentTile.QCC = [];
 
-               }
 
-               break;
 
-             case 0xff5d:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               var qcc = {};
 
-               j = position + 2;
 
-               var cqcc;
 
-               if (context.SIZ.Csiz < 257) {
 
-                 cqcc = data[j++];
 
-               } else {
 
-                 cqcc = (0, _core_utils.readUint16)(data, j);
 
-                 j += 2;
 
-               }
 
-               sqcd = data[j++];
 
-               switch (sqcd & 0x1f) {
 
-                 case 0:
 
-                   spqcdSize = 8;
 
-                   scalarExpounded = true;
 
-                   break;
 
-                 case 1:
 
-                   spqcdSize = 16;
 
-                   scalarExpounded = false;
 
-                   break;
 
-                 case 2:
 
-                   spqcdSize = 16;
 
-                   scalarExpounded = true;
 
-                   break;
 
-                 default:
 
-                   throw new Error("Invalid SQcd value " + sqcd);
 
-               }
 
-               qcc.noQuantization = spqcdSize === 8;
 
-               qcc.scalarExpounded = scalarExpounded;
 
-               qcc.guardBits = sqcd >> 5;
 
-               spqcds = [];
 
-               while (j < length + position) {
 
-                 spqcd = {};
 
-                 if (spqcdSize === 8) {
 
-                   spqcd.epsilon = data[j++] >> 3;
 
-                   spqcd.mu = 0;
 
-                 } else {
 
-                   spqcd.epsilon = data[j] >> 3;
 
-                   spqcd.mu = (data[j] & 0x7) << 8 | data[j + 1];
 
-                   j += 2;
 
-                 }
 
-                 spqcds.push(spqcd);
 
-               }
 
-               qcc.SPqcds = spqcds;
 
-               if (context.mainHeader) {
 
-                 context.QCC[cqcc] = qcc;
 
-               } else {
 
-                 context.currentTile.QCC[cqcc] = qcc;
 
-               }
 
-               break;
 
-             case 0xff52:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               var cod = {};
 
-               j = position + 2;
 
-               var scod = data[j++];
 
-               cod.entropyCoderWithCustomPrecincts = !!(scod & 1);
 
-               cod.sopMarkerUsed = !!(scod & 2);
 
-               cod.ephMarkerUsed = !!(scod & 4);
 
-               cod.progressionOrder = data[j++];
 
-               cod.layersCount = (0, _core_utils.readUint16)(data, j);
 
-               j += 2;
 
-               cod.multipleComponentTransform = data[j++];
 
-               cod.decompositionLevelsCount = data[j++];
 
-               cod.xcb = (data[j++] & 0xf) + 2;
 
-               cod.ycb = (data[j++] & 0xf) + 2;
 
-               var blockStyle = data[j++];
 
-               cod.selectiveArithmeticCodingBypass = !!(blockStyle & 1);
 
-               cod.resetContextProbabilities = !!(blockStyle & 2);
 
-               cod.terminationOnEachCodingPass = !!(blockStyle & 4);
 
-               cod.verticallyStripe = !!(blockStyle & 8);
 
-               cod.predictableTermination = !!(blockStyle & 16);
 
-               cod.segmentationSymbolUsed = !!(blockStyle & 32);
 
-               cod.reversibleTransformation = data[j++];
 
-               if (cod.entropyCoderWithCustomPrecincts) {
 
-                 var precinctsSizes = [];
 
-                 while (j < length + position) {
 
-                   var precinctsSize = data[j++];
 
-                   precinctsSizes.push({
 
-                     PPx: precinctsSize & 0xf,
 
-                     PPy: precinctsSize >> 4
 
-                   });
 
-                 }
 
-                 cod.precinctsSizes = precinctsSizes;
 
-               }
 
-               var unsupported = [];
 
-               if (cod.selectiveArithmeticCodingBypass) {
 
-                 unsupported.push("selectiveArithmeticCodingBypass");
 
-               }
 
-               if (cod.resetContextProbabilities) {
 
-                 unsupported.push("resetContextProbabilities");
 
-               }
 
-               if (cod.terminationOnEachCodingPass) {
 
-                 unsupported.push("terminationOnEachCodingPass");
 
-               }
 
-               if (cod.verticallyStripe) {
 
-                 unsupported.push("verticallyStripe");
 
-               }
 
-               if (cod.predictableTermination) {
 
-                 unsupported.push("predictableTermination");
 
-               }
 
-               if (unsupported.length > 0) {
 
-                 doNotRecover = true;
 
-                 throw new Error("Unsupported COD options (" + unsupported.join(", ") + ")");
 
-               }
 
-               if (context.mainHeader) {
 
-                 context.COD = cod;
 
-               } else {
 
-                 context.currentTile.COD = cod;
 
-                 context.currentTile.COC = [];
 
-               }
 
-               break;
 
-             case 0xff90:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               tile = {};
 
-               tile.index = (0, _core_utils.readUint16)(data, position + 2);
 
-               tile.length = (0, _core_utils.readUint32)(data, position + 4);
 
-               tile.dataEnd = tile.length + position - 2;
 
-               tile.partIndex = data[position + 8];
 
-               tile.partsCount = data[position + 9];
 
-               context.mainHeader = false;
 
-               if (tile.partIndex === 0) {
 
-                 tile.COD = context.COD;
 
-                 tile.COC = context.COC.slice(0);
 
-                 tile.QCD = context.QCD;
 
-                 tile.QCC = context.QCC.slice(0);
 
-               }
 
-               context.currentTile = tile;
 
-               break;
 
-             case 0xff93:
 
-               tile = context.currentTile;
 
-               if (tile.partIndex === 0) {
 
-                 initializeTile(context, tile.index);
 
-                 buildPackets(context);
 
-               }
 
-               length = tile.dataEnd - position;
 
-               parseTilePackets(context, data, position, length);
 
-               break;
 
-             case 0xff55:
 
-             case 0xff57:
 
-             case 0xff58:
 
-             case 0xff64:
 
-               length = (0, _core_utils.readUint16)(data, position);
 
-               break;
 
-             case 0xff53:
 
-               throw new Error("Codestream code 0xFF53 (COC) is not implemented");
 
-             default:
 
-               throw new Error("Unknown codestream code: " + code.toString(16));
 
-           }
 
-           position += length;
 
-         }
 
-       } catch (e) {
 
-         if (doNotRecover || this.failOnCorruptedImage) {
 
-           throw new JpxError(e.message);
 
-         } else {
 
-           (0, _util.warn)("JPX: Trying to recover from: " + e.message);
 
-         }
 
-       }
 
-       this.tiles = transformComponents(context);
 
-       this.width = context.SIZ.Xsiz - context.SIZ.XOsiz;
 
-       this.height = context.SIZ.Ysiz - context.SIZ.YOsiz;
 
-       this.componentsCount = context.SIZ.Csiz;
 
-     }
 
-   };
 
-   function calculateComponentDimensions(component, siz) {
 
-     component.x0 = Math.ceil(siz.XOsiz / component.XRsiz);
 
-     component.x1 = Math.ceil(siz.Xsiz / component.XRsiz);
 
-     component.y0 = Math.ceil(siz.YOsiz / component.YRsiz);
 
-     component.y1 = Math.ceil(siz.Ysiz / component.YRsiz);
 
-     component.width = component.x1 - component.x0;
 
-     component.height = component.y1 - component.y0;
 
-   }
 
-   function calculateTileGrids(context, components) {
 
-     var siz = context.SIZ;
 
-     var tile,
 
-         tiles = [];
 
-     var numXtiles = Math.ceil((siz.Xsiz - siz.XTOsiz) / siz.XTsiz);
 
-     var numYtiles = Math.ceil((siz.Ysiz - siz.YTOsiz) / siz.YTsiz);
 
-     for (var q = 0; q < numYtiles; q++) {
 
-       for (var p = 0; p < numXtiles; p++) {
 
-         tile = {};
 
-         tile.tx0 = Math.max(siz.XTOsiz + p * siz.XTsiz, siz.XOsiz);
 
-         tile.ty0 = Math.max(siz.YTOsiz + q * siz.YTsiz, siz.YOsiz);
 
-         tile.tx1 = Math.min(siz.XTOsiz + (p + 1) * siz.XTsiz, siz.Xsiz);
 
-         tile.ty1 = Math.min(siz.YTOsiz + (q + 1) * siz.YTsiz, siz.Ysiz);
 
-         tile.width = tile.tx1 - tile.tx0;
 
-         tile.height = tile.ty1 - tile.ty0;
 
-         tile.components = [];
 
-         tiles.push(tile);
 
-       }
 
-     }
 
-     context.tiles = tiles;
 
-     var componentsCount = siz.Csiz;
 
-     for (var i = 0, ii = componentsCount; i < ii; i++) {
 
-       var component = components[i];
 
-       for (var j = 0, jj = tiles.length; j < jj; j++) {
 
-         var tileComponent = {};
 
-         tile = tiles[j];
 
-         tileComponent.tcx0 = Math.ceil(tile.tx0 / component.XRsiz);
 
-         tileComponent.tcy0 = Math.ceil(tile.ty0 / component.YRsiz);
 
-         tileComponent.tcx1 = Math.ceil(tile.tx1 / component.XRsiz);
 
-         tileComponent.tcy1 = Math.ceil(tile.ty1 / component.YRsiz);
 
-         tileComponent.width = tileComponent.tcx1 - tileComponent.tcx0;
 
-         tileComponent.height = tileComponent.tcy1 - tileComponent.tcy0;
 
-         tile.components[i] = tileComponent;
 
-       }
 
-     }
 
-   }
 
-   function getBlocksDimensions(context, component, r) {
 
-     var codOrCoc = component.codingStyleParameters;
 
-     var result = {};
 
-     if (!codOrCoc.entropyCoderWithCustomPrecincts) {
 
-       result.PPx = 15;
 
-       result.PPy = 15;
 
-     } else {
 
-       result.PPx = codOrCoc.precinctsSizes[r].PPx;
 
-       result.PPy = codOrCoc.precinctsSizes[r].PPy;
 
-     }
 
-     result.xcb_ = r > 0 ? Math.min(codOrCoc.xcb, result.PPx - 1) : Math.min(codOrCoc.xcb, result.PPx);
 
-     result.ycb_ = r > 0 ? Math.min(codOrCoc.ycb, result.PPy - 1) : Math.min(codOrCoc.ycb, result.PPy);
 
-     return result;
 
-   }
 
-   function buildPrecincts(context, resolution, dimensions) {
 
-     var precinctWidth = 1 << dimensions.PPx;
 
-     var precinctHeight = 1 << dimensions.PPy;
 
-     var isZeroRes = resolution.resLevel === 0;
 
-     var precinctWidthInSubband = 1 << dimensions.PPx + (isZeroRes ? 0 : -1);
 
-     var precinctHeightInSubband = 1 << dimensions.PPy + (isZeroRes ? 0 : -1);
 
-     var numprecinctswide = resolution.trx1 > resolution.trx0 ? Math.ceil(resolution.trx1 / precinctWidth) - Math.floor(resolution.trx0 / precinctWidth) : 0;
 
-     var numprecinctshigh = resolution.try1 > resolution.try0 ? Math.ceil(resolution.try1 / precinctHeight) - Math.floor(resolution.try0 / precinctHeight) : 0;
 
-     var numprecincts = numprecinctswide * numprecinctshigh;
 
-     resolution.precinctParameters = {
 
-       precinctWidth,
 
-       precinctHeight,
 
-       numprecinctswide,
 
-       numprecinctshigh,
 
-       numprecincts,
 
-       precinctWidthInSubband,
 
-       precinctHeightInSubband
 
-     };
 
-   }
 
-   function buildCodeblocks(context, subband, dimensions) {
 
-     var xcb_ = dimensions.xcb_;
 
-     var ycb_ = dimensions.ycb_;
 
-     var codeblockWidth = 1 << xcb_;
 
-     var codeblockHeight = 1 << ycb_;
 
-     var cbx0 = subband.tbx0 >> xcb_;
 
-     var cby0 = subband.tby0 >> ycb_;
 
-     var cbx1 = subband.tbx1 + codeblockWidth - 1 >> xcb_;
 
-     var cby1 = subband.tby1 + codeblockHeight - 1 >> ycb_;
 
-     var precinctParameters = subband.resolution.precinctParameters;
 
-     var codeblocks = [];
 
-     var precincts = [];
 
-     var i, j, codeblock, precinctNumber;
 
-     for (j = cby0; j < cby1; j++) {
 
-       for (i = cbx0; i < cbx1; i++) {
 
-         codeblock = {
 
-           cbx: i,
 
-           cby: j,
 
-           tbx0: codeblockWidth * i,
 
-           tby0: codeblockHeight * j,
 
-           tbx1: codeblockWidth * (i + 1),
 
-           tby1: codeblockHeight * (j + 1)
 
-         };
 
-         codeblock.tbx0_ = Math.max(subband.tbx0, codeblock.tbx0);
 
-         codeblock.tby0_ = Math.max(subband.tby0, codeblock.tby0);
 
-         codeblock.tbx1_ = Math.min(subband.tbx1, codeblock.tbx1);
 
-         codeblock.tby1_ = Math.min(subband.tby1, codeblock.tby1);
 
-         var pi = Math.floor((codeblock.tbx0_ - subband.tbx0) / precinctParameters.precinctWidthInSubband);
 
-         var pj = Math.floor((codeblock.tby0_ - subband.tby0) / precinctParameters.precinctHeightInSubband);
 
-         precinctNumber = pi + pj * precinctParameters.numprecinctswide;
 
-         codeblock.precinctNumber = precinctNumber;
 
-         codeblock.subbandType = subband.type;
 
-         codeblock.Lblock = 3;
 
-         if (codeblock.tbx1_ <= codeblock.tbx0_ || codeblock.tby1_ <= codeblock.tby0_) {
 
-           continue;
 
-         }
 
-         codeblocks.push(codeblock);
 
-         var precinct = precincts[precinctNumber];
 
-         if (precinct !== undefined) {
 
-           if (i < precinct.cbxMin) {
 
-             precinct.cbxMin = i;
 
-           } else if (i > precinct.cbxMax) {
 
-             precinct.cbxMax = i;
 
-           }
 
-           if (j < precinct.cbyMin) {
 
-             precinct.cbxMin = j;
 
-           } else if (j > precinct.cbyMax) {
 
-             precinct.cbyMax = j;
 
-           }
 
-         } else {
 
-           precincts[precinctNumber] = precinct = {
 
-             cbxMin: i,
 
-             cbyMin: j,
 
-             cbxMax: i,
 
-             cbyMax: j
 
-           };
 
-         }
 
-         codeblock.precinct = precinct;
 
-       }
 
-     }
 
-     subband.codeblockParameters = {
 
-       codeblockWidth: xcb_,
 
-       codeblockHeight: ycb_,
 
-       numcodeblockwide: cbx1 - cbx0 + 1,
 
-       numcodeblockhigh: cby1 - cby0 + 1
 
-     };
 
-     subband.codeblocks = codeblocks;
 
-     subband.precincts = precincts;
 
-   }
 
-   function createPacket(resolution, precinctNumber, layerNumber) {
 
-     var precinctCodeblocks = [];
 
-     var subbands = resolution.subbands;
 
-     for (var i = 0, ii = subbands.length; i < ii; i++) {
 
-       var subband = subbands[i];
 
-       var codeblocks = subband.codeblocks;
 
-       for (var j = 0, jj = codeblocks.length; j < jj; j++) {
 
-         var codeblock = codeblocks[j];
 
-         if (codeblock.precinctNumber !== precinctNumber) {
 
-           continue;
 
-         }
 
-         precinctCodeblocks.push(codeblock);
 
-       }
 
-     }
 
-     return {
 
-       layerNumber,
 
-       codeblocks: precinctCodeblocks
 
-     };
 
-   }
 
-   function LayerResolutionComponentPositionIterator(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var layersCount = tile.codingStyleDefaultParameters.layersCount;
 
-     var componentsCount = siz.Csiz;
 
-     var maxDecompositionLevelsCount = 0;
 
-     for (var q = 0; q < componentsCount; q++) {
 
-       maxDecompositionLevelsCount = Math.max(maxDecompositionLevelsCount, tile.components[q].codingStyleParameters.decompositionLevelsCount);
 
-     }
 
-     var l = 0,
 
-         r = 0,
 
-         i = 0,
 
-         k = 0;
 
-     this.nextPacket = function JpxImage_nextPacket() {
 
-       for (; l < layersCount; l++) {
 
-         for (; r <= maxDecompositionLevelsCount; r++) {
 
-           for (; i < componentsCount; i++) {
 
-             var component = tile.components[i];
 
-             if (r > component.codingStyleParameters.decompositionLevelsCount) {
 
-               continue;
 
-             }
 
-             var resolution = component.resolutions[r];
 
-             var numprecincts = resolution.precinctParameters.numprecincts;
 
-             for (; k < numprecincts;) {
 
-               var packet = createPacket(resolution, k, l);
 
-               k++;
 
-               return packet;
 
-             }
 
-             k = 0;
 
-           }
 
-           i = 0;
 
-         }
 
-         r = 0;
 
-       }
 
-       throw new JpxError("Out of packets");
 
-     };
 
-   }
 
-   function ResolutionLayerComponentPositionIterator(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var layersCount = tile.codingStyleDefaultParameters.layersCount;
 
-     var componentsCount = siz.Csiz;
 
-     var maxDecompositionLevelsCount = 0;
 
-     for (var q = 0; q < componentsCount; q++) {
 
-       maxDecompositionLevelsCount = Math.max(maxDecompositionLevelsCount, tile.components[q].codingStyleParameters.decompositionLevelsCount);
 
-     }
 
-     var r = 0,
 
-         l = 0,
 
-         i = 0,
 
-         k = 0;
 
-     this.nextPacket = function JpxImage_nextPacket() {
 
-       for (; r <= maxDecompositionLevelsCount; r++) {
 
-         for (; l < layersCount; l++) {
 
-           for (; i < componentsCount; i++) {
 
-             var component = tile.components[i];
 
-             if (r > component.codingStyleParameters.decompositionLevelsCount) {
 
-               continue;
 
-             }
 
-             var resolution = component.resolutions[r];
 
-             var numprecincts = resolution.precinctParameters.numprecincts;
 
-             for (; k < numprecincts;) {
 
-               var packet = createPacket(resolution, k, l);
 
-               k++;
 
-               return packet;
 
-             }
 
-             k = 0;
 
-           }
 
-           i = 0;
 
-         }
 
-         l = 0;
 
-       }
 
-       throw new JpxError("Out of packets");
 
-     };
 
-   }
 
-   function ResolutionPositionComponentLayerIterator(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var layersCount = tile.codingStyleDefaultParameters.layersCount;
 
-     var componentsCount = siz.Csiz;
 
-     var l, r, c, p;
 
-     var maxDecompositionLevelsCount = 0;
 
-     for (c = 0; c < componentsCount; c++) {
 
-       var component = tile.components[c];
 
-       maxDecompositionLevelsCount = Math.max(maxDecompositionLevelsCount, component.codingStyleParameters.decompositionLevelsCount);
 
-     }
 
-     var maxNumPrecinctsInLevel = new Int32Array(maxDecompositionLevelsCount + 1);
 
-     for (r = 0; r <= maxDecompositionLevelsCount; ++r) {
 
-       var maxNumPrecincts = 0;
 
-       for (c = 0; c < componentsCount; ++c) {
 
-         var resolutions = tile.components[c].resolutions;
 
-         if (r < resolutions.length) {
 
-           maxNumPrecincts = Math.max(maxNumPrecincts, resolutions[r].precinctParameters.numprecincts);
 
-         }
 
-       }
 
-       maxNumPrecinctsInLevel[r] = maxNumPrecincts;
 
-     }
 
-     l = 0;
 
-     r = 0;
 
-     c = 0;
 
-     p = 0;
 
-     this.nextPacket = function JpxImage_nextPacket() {
 
-       for (; r <= maxDecompositionLevelsCount; r++) {
 
-         for (; p < maxNumPrecinctsInLevel[r]; p++) {
 
-           for (; c < componentsCount; c++) {
 
-             var component = tile.components[c];
 
-             if (r > component.codingStyleParameters.decompositionLevelsCount) {
 
-               continue;
 
-             }
 
-             var resolution = component.resolutions[r];
 
-             var numprecincts = resolution.precinctParameters.numprecincts;
 
-             if (p >= numprecincts) {
 
-               continue;
 
-             }
 
-             for (; l < layersCount;) {
 
-               var packet = createPacket(resolution, p, l);
 
-               l++;
 
-               return packet;
 
-             }
 
-             l = 0;
 
-           }
 
-           c = 0;
 
-         }
 
-         p = 0;
 
-       }
 
-       throw new JpxError("Out of packets");
 
-     };
 
-   }
 
-   function PositionComponentResolutionLayerIterator(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var layersCount = tile.codingStyleDefaultParameters.layersCount;
 
-     var componentsCount = siz.Csiz;
 
-     var precinctsSizes = getPrecinctSizesInImageScale(tile);
 
-     var precinctsIterationSizes = precinctsSizes;
 
-     var l = 0,
 
-         r = 0,
 
-         c = 0,
 
-         px = 0,
 
-         py = 0;
 
-     this.nextPacket = function JpxImage_nextPacket() {
 
-       for (; py < precinctsIterationSizes.maxNumHigh; py++) {
 
-         for (; px < precinctsIterationSizes.maxNumWide; px++) {
 
-           for (; c < componentsCount; c++) {
 
-             var component = tile.components[c];
 
-             var decompositionLevelsCount = component.codingStyleParameters.decompositionLevelsCount;
 
-             for (; r <= decompositionLevelsCount; r++) {
 
-               var resolution = component.resolutions[r];
 
-               var sizeInImageScale = precinctsSizes.components[c].resolutions[r];
 
-               var k = getPrecinctIndexIfExist(px, py, sizeInImageScale, precinctsIterationSizes, resolution);
 
-               if (k === null) {
 
-                 continue;
 
-               }
 
-               for (; l < layersCount;) {
 
-                 var packet = createPacket(resolution, k, l);
 
-                 l++;
 
-                 return packet;
 
-               }
 
-               l = 0;
 
-             }
 
-             r = 0;
 
-           }
 
-           c = 0;
 
-         }
 
-         px = 0;
 
-       }
 
-       throw new JpxError("Out of packets");
 
-     };
 
-   }
 
-   function ComponentPositionResolutionLayerIterator(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var layersCount = tile.codingStyleDefaultParameters.layersCount;
 
-     var componentsCount = siz.Csiz;
 
-     var precinctsSizes = getPrecinctSizesInImageScale(tile);
 
-     var l = 0,
 
-         r = 0,
 
-         c = 0,
 
-         px = 0,
 
-         py = 0;
 
-     this.nextPacket = function JpxImage_nextPacket() {
 
-       for (; c < componentsCount; ++c) {
 
-         var component = tile.components[c];
 
-         var precinctsIterationSizes = precinctsSizes.components[c];
 
-         var decompositionLevelsCount = component.codingStyleParameters.decompositionLevelsCount;
 
-         for (; py < precinctsIterationSizes.maxNumHigh; py++) {
 
-           for (; px < precinctsIterationSizes.maxNumWide; px++) {
 
-             for (; r <= decompositionLevelsCount; r++) {
 
-               var resolution = component.resolutions[r];
 
-               var sizeInImageScale = precinctsIterationSizes.resolutions[r];
 
-               var k = getPrecinctIndexIfExist(px, py, sizeInImageScale, precinctsIterationSizes, resolution);
 
-               if (k === null) {
 
-                 continue;
 
-               }
 
-               for (; l < layersCount;) {
 
-                 var packet = createPacket(resolution, k, l);
 
-                 l++;
 
-                 return packet;
 
-               }
 
-               l = 0;
 
-             }
 
-             r = 0;
 
-           }
 
-           px = 0;
 
-         }
 
-         py = 0;
 
-       }
 
-       throw new JpxError("Out of packets");
 
-     };
 
-   }
 
-   function getPrecinctIndexIfExist(pxIndex, pyIndex, sizeInImageScale, precinctIterationSizes, resolution) {
 
-     var posX = pxIndex * precinctIterationSizes.minWidth;
 
-     var posY = pyIndex * precinctIterationSizes.minHeight;
 
-     if (posX % sizeInImageScale.width !== 0 || posY % sizeInImageScale.height !== 0) {
 
-       return null;
 
-     }
 
-     var startPrecinctRowIndex = posY / sizeInImageScale.width * resolution.precinctParameters.numprecinctswide;
 
-     return posX / sizeInImageScale.height + startPrecinctRowIndex;
 
-   }
 
-   function getPrecinctSizesInImageScale(tile) {
 
-     var componentsCount = tile.components.length;
 
-     var minWidth = Number.MAX_VALUE;
 
-     var minHeight = Number.MAX_VALUE;
 
-     var maxNumWide = 0;
 
-     var maxNumHigh = 0;
 
-     var sizePerComponent = new Array(componentsCount);
 
-     for (var c = 0; c < componentsCount; c++) {
 
-       var component = tile.components[c];
 
-       var decompositionLevelsCount = component.codingStyleParameters.decompositionLevelsCount;
 
-       var sizePerResolution = new Array(decompositionLevelsCount + 1);
 
-       var minWidthCurrentComponent = Number.MAX_VALUE;
 
-       var minHeightCurrentComponent = Number.MAX_VALUE;
 
-       var maxNumWideCurrentComponent = 0;
 
-       var maxNumHighCurrentComponent = 0;
 
-       var scale = 1;
 
-       for (var r = decompositionLevelsCount; r >= 0; --r) {
 
-         var resolution = component.resolutions[r];
 
-         var widthCurrentResolution = scale * resolution.precinctParameters.precinctWidth;
 
-         var heightCurrentResolution = scale * resolution.precinctParameters.precinctHeight;
 
-         minWidthCurrentComponent = Math.min(minWidthCurrentComponent, widthCurrentResolution);
 
-         minHeightCurrentComponent = Math.min(minHeightCurrentComponent, heightCurrentResolution);
 
-         maxNumWideCurrentComponent = Math.max(maxNumWideCurrentComponent, resolution.precinctParameters.numprecinctswide);
 
-         maxNumHighCurrentComponent = Math.max(maxNumHighCurrentComponent, resolution.precinctParameters.numprecinctshigh);
 
-         sizePerResolution[r] = {
 
-           width: widthCurrentResolution,
 
-           height: heightCurrentResolution
 
-         };
 
-         scale <<= 1;
 
-       }
 
-       minWidth = Math.min(minWidth, minWidthCurrentComponent);
 
-       minHeight = Math.min(minHeight, minHeightCurrentComponent);
 
-       maxNumWide = Math.max(maxNumWide, maxNumWideCurrentComponent);
 
-       maxNumHigh = Math.max(maxNumHigh, maxNumHighCurrentComponent);
 
-       sizePerComponent[c] = {
 
-         resolutions: sizePerResolution,
 
-         minWidth: minWidthCurrentComponent,
 
-         minHeight: minHeightCurrentComponent,
 
-         maxNumWide: maxNumWideCurrentComponent,
 
-         maxNumHigh: maxNumHighCurrentComponent
 
-       };
 
-     }
 
-     return {
 
-       components: sizePerComponent,
 
-       minWidth,
 
-       minHeight,
 
-       maxNumWide,
 
-       maxNumHigh
 
-     };
 
-   }
 
-   function buildPackets(context) {
 
-     var siz = context.SIZ;
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var componentsCount = siz.Csiz;
 
-     for (var c = 0; c < componentsCount; c++) {
 
-       var component = tile.components[c];
 
-       var decompositionLevelsCount = component.codingStyleParameters.decompositionLevelsCount;
 
-       var resolutions = [];
 
-       var subbands = [];
 
-       for (var r = 0; r <= decompositionLevelsCount; r++) {
 
-         var blocksDimensions = getBlocksDimensions(context, component, r);
 
-         var resolution = {};
 
-         var scale = 1 << decompositionLevelsCount - r;
 
-         resolution.trx0 = Math.ceil(component.tcx0 / scale);
 
-         resolution.try0 = Math.ceil(component.tcy0 / scale);
 
-         resolution.trx1 = Math.ceil(component.tcx1 / scale);
 
-         resolution.try1 = Math.ceil(component.tcy1 / scale);
 
-         resolution.resLevel = r;
 
-         buildPrecincts(context, resolution, blocksDimensions);
 
-         resolutions.push(resolution);
 
-         var subband;
 
-         if (r === 0) {
 
-           subband = {};
 
-           subband.type = "LL";
 
-           subband.tbx0 = Math.ceil(component.tcx0 / scale);
 
-           subband.tby0 = Math.ceil(component.tcy0 / scale);
 
-           subband.tbx1 = Math.ceil(component.tcx1 / scale);
 
-           subband.tby1 = Math.ceil(component.tcy1 / scale);
 
-           subband.resolution = resolution;
 
-           buildCodeblocks(context, subband, blocksDimensions);
 
-           subbands.push(subband);
 
-           resolution.subbands = [subband];
 
-         } else {
 
-           var bscale = 1 << decompositionLevelsCount - r + 1;
 
-           var resolutionSubbands = [];
 
-           subband = {};
 
-           subband.type = "HL";
 
-           subband.tbx0 = Math.ceil(component.tcx0 / bscale - 0.5);
 
-           subband.tby0 = Math.ceil(component.tcy0 / bscale);
 
-           subband.tbx1 = Math.ceil(component.tcx1 / bscale - 0.5);
 
-           subband.tby1 = Math.ceil(component.tcy1 / bscale);
 
-           subband.resolution = resolution;
 
-           buildCodeblocks(context, subband, blocksDimensions);
 
-           subbands.push(subband);
 
-           resolutionSubbands.push(subband);
 
-           subband = {};
 
-           subband.type = "LH";
 
-           subband.tbx0 = Math.ceil(component.tcx0 / bscale);
 
-           subband.tby0 = Math.ceil(component.tcy0 / bscale - 0.5);
 
-           subband.tbx1 = Math.ceil(component.tcx1 / bscale);
 
-           subband.tby1 = Math.ceil(component.tcy1 / bscale - 0.5);
 
-           subband.resolution = resolution;
 
-           buildCodeblocks(context, subband, blocksDimensions);
 
-           subbands.push(subband);
 
-           resolutionSubbands.push(subband);
 
-           subband = {};
 
-           subband.type = "HH";
 
-           subband.tbx0 = Math.ceil(component.tcx0 / bscale - 0.5);
 
-           subband.tby0 = Math.ceil(component.tcy0 / bscale - 0.5);
 
-           subband.tbx1 = Math.ceil(component.tcx1 / bscale - 0.5);
 
-           subband.tby1 = Math.ceil(component.tcy1 / bscale - 0.5);
 
-           subband.resolution = resolution;
 
-           buildCodeblocks(context, subband, blocksDimensions);
 
-           subbands.push(subband);
 
-           resolutionSubbands.push(subband);
 
-           resolution.subbands = resolutionSubbands;
 
-         }
 
-       }
 
-       component.resolutions = resolutions;
 
-       component.subbands = subbands;
 
-     }
 
-     var progressionOrder = tile.codingStyleDefaultParameters.progressionOrder;
 
-     switch (progressionOrder) {
 
-       case 0:
 
-         tile.packetsIterator = new LayerResolutionComponentPositionIterator(context);
 
-         break;
 
-       case 1:
 
-         tile.packetsIterator = new ResolutionLayerComponentPositionIterator(context);
 
-         break;
 
-       case 2:
 
-         tile.packetsIterator = new ResolutionPositionComponentLayerIterator(context);
 
-         break;
 
-       case 3:
 
-         tile.packetsIterator = new PositionComponentResolutionLayerIterator(context);
 
-         break;
 
-       case 4:
 
-         tile.packetsIterator = new ComponentPositionResolutionLayerIterator(context);
 
-         break;
 
-       default:
 
-         throw new JpxError(`Unsupported progression order ${progressionOrder}`);
 
-     }
 
-   }
 
-   function parseTilePackets(context, data, offset, dataLength) {
 
-     var position = 0;
 
-     var buffer,
 
-         bufferSize = 0,
 
-         skipNextBit = false;
 
-     function readBits(count) {
 
-       while (bufferSize < count) {
 
-         var b = data[offset + position];
 
-         position++;
 
-         if (skipNextBit) {
 
-           buffer = buffer << 7 | b;
 
-           bufferSize += 7;
 
-           skipNextBit = false;
 
-         } else {
 
-           buffer = buffer << 8 | b;
 
-           bufferSize += 8;
 
-         }
 
-         if (b === 0xff) {
 
-           skipNextBit = true;
 
-         }
 
-       }
 
-       bufferSize -= count;
 
-       return buffer >>> bufferSize & (1 << count) - 1;
 
-     }
 
-     function skipMarkerIfEqual(value) {
 
-       if (data[offset + position - 1] === 0xff && data[offset + position] === value) {
 
-         skipBytes(1);
 
-         return true;
 
-       } else if (data[offset + position] === 0xff && data[offset + position + 1] === value) {
 
-         skipBytes(2);
 
-         return true;
 
-       }
 
-       return false;
 
-     }
 
-     function skipBytes(count) {
 
-       position += count;
 
-     }
 
-     function alignToByte() {
 
-       bufferSize = 0;
 
-       if (skipNextBit) {
 
-         position++;
 
-         skipNextBit = false;
 
-       }
 
-     }
 
-     function readCodingpasses() {
 
-       if (readBits(1) === 0) {
 
-         return 1;
 
-       }
 
-       if (readBits(1) === 0) {
 
-         return 2;
 
-       }
 
-       var value = readBits(2);
 
-       if (value < 3) {
 
-         return value + 3;
 
-       }
 
-       value = readBits(5);
 
-       if (value < 31) {
 
-         return value + 6;
 
-       }
 
-       value = readBits(7);
 
-       return value + 37;
 
-     }
 
-     var tileIndex = context.currentTile.index;
 
-     var tile = context.tiles[tileIndex];
 
-     var sopMarkerUsed = context.COD.sopMarkerUsed;
 
-     var ephMarkerUsed = context.COD.ephMarkerUsed;
 
-     var packetsIterator = tile.packetsIterator;
 
-     while (position < dataLength) {
 
-       alignToByte();
 
-       if (sopMarkerUsed && skipMarkerIfEqual(0x91)) {
 
-         skipBytes(4);
 
-       }
 
-       var packet = packetsIterator.nextPacket();
 
-       if (!readBits(1)) {
 
-         continue;
 
-       }
 
-       var layerNumber = packet.layerNumber;
 
-       var queue = [],
 
-           codeblock;
 
-       for (var i = 0, ii = packet.codeblocks.length; i < ii; i++) {
 
-         codeblock = packet.codeblocks[i];
 
-         var precinct = codeblock.precinct;
 
-         var codeblockColumn = codeblock.cbx - precinct.cbxMin;
 
-         var codeblockRow = codeblock.cby - precinct.cbyMin;
 
-         var codeblockIncluded = false;
 
-         var firstTimeInclusion = false;
 
-         var valueReady;
 
-         if (codeblock["included"] !== undefined) {
 
-           codeblockIncluded = !!readBits(1);
 
-         } else {
 
-           precinct = codeblock.precinct;
 
-           var inclusionTree, zeroBitPlanesTree;
 
-           if (precinct["inclusionTree"] !== undefined) {
 
-             inclusionTree = precinct.inclusionTree;
 
-           } else {
 
-             var width = precinct.cbxMax - precinct.cbxMin + 1;
 
-             var height = precinct.cbyMax - precinct.cbyMin + 1;
 
-             inclusionTree = new InclusionTree(width, height, layerNumber);
 
-             zeroBitPlanesTree = new TagTree(width, height);
 
-             precinct.inclusionTree = inclusionTree;
 
-             precinct.zeroBitPlanesTree = zeroBitPlanesTree;
 
-           }
 
-           if (inclusionTree.reset(codeblockColumn, codeblockRow, layerNumber)) {
 
-             while (true) {
 
-               if (readBits(1)) {
 
-                 valueReady = !inclusionTree.nextLevel();
 
-                 if (valueReady) {
 
-                   codeblock.included = true;
 
-                   codeblockIncluded = firstTimeInclusion = true;
 
-                   break;
 
-                 }
 
-               } else {
 
-                 inclusionTree.incrementValue(layerNumber);
 
-                 break;
 
-               }
 
-             }
 
-           }
 
-         }
 
-         if (!codeblockIncluded) {
 
-           continue;
 
-         }
 
-         if (firstTimeInclusion) {
 
-           zeroBitPlanesTree = precinct.zeroBitPlanesTree;
 
-           zeroBitPlanesTree.reset(codeblockColumn, codeblockRow);
 
-           while (true) {
 
-             if (readBits(1)) {
 
-               valueReady = !zeroBitPlanesTree.nextLevel();
 
-               if (valueReady) {
 
-                 break;
 
-               }
 
-             } else {
 
-               zeroBitPlanesTree.incrementValue();
 
-             }
 
-           }
 
-           codeblock.zeroBitPlanes = zeroBitPlanesTree.value;
 
-         }
 
-         var codingpasses = readCodingpasses();
 
-         while (readBits(1)) {
 
-           codeblock.Lblock++;
 
-         }
 
-         var codingpassesLog2 = (0, _core_utils.log2)(codingpasses);
 
-         var bits = (codingpasses < 1 << codingpassesLog2 ? codingpassesLog2 - 1 : codingpassesLog2) + codeblock.Lblock;
 
-         var codedDataLength = readBits(bits);
 
-         queue.push({
 
-           codeblock,
 
-           codingpasses,
 
-           dataLength: codedDataLength
 
-         });
 
-       }
 
-       alignToByte();
 
-       if (ephMarkerUsed) {
 
-         skipMarkerIfEqual(0x92);
 
-       }
 
-       while (queue.length > 0) {
 
-         var packetItem = queue.shift();
 
-         codeblock = packetItem.codeblock;
 
-         if (codeblock["data"] === undefined) {
 
-           codeblock.data = [];
 
-         }
 
-         codeblock.data.push({
 
-           data,
 
-           start: offset + position,
 
-           end: offset + position + packetItem.dataLength,
 
-           codingpasses: packetItem.codingpasses
 
-         });
 
-         position += packetItem.dataLength;
 
-       }
 
-     }
 
-     return position;
 
-   }
 
-   function copyCoefficients(coefficients, levelWidth, levelHeight, subband, delta, mb, reversible, segmentationSymbolUsed) {
 
-     var x0 = subband.tbx0;
 
-     var y0 = subband.tby0;
 
-     var width = subband.tbx1 - subband.tbx0;
 
-     var codeblocks = subband.codeblocks;
 
-     var right = subband.type.charAt(0) === "H" ? 1 : 0;
 
-     var bottom = subband.type.charAt(1) === "H" ? levelWidth : 0;
 
-     for (var i = 0, ii = codeblocks.length; i < ii; ++i) {
 
-       var codeblock = codeblocks[i];
 
-       var blockWidth = codeblock.tbx1_ - codeblock.tbx0_;
 
-       var blockHeight = codeblock.tby1_ - codeblock.tby0_;
 
-       if (blockWidth === 0 || blockHeight === 0) {
 
-         continue;
 
-       }
 
-       if (codeblock["data"] === undefined) {
 
-         continue;
 
-       }
 
-       var bitModel, currentCodingpassType;
 
-       bitModel = new BitModel(blockWidth, blockHeight, codeblock.subbandType, codeblock.zeroBitPlanes, mb);
 
-       currentCodingpassType = 2;
 
-       var data = codeblock.data,
 
-           totalLength = 0,
 
-           codingpasses = 0;
 
-       var j, jj, dataItem;
 
-       for (j = 0, jj = data.length; j < jj; j++) {
 
-         dataItem = data[j];
 
-         totalLength += dataItem.end - dataItem.start;
 
-         codingpasses += dataItem.codingpasses;
 
-       }
 
-       var encodedData = new Uint8Array(totalLength);
 
-       var position = 0;
 
-       for (j = 0, jj = data.length; j < jj; j++) {
 
-         dataItem = data[j];
 
-         var chunk = dataItem.data.subarray(dataItem.start, dataItem.end);
 
-         encodedData.set(chunk, position);
 
-         position += chunk.length;
 
-       }
 
-       var decoder = new _arithmetic_decoder.ArithmeticDecoder(encodedData, 0, totalLength);
 
-       bitModel.setDecoder(decoder);
 
-       for (j = 0; j < codingpasses; j++) {
 
-         switch (currentCodingpassType) {
 
-           case 0:
 
-             bitModel.runSignificancePropagationPass();
 
-             break;
 
-           case 1:
 
-             bitModel.runMagnitudeRefinementPass();
 
-             break;
 
-           case 2:
 
-             bitModel.runCleanupPass();
 
-             if (segmentationSymbolUsed) {
 
-               bitModel.checkSegmentationSymbol();
 
-             }
 
-             break;
 
-         }
 
-         currentCodingpassType = (currentCodingpassType + 1) % 3;
 
-       }
 
-       var offset = codeblock.tbx0_ - x0 + (codeblock.tby0_ - y0) * width;
 
-       var sign = bitModel.coefficentsSign;
 
-       var magnitude = bitModel.coefficentsMagnitude;
 
-       var bitsDecoded = bitModel.bitsDecoded;
 
-       var magnitudeCorrection = reversible ? 0 : 0.5;
 
-       var k, n, nb;
 
-       position = 0;
 
-       var interleave = subband.type !== "LL";
 
-       for (j = 0; j < blockHeight; j++) {
 
-         var row = offset / width | 0;
 
-         var levelOffset = 2 * row * (levelWidth - width) + right + bottom;
 
-         for (k = 0; k < blockWidth; k++) {
 
-           n = magnitude[position];
 
-           if (n !== 0) {
 
-             n = (n + magnitudeCorrection) * delta;
 
-             if (sign[position] !== 0) {
 
-               n = -n;
 
-             }
 
-             nb = bitsDecoded[position];
 
-             var pos = interleave ? levelOffset + (offset << 1) : offset;
 
-             if (reversible && nb >= mb) {
 
-               coefficients[pos] = n;
 
-             } else {
 
-               coefficients[pos] = n * (1 << mb - nb);
 
-             }
 
-           }
 
-           offset++;
 
-           position++;
 
-         }
 
-         offset += width - blockWidth;
 
-       }
 
-     }
 
-   }
 
-   function transformTile(context, tile, c) {
 
-     var component = tile.components[c];
 
-     var codingStyleParameters = component.codingStyleParameters;
 
-     var quantizationParameters = component.quantizationParameters;
 
-     var decompositionLevelsCount = codingStyleParameters.decompositionLevelsCount;
 
-     var spqcds = quantizationParameters.SPqcds;
 
-     var scalarExpounded = quantizationParameters.scalarExpounded;
 
-     var guardBits = quantizationParameters.guardBits;
 
-     var segmentationSymbolUsed = codingStyleParameters.segmentationSymbolUsed;
 
-     var precision = context.components[c].precision;
 
-     var reversible = codingStyleParameters.reversibleTransformation;
 
-     var transform = reversible ? new ReversibleTransform() : new IrreversibleTransform();
 
-     var subbandCoefficients = [];
 
-     var b = 0;
 
-     for (var i = 0; i <= decompositionLevelsCount; i++) {
 
-       var resolution = component.resolutions[i];
 
-       var width = resolution.trx1 - resolution.trx0;
 
-       var height = resolution.try1 - resolution.try0;
 
-       var coefficients = new Float32Array(width * height);
 
-       for (var j = 0, jj = resolution.subbands.length; j < jj; j++) {
 
-         var mu, epsilon;
 
-         if (!scalarExpounded) {
 
-           mu = spqcds[0].mu;
 
-           epsilon = spqcds[0].epsilon + (i > 0 ? 1 - i : 0);
 
-         } else {
 
-           mu = spqcds[b].mu;
 
-           epsilon = spqcds[b].epsilon;
 
-           b++;
 
-         }
 
-         var subband = resolution.subbands[j];
 
-         var gainLog2 = SubbandsGainLog2[subband.type];
 
-         var delta = reversible ? 1 : 2 ** (precision + gainLog2 - epsilon) * (1 + mu / 2048);
 
-         var mb = guardBits + epsilon - 1;
 
-         copyCoefficients(coefficients, width, height, subband, delta, mb, reversible, segmentationSymbolUsed);
 
-       }
 
-       subbandCoefficients.push({
 
-         width,
 
-         height,
 
-         items: coefficients
 
-       });
 
-     }
 
-     var result = transform.calculate(subbandCoefficients, component.tcx0, component.tcy0);
 
-     return {
 
-       left: component.tcx0,
 
-       top: component.tcy0,
 
-       width: result.width,
 
-       height: result.height,
 
-       items: result.items
 
-     };
 
-   }
 
-   function transformComponents(context) {
 
-     var siz = context.SIZ;
 
-     var components = context.components;
 
-     var componentsCount = siz.Csiz;
 
-     var resultImages = [];
 
-     for (var i = 0, ii = context.tiles.length; i < ii; i++) {
 
-       var tile = context.tiles[i];
 
-       var transformedTiles = [];
 
-       var c;
 
-       for (c = 0; c < componentsCount; c++) {
 
-         transformedTiles[c] = transformTile(context, tile, c);
 
-       }
 
-       var tile0 = transformedTiles[0];
 
-       var out = new Uint8ClampedArray(tile0.items.length * componentsCount);
 
-       var result = {
 
-         left: tile0.left,
 
-         top: tile0.top,
 
-         width: tile0.width,
 
-         height: tile0.height,
 
-         items: out
 
-       };
 
-       var shift, offset;
 
-       var pos = 0,
 
-           j,
 
-           jj,
 
-           y0,
 
-           y1,
 
-           y2;
 
-       if (tile.codingStyleDefaultParameters.multipleComponentTransform) {
 
-         var fourComponents = componentsCount === 4;
 
-         var y0items = transformedTiles[0].items;
 
-         var y1items = transformedTiles[1].items;
 
-         var y2items = transformedTiles[2].items;
 
-         var y3items = fourComponents ? transformedTiles[3].items : null;
 
-         shift = components[0].precision - 8;
 
-         offset = (128 << shift) + 0.5;
 
-         var component0 = tile.components[0];
 
-         var alpha01 = componentsCount - 3;
 
-         jj = y0items.length;
 
-         if (!component0.codingStyleParameters.reversibleTransformation) {
 
-           for (j = 0; j < jj; j++, pos += alpha01) {
 
-             y0 = y0items[j] + offset;
 
-             y1 = y1items[j];
 
-             y2 = y2items[j];
 
-             out[pos++] = y0 + 1.402 * y2 >> shift;
 
-             out[pos++] = y0 - 0.34413 * y1 - 0.71414 * y2 >> shift;
 
-             out[pos++] = y0 + 1.772 * y1 >> shift;
 
-           }
 
-         } else {
 
-           for (j = 0; j < jj; j++, pos += alpha01) {
 
-             y0 = y0items[j] + offset;
 
-             y1 = y1items[j];
 
-             y2 = y2items[j];
 
-             const g = y0 - (y2 + y1 >> 2);
 
-             out[pos++] = g + y2 >> shift;
 
-             out[pos++] = g >> shift;
 
-             out[pos++] = g + y1 >> shift;
 
-           }
 
-         }
 
-         if (fourComponents) {
 
-           for (j = 0, pos = 3; j < jj; j++, pos += 4) {
 
-             out[pos] = y3items[j] + offset >> shift;
 
-           }
 
-         }
 
-       } else {
 
-         for (c = 0; c < componentsCount; c++) {
 
-           var items = transformedTiles[c].items;
 
-           shift = components[c].precision - 8;
 
-           offset = (128 << shift) + 0.5;
 
-           for (pos = c, j = 0, jj = items.length; j < jj; j++) {
 
-             out[pos] = items[j] + offset >> shift;
 
-             pos += componentsCount;
 
-           }
 
-         }
 
-       }
 
-       resultImages.push(result);
 
-     }
 
-     return resultImages;
 
-   }
 
-   function initializeTile(context, tileIndex) {
 
-     var siz = context.SIZ;
 
-     var componentsCount = siz.Csiz;
 
-     var tile = context.tiles[tileIndex];
 
-     for (var c = 0; c < componentsCount; c++) {
 
-       var component = tile.components[c];
 
-       var qcdOrQcc = context.currentTile.QCC[c] !== undefined ? context.currentTile.QCC[c] : context.currentTile.QCD;
 
-       component.quantizationParameters = qcdOrQcc;
 
-       var codOrCoc = context.currentTile.COC[c] !== undefined ? context.currentTile.COC[c] : context.currentTile.COD;
 
-       component.codingStyleParameters = codOrCoc;
 
-     }
 
-     tile.codingStyleDefaultParameters = context.currentTile.COD;
 
-   }
 
-   var TagTree = function TagTreeClosure() {
 
-     function TagTree(width, height) {
 
-       var levelsLength = (0, _core_utils.log2)(Math.max(width, height)) + 1;
 
-       this.levels = [];
 
-       for (var i = 0; i < levelsLength; i++) {
 
-         var level = {
 
-           width,
 
-           height,
 
-           items: []
 
-         };
 
-         this.levels.push(level);
 
-         width = Math.ceil(width / 2);
 
-         height = Math.ceil(height / 2);
 
-       }
 
-     }
 
-     TagTree.prototype = {
 
-       reset: function TagTree_reset(i, j) {
 
-         var currentLevel = 0,
 
-             value = 0,
 
-             level;
 
-         while (currentLevel < this.levels.length) {
 
-           level = this.levels[currentLevel];
 
-           var index = i + j * level.width;
 
-           if (level.items[index] !== undefined) {
 
-             value = level.items[index];
 
-             break;
 
-           }
 
-           level.index = index;
 
-           i >>= 1;
 
-           j >>= 1;
 
-           currentLevel++;
 
-         }
 
-         currentLevel--;
 
-         level = this.levels[currentLevel];
 
-         level.items[level.index] = value;
 
-         this.currentLevel = currentLevel;
 
-         delete this.value;
 
-       },
 
-       incrementValue: function TagTree_incrementValue() {
 
-         var level = this.levels[this.currentLevel];
 
-         level.items[level.index]++;
 
-       },
 
-       nextLevel: function TagTree_nextLevel() {
 
-         var currentLevel = this.currentLevel;
 
-         var level = this.levels[currentLevel];
 
-         var value = level.items[level.index];
 
-         currentLevel--;
 
-         if (currentLevel < 0) {
 
-           this.value = value;
 
-           return false;
 
-         }
 
-         this.currentLevel = currentLevel;
 
-         level = this.levels[currentLevel];
 
-         level.items[level.index] = value;
 
-         return true;
 
-       }
 
-     };
 
-     return TagTree;
 
-   }();
 
-   var InclusionTree = function InclusionTreeClosure() {
 
-     function InclusionTree(width, height, defaultValue) {
 
-       var levelsLength = (0, _core_utils.log2)(Math.max(width, height)) + 1;
 
-       this.levels = [];
 
-       for (var i = 0; i < levelsLength; i++) {
 
-         var items = new Uint8Array(width * height);
 
-         for (var j = 0, jj = items.length; j < jj; j++) {
 
-           items[j] = defaultValue;
 
-         }
 
-         var level = {
 
-           width,
 
-           height,
 
-           items
 
-         };
 
-         this.levels.push(level);
 
-         width = Math.ceil(width / 2);
 
-         height = Math.ceil(height / 2);
 
-       }
 
-     }
 
-     InclusionTree.prototype = {
 
-       reset: function InclusionTree_reset(i, j, stopValue) {
 
-         var currentLevel = 0;
 
-         while (currentLevel < this.levels.length) {
 
-           var level = this.levels[currentLevel];
 
-           var index = i + j * level.width;
 
-           level.index = index;
 
-           var value = level.items[index];
 
-           if (value === 0xff) {
 
-             break;
 
-           }
 
-           if (value > stopValue) {
 
-             this.currentLevel = currentLevel;
 
-             this.propagateValues();
 
-             return false;
 
-           }
 
-           i >>= 1;
 
-           j >>= 1;
 
-           currentLevel++;
 
-         }
 
-         this.currentLevel = currentLevel - 1;
 
-         return true;
 
-       },
 
-       incrementValue: function InclusionTree_incrementValue(stopValue) {
 
-         var level = this.levels[this.currentLevel];
 
-         level.items[level.index] = stopValue + 1;
 
-         this.propagateValues();
 
-       },
 
-       propagateValues: function InclusionTree_propagateValues() {
 
-         var levelIndex = this.currentLevel;
 
-         var level = this.levels[levelIndex];
 
-         var currentValue = level.items[level.index];
 
-         while (--levelIndex >= 0) {
 
-           level = this.levels[levelIndex];
 
-           level.items[level.index] = currentValue;
 
-         }
 
-       },
 
-       nextLevel: function InclusionTree_nextLevel() {
 
-         var currentLevel = this.currentLevel;
 
-         var level = this.levels[currentLevel];
 
-         var value = level.items[level.index];
 
-         level.items[level.index] = 0xff;
 
-         currentLevel--;
 
-         if (currentLevel < 0) {
 
-           return false;
 
-         }
 
-         this.currentLevel = currentLevel;
 
-         level = this.levels[currentLevel];
 
-         level.items[level.index] = value;
 
-         return true;
 
-       }
 
-     };
 
-     return InclusionTree;
 
-   }();
 
-   var BitModel = function BitModelClosure() {
 
-     var UNIFORM_CONTEXT = 17;
 
-     var RUNLENGTH_CONTEXT = 18;
 
-     var LLAndLHContextsLabel = new Uint8Array([0, 5, 8, 0, 3, 7, 8, 0, 4, 7, 8, 0, 0, 0, 0, 0, 1, 6, 8, 0, 3, 7, 8, 0, 4, 7, 8, 0, 0, 0, 0, 0, 2, 6, 8, 0, 3, 7, 8, 0, 4, 7, 8, 0, 0, 0, 0, 0, 2, 6, 8, 0, 3, 7, 8, 0, 4, 7, 8, 0, 0, 0, 0, 0, 2, 6, 8, 0, 3, 7, 8, 0, 4, 7, 8]);
 
-     var HLContextLabel = new Uint8Array([0, 3, 4, 0, 5, 7, 7, 0, 8, 8, 8, 0, 0, 0, 0, 0, 1, 3, 4, 0, 6, 7, 7, 0, 8, 8, 8, 0, 0, 0, 0, 0, 2, 3, 4, 0, 6, 7, 7, 0, 8, 8, 8, 0, 0, 0, 0, 0, 2, 3, 4, 0, 6, 7, 7, 0, 8, 8, 8, 0, 0, 0, 0, 0, 2, 3, 4, 0, 6, 7, 7, 0, 8, 8, 8]);
 
-     var HHContextLabel = new Uint8Array([0, 1, 2, 0, 1, 2, 2, 0, 2, 2, 2, 0, 0, 0, 0, 0, 3, 4, 5, 0, 4, 5, 5, 0, 5, 5, 5, 0, 0, 0, 0, 0, 6, 7, 7, 0, 7, 7, 7, 0, 7, 7, 7, 0, 0, 0, 0, 0, 8, 8, 8, 0, 8, 8, 8, 0, 8, 8, 8, 0, 0, 0, 0, 0, 8, 8, 8, 0, 8, 8, 8, 0, 8, 8, 8]);
 
-     function BitModel(width, height, subband, zeroBitPlanes, mb) {
 
-       this.width = width;
 
-       this.height = height;
 
-       let contextLabelTable;
 
-       if (subband === "HH") {
 
-         contextLabelTable = HHContextLabel;
 
-       } else if (subband === "HL") {
 
-         contextLabelTable = HLContextLabel;
 
-       } else {
 
-         contextLabelTable = LLAndLHContextsLabel;
 
-       }
 
-       this.contextLabelTable = contextLabelTable;
 
-       var coefficientCount = width * height;
 
-       this.neighborsSignificance = new Uint8Array(coefficientCount);
 
-       this.coefficentsSign = new Uint8Array(coefficientCount);
 
-       let coefficentsMagnitude;
 
-       if (mb > 14) {
 
-         coefficentsMagnitude = new Uint32Array(coefficientCount);
 
-       } else if (mb > 6) {
 
-         coefficentsMagnitude = new Uint16Array(coefficientCount);
 
-       } else {
 
-         coefficentsMagnitude = new Uint8Array(coefficientCount);
 
-       }
 
-       this.coefficentsMagnitude = coefficentsMagnitude;
 
-       this.processingFlags = new Uint8Array(coefficientCount);
 
-       var bitsDecoded = new Uint8Array(coefficientCount);
 
-       if (zeroBitPlanes !== 0) {
 
-         for (var i = 0; i < coefficientCount; i++) {
 
-           bitsDecoded[i] = zeroBitPlanes;
 
-         }
 
-       }
 
-       this.bitsDecoded = bitsDecoded;
 
-       this.reset();
 
-     }
 
-     BitModel.prototype = {
 
-       setDecoder: function BitModel_setDecoder(decoder) {
 
-         this.decoder = decoder;
 
-       },
 
-       reset: function BitModel_reset() {
 
-         this.contexts = new Int8Array(19);
 
-         this.contexts[0] = 4 << 1 | 0;
 
-         this.contexts[UNIFORM_CONTEXT] = 46 << 1 | 0;
 
-         this.contexts[RUNLENGTH_CONTEXT] = 3 << 1 | 0;
 
-       },
 
-       setNeighborsSignificance: function BitModel_setNeighborsSignificance(row, column, index) {
 
-         var neighborsSignificance = this.neighborsSignificance;
 
-         var width = this.width,
 
-             height = this.height;
 
-         var left = column > 0;
 
-         var right = column + 1 < width;
 
-         var i;
 
-         if (row > 0) {
 
-           i = index - width;
 
-           if (left) {
 
-             neighborsSignificance[i - 1] += 0x10;
 
-           }
 
-           if (right) {
 
-             neighborsSignificance[i + 1] += 0x10;
 
-           }
 
-           neighborsSignificance[i] += 0x04;
 
-         }
 
-         if (row + 1 < height) {
 
-           i = index + width;
 
-           if (left) {
 
-             neighborsSignificance[i - 1] += 0x10;
 
-           }
 
-           if (right) {
 
-             neighborsSignificance[i + 1] += 0x10;
 
-           }
 
-           neighborsSignificance[i] += 0x04;
 
-         }
 
-         if (left) {
 
-           neighborsSignificance[index - 1] += 0x01;
 
-         }
 
-         if (right) {
 
-           neighborsSignificance[index + 1] += 0x01;
 
-         }
 
-         neighborsSignificance[index] |= 0x80;
 
-       },
 
-       runSignificancePropagationPass: function BitModel_runSignificancePropagationPass() {
 
-         var decoder = this.decoder;
 
-         var width = this.width,
 
-             height = this.height;
 
-         var coefficentsMagnitude = this.coefficentsMagnitude;
 
-         var coefficentsSign = this.coefficentsSign;
 
-         var neighborsSignificance = this.neighborsSignificance;
 
-         var processingFlags = this.processingFlags;
 
-         var contexts = this.contexts;
 
-         var labels = this.contextLabelTable;
 
-         var bitsDecoded = this.bitsDecoded;
 
-         var processedInverseMask = ~1;
 
-         var processedMask = 1;
 
-         var firstMagnitudeBitMask = 2;
 
-         for (var i0 = 0; i0 < height; i0 += 4) {
 
-           for (var j = 0; j < width; j++) {
 
-             var index = i0 * width + j;
 
-             for (var i1 = 0; i1 < 4; i1++, index += width) {
 
-               var i = i0 + i1;
 
-               if (i >= height) {
 
-                 break;
 
-               }
 
-               processingFlags[index] &= processedInverseMask;
 
-               if (coefficentsMagnitude[index] || !neighborsSignificance[index]) {
 
-                 continue;
 
-               }
 
-               var contextLabel = labels[neighborsSignificance[index]];
 
-               var decision = decoder.readBit(contexts, contextLabel);
 
-               if (decision) {
 
-                 var sign = this.decodeSignBit(i, j, index);
 
-                 coefficentsSign[index] = sign;
 
-                 coefficentsMagnitude[index] = 1;
 
-                 this.setNeighborsSignificance(i, j, index);
 
-                 processingFlags[index] |= firstMagnitudeBitMask;
 
-               }
 
-               bitsDecoded[index]++;
 
-               processingFlags[index] |= processedMask;
 
-             }
 
-           }
 
-         }
 
-       },
 
-       decodeSignBit: function BitModel_decodeSignBit(row, column, index) {
 
-         var width = this.width,
 
-             height = this.height;
 
-         var coefficentsMagnitude = this.coefficentsMagnitude;
 
-         var coefficentsSign = this.coefficentsSign;
 
-         var contribution, sign0, sign1, significance1;
 
-         var contextLabel, decoded;
 
-         significance1 = column > 0 && coefficentsMagnitude[index - 1] !== 0;
 
-         if (column + 1 < width && coefficentsMagnitude[index + 1] !== 0) {
 
-           sign1 = coefficentsSign[index + 1];
 
-           if (significance1) {
 
-             sign0 = coefficentsSign[index - 1];
 
-             contribution = 1 - sign1 - sign0;
 
-           } else {
 
-             contribution = 1 - sign1 - sign1;
 
-           }
 
-         } else if (significance1) {
 
-           sign0 = coefficentsSign[index - 1];
 
-           contribution = 1 - sign0 - sign0;
 
-         } else {
 
-           contribution = 0;
 
-         }
 
-         var horizontalContribution = 3 * contribution;
 
-         significance1 = row > 0 && coefficentsMagnitude[index - width] !== 0;
 
-         if (row + 1 < height && coefficentsMagnitude[index + width] !== 0) {
 
-           sign1 = coefficentsSign[index + width];
 
-           if (significance1) {
 
-             sign0 = coefficentsSign[index - width];
 
-             contribution = 1 - sign1 - sign0 + horizontalContribution;
 
-           } else {
 
-             contribution = 1 - sign1 - sign1 + horizontalContribution;
 
-           }
 
-         } else if (significance1) {
 
-           sign0 = coefficentsSign[index - width];
 
-           contribution = 1 - sign0 - sign0 + horizontalContribution;
 
-         } else {
 
-           contribution = horizontalContribution;
 
-         }
 
-         if (contribution >= 0) {
 
-           contextLabel = 9 + contribution;
 
-           decoded = this.decoder.readBit(this.contexts, contextLabel);
 
-         } else {
 
-           contextLabel = 9 - contribution;
 
-           decoded = this.decoder.readBit(this.contexts, contextLabel) ^ 1;
 
-         }
 
-         return decoded;
 
-       },
 
-       runMagnitudeRefinementPass: function BitModel_runMagnitudeRefinementPass() {
 
-         var decoder = this.decoder;
 
-         var width = this.width,
 
-             height = this.height;
 
-         var coefficentsMagnitude = this.coefficentsMagnitude;
 
-         var neighborsSignificance = this.neighborsSignificance;
 
-         var contexts = this.contexts;
 
-         var bitsDecoded = this.bitsDecoded;
 
-         var processingFlags = this.processingFlags;
 
-         var processedMask = 1;
 
-         var firstMagnitudeBitMask = 2;
 
-         var length = width * height;
 
-         var width4 = width * 4;
 
-         for (var index0 = 0, indexNext; index0 < length; index0 = indexNext) {
 
-           indexNext = Math.min(length, index0 + width4);
 
-           for (var j = 0; j < width; j++) {
 
-             for (var index = index0 + j; index < indexNext; index += width) {
 
-               if (!coefficentsMagnitude[index] || (processingFlags[index] & processedMask) !== 0) {
 
-                 continue;
 
-               }
 
-               var contextLabel = 16;
 
-               if ((processingFlags[index] & firstMagnitudeBitMask) !== 0) {
 
-                 processingFlags[index] ^= firstMagnitudeBitMask;
 
-                 var significance = neighborsSignificance[index] & 127;
 
-                 contextLabel = significance === 0 ? 15 : 14;
 
-               }
 
-               var bit = decoder.readBit(contexts, contextLabel);
 
-               coefficentsMagnitude[index] = coefficentsMagnitude[index] << 1 | bit;
 
-               bitsDecoded[index]++;
 
-               processingFlags[index] |= processedMask;
 
-             }
 
-           }
 
-         }
 
-       },
 
-       runCleanupPass: function BitModel_runCleanupPass() {
 
-         var decoder = this.decoder;
 
-         var width = this.width,
 
-             height = this.height;
 
-         var neighborsSignificance = this.neighborsSignificance;
 
-         var coefficentsMagnitude = this.coefficentsMagnitude;
 
-         var coefficentsSign = this.coefficentsSign;
 
-         var contexts = this.contexts;
 
-         var labels = this.contextLabelTable;
 
-         var bitsDecoded = this.bitsDecoded;
 
-         var processingFlags = this.processingFlags;
 
-         var processedMask = 1;
 
-         var firstMagnitudeBitMask = 2;
 
-         var oneRowDown = width;
 
-         var twoRowsDown = width * 2;
 
-         var threeRowsDown = width * 3;
 
-         var iNext;
 
-         for (var i0 = 0; i0 < height; i0 = iNext) {
 
-           iNext = Math.min(i0 + 4, height);
 
-           var indexBase = i0 * width;
 
-           var checkAllEmpty = i0 + 3 < height;
 
-           for (var j = 0; j < width; j++) {
 
-             var index0 = indexBase + j;
 
-             var allEmpty = checkAllEmpty && processingFlags[index0] === 0 && processingFlags[index0 + oneRowDown] === 0 && processingFlags[index0 + twoRowsDown] === 0 && processingFlags[index0 + threeRowsDown] === 0 && neighborsSignificance[index0] === 0 && neighborsSignificance[index0 + oneRowDown] === 0 && neighborsSignificance[index0 + twoRowsDown] === 0 && neighborsSignificance[index0 + threeRowsDown] === 0;
 
-             var i1 = 0,
 
-                 index = index0;
 
-             var i = i0,
 
-                 sign;
 
-             if (allEmpty) {
 
-               var hasSignificantCoefficent = decoder.readBit(contexts, RUNLENGTH_CONTEXT);
 
-               if (!hasSignificantCoefficent) {
 
-                 bitsDecoded[index0]++;
 
-                 bitsDecoded[index0 + oneRowDown]++;
 
-                 bitsDecoded[index0 + twoRowsDown]++;
 
-                 bitsDecoded[index0 + threeRowsDown]++;
 
-                 continue;
 
-               }
 
-               i1 = decoder.readBit(contexts, UNIFORM_CONTEXT) << 1 | decoder.readBit(contexts, UNIFORM_CONTEXT);
 
-               if (i1 !== 0) {
 
-                 i = i0 + i1;
 
-                 index += i1 * width;
 
-               }
 
-               sign = this.decodeSignBit(i, j, index);
 
-               coefficentsSign[index] = sign;
 
-               coefficentsMagnitude[index] = 1;
 
-               this.setNeighborsSignificance(i, j, index);
 
-               processingFlags[index] |= firstMagnitudeBitMask;
 
-               index = index0;
 
-               for (var i2 = i0; i2 <= i; i2++, index += width) {
 
-                 bitsDecoded[index]++;
 
-               }
 
-               i1++;
 
-             }
 
-             for (i = i0 + i1; i < iNext; i++, index += width) {
 
-               if (coefficentsMagnitude[index] || (processingFlags[index] & processedMask) !== 0) {
 
-                 continue;
 
-               }
 
-               var contextLabel = labels[neighborsSignificance[index]];
 
-               var decision = decoder.readBit(contexts, contextLabel);
 
-               if (decision === 1) {
 
-                 sign = this.decodeSignBit(i, j, index);
 
-                 coefficentsSign[index] = sign;
 
-                 coefficentsMagnitude[index] = 1;
 
-                 this.setNeighborsSignificance(i, j, index);
 
-                 processingFlags[index] |= firstMagnitudeBitMask;
 
-               }
 
-               bitsDecoded[index]++;
 
-             }
 
-           }
 
-         }
 
-       },
 
-       checkSegmentationSymbol: function BitModel_checkSegmentationSymbol() {
 
-         var decoder = this.decoder;
 
-         var contexts = this.contexts;
 
-         var symbol = decoder.readBit(contexts, UNIFORM_CONTEXT) << 3 | decoder.readBit(contexts, UNIFORM_CONTEXT) << 2 | decoder.readBit(contexts, UNIFORM_CONTEXT) << 1 | decoder.readBit(contexts, UNIFORM_CONTEXT);
 
-         if (symbol !== 0xa) {
 
-           throw new JpxError("Invalid segmentation symbol");
 
-         }
 
-       }
 
-     };
 
-     return BitModel;
 
-   }();
 
-   var Transform = function TransformClosure() {
 
-     function Transform() {}
 
-     Transform.prototype.calculate = function transformCalculate(subbands, u0, v0) {
 
-       var ll = subbands[0];
 
-       for (var i = 1, ii = subbands.length; i < ii; i++) {
 
-         ll = this.iterate(ll, subbands[i], u0, v0);
 
-       }
 
-       return ll;
 
-     };
 
-     Transform.prototype.extend = function extend(buffer, offset, size) {
 
-       var i1 = offset - 1,
 
-           j1 = offset + 1;
 
-       var i2 = offset + size - 2,
 
-           j2 = offset + size;
 
-       buffer[i1--] = buffer[j1++];
 
-       buffer[j2++] = buffer[i2--];
 
-       buffer[i1--] = buffer[j1++];
 
-       buffer[j2++] = buffer[i2--];
 
-       buffer[i1--] = buffer[j1++];
 
-       buffer[j2++] = buffer[i2--];
 
-       buffer[i1] = buffer[j1];
 
-       buffer[j2] = buffer[i2];
 
-     };
 
-     Transform.prototype.iterate = function Transform_iterate(ll, hl_lh_hh, u0, v0) {
 
-       var llWidth = ll.width,
 
-           llHeight = ll.height,
 
-           llItems = ll.items;
 
-       var width = hl_lh_hh.width;
 
-       var height = hl_lh_hh.height;
 
-       var items = hl_lh_hh.items;
 
-       var i, j, k, l, u, v;
 
-       for (k = 0, i = 0; i < llHeight; i++) {
 
-         l = i * 2 * width;
 
-         for (j = 0; j < llWidth; j++, k++, l += 2) {
 
-           items[l] = llItems[k];
 
-         }
 
-       }
 
-       llItems = ll.items = null;
 
-       var bufferPadding = 4;
 
-       var rowBuffer = new Float32Array(width + 2 * bufferPadding);
 
-       if (width === 1) {
 
-         if ((u0 & 1) !== 0) {
 
-           for (v = 0, k = 0; v < height; v++, k += width) {
 
-             items[k] *= 0.5;
 
-           }
 
-         }
 
-       } else {
 
-         for (v = 0, k = 0; v < height; v++, k += width) {
 
-           rowBuffer.set(items.subarray(k, k + width), bufferPadding);
 
-           this.extend(rowBuffer, bufferPadding, width);
 
-           this.filter(rowBuffer, bufferPadding, width);
 
-           items.set(rowBuffer.subarray(bufferPadding, bufferPadding + width), k);
 
-         }
 
-       }
 
-       var numBuffers = 16;
 
-       var colBuffers = [];
 
-       for (i = 0; i < numBuffers; i++) {
 
-         colBuffers.push(new Float32Array(height + 2 * bufferPadding));
 
-       }
 
-       var b,
 
-           currentBuffer = 0;
 
-       ll = bufferPadding + height;
 
-       if (height === 1) {
 
-         if ((v0 & 1) !== 0) {
 
-           for (u = 0; u < width; u++) {
 
-             items[u] *= 0.5;
 
-           }
 
-         }
 
-       } else {
 
-         for (u = 0; u < width; u++) {
 
-           if (currentBuffer === 0) {
 
-             numBuffers = Math.min(width - u, numBuffers);
 
-             for (k = u, l = bufferPadding; l < ll; k += width, l++) {
 
-               for (b = 0; b < numBuffers; b++) {
 
-                 colBuffers[b][l] = items[k + b];
 
-               }
 
-             }
 
-             currentBuffer = numBuffers;
 
-           }
 
-           currentBuffer--;
 
-           var buffer = colBuffers[currentBuffer];
 
-           this.extend(buffer, bufferPadding, height);
 
-           this.filter(buffer, bufferPadding, height);
 
-           if (currentBuffer === 0) {
 
-             k = u - numBuffers + 1;
 
-             for (l = bufferPadding; l < ll; k += width, l++) {
 
-               for (b = 0; b < numBuffers; b++) {
 
-                 items[k + b] = colBuffers[b][l];
 
-               }
 
-             }
 
-           }
 
-         }
 
-       }
 
-       return {
 
-         width,
 
-         height,
 
-         items
 
-       };
 
-     };
 
-     return Transform;
 
-   }();
 
-   var IrreversibleTransform = function IrreversibleTransformClosure() {
 
-     function IrreversibleTransform() {
 
-       Transform.call(this);
 
-     }
 
-     IrreversibleTransform.prototype = Object.create(Transform.prototype);
 
-     IrreversibleTransform.prototype.filter = function irreversibleTransformFilter(x, offset, length) {
 
-       var len = length >> 1;
 
-       offset = offset | 0;
 
-       var j, n, current, next;
 
-       var alpha = -1.586134342059924;
 
-       var beta = -0.052980118572961;
 
-       var gamma = 0.882911075530934;
 
-       var delta = 0.443506852043971;
 
-       var K = 1.230174104914001;
 
-       var K_ = 1 / K;
 
-       j = offset - 3;
 
-       for (n = len + 4; n--; j += 2) {
 
-         x[j] *= K_;
 
-       }
 
-       j = offset - 2;
 
-       current = delta * x[j - 1];
 
-       for (n = len + 3; n--; j += 2) {
 
-         next = delta * x[j + 1];
 
-         x[j] = K * x[j] - current - next;
 
-         if (n--) {
 
-           j += 2;
 
-           current = delta * x[j + 1];
 
-           x[j] = K * x[j] - current - next;
 
-         } else {
 
-           break;
 
-         }
 
-       }
 
-       j = offset - 1;
 
-       current = gamma * x[j - 1];
 
-       for (n = len + 2; n--; j += 2) {
 
-         next = gamma * x[j + 1];
 
-         x[j] -= current + next;
 
-         if (n--) {
 
-           j += 2;
 
-           current = gamma * x[j + 1];
 
-           x[j] -= current + next;
 
-         } else {
 
-           break;
 
-         }
 
-       }
 
-       j = offset;
 
-       current = beta * x[j - 1];
 
-       for (n = len + 1; n--; j += 2) {
 
-         next = beta * x[j + 1];
 
-         x[j] -= current + next;
 
-         if (n--) {
 
-           j += 2;
 
-           current = beta * x[j + 1];
 
-           x[j] -= current + next;
 
-         } else {
 
-           break;
 
-         }
 
-       }
 
-       if (len !== 0) {
 
-         j = offset + 1;
 
-         current = alpha * x[j - 1];
 
-         for (n = len; n--; j += 2) {
 
-           next = alpha * x[j + 1];
 
-           x[j] -= current + next;
 
-           if (n--) {
 
-             j += 2;
 
-             current = alpha * x[j + 1];
 
-             x[j] -= current + next;
 
-           } else {
 
-             break;
 
-           }
 
-         }
 
-       }
 
-     };
 
-     return IrreversibleTransform;
 
-   }();
 
-   var ReversibleTransform = function ReversibleTransformClosure() {
 
-     function ReversibleTransform() {
 
-       Transform.call(this);
 
-     }
 
-     ReversibleTransform.prototype = Object.create(Transform.prototype);
 
-     ReversibleTransform.prototype.filter = function reversibleTransformFilter(x, offset, length) {
 
-       var len = length >> 1;
 
-       offset = offset | 0;
 
-       var j, n;
 
-       for (j = offset, n = len + 1; n--; j += 2) {
 
-         x[j] -= x[j - 1] + x[j + 1] + 2 >> 2;
 
-       }
 
-       for (j = offset + 1, n = len; n--; j += 2) {
 
-         x[j] += x[j - 1] + x[j + 1] >> 1;
 
-       }
 
-     };
 
-     return ReversibleTransform;
 
-   }();
 
-   return JpxImage;
 
- }();
 
- exports.JpxImage = JpxImage;
 
- /***/ }),
 
- /* 21 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.calculateSHA512 = exports.calculateSHA384 = exports.calculateSHA256 = exports.calculateMD5 = exports.PDF20 = exports.PDF17 = exports.CipherTransformFactory = exports.ARCFourCipher = exports.AES256Cipher = exports.AES128Cipher = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _stream = __w_pdfjs_require__(11);
 
- var ARCFourCipher = function ARCFourCipherClosure() {
 
-   function ARCFourCipher(key) {
 
-     this.a = 0;
 
-     this.b = 0;
 
-     var s = new Uint8Array(256);
 
-     var i,
 
-         j = 0,
 
-         tmp,
 
-         keyLength = key.length;
 
-     for (i = 0; i < 256; ++i) {
 
-       s[i] = i;
 
-     }
 
-     for (i = 0; i < 256; ++i) {
 
-       tmp = s[i];
 
-       j = j + tmp + key[i % keyLength] & 0xff;
 
-       s[i] = s[j];
 
-       s[j] = tmp;
 
-     }
 
-     this.s = s;
 
-   }
 
-   ARCFourCipher.prototype = {
 
-     encryptBlock: function ARCFourCipher_encryptBlock(data) {
 
-       var i,
 
-           n = data.length,
 
-           tmp,
 
-           tmp2;
 
-       var a = this.a,
 
-           b = this.b,
 
-           s = this.s;
 
-       var output = new Uint8Array(n);
 
-       for (i = 0; i < n; ++i) {
 
-         a = a + 1 & 0xff;
 
-         tmp = s[a];
 
-         b = b + tmp & 0xff;
 
-         tmp2 = s[b];
 
-         s[a] = tmp2;
 
-         s[b] = tmp;
 
-         output[i] = data[i] ^ s[tmp + tmp2 & 0xff];
 
-       }
 
-       this.a = a;
 
-       this.b = b;
 
-       return output;
 
-     }
 
-   };
 
-   ARCFourCipher.prototype.decryptBlock = ARCFourCipher.prototype.encryptBlock;
 
-   return ARCFourCipher;
 
- }();
 
- exports.ARCFourCipher = ARCFourCipher;
 
- var calculateMD5 = function calculateMD5Closure() {
 
-   var r = new Uint8Array([7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21]);
 
-   var k = new Int32Array([-680876936, -389564586, 606105819, -1044525330, -176418897, 1200080426, -1473231341, -45705983, 1770035416, -1958414417, -42063, -1990404162, 1804603682, -40341101, -1502002290, 1236535329, -165796510, -1069501632, 643717713, -373897302, -701558691, 38016083, -660478335, -405537848, 568446438, -1019803690, -187363961, 1163531501, -1444681467, -51403784, 1735328473, -1926607734, -378558, -2022574463, 1839030562, -35309556, -1530992060, 1272893353, -155497632, -1094730640, 681279174, -358537222, -722521979, 76029189, -640364487, -421815835, 530742520, -995338651, -198630844, 1126891415, -1416354905, -57434055, 1700485571, -1894986606, -1051523, -2054922799, 1873313359, -30611744, -1560198380, 1309151649, -145523070, -1120210379, 718787259, -343485551]);
 
-   function hash(data, offset, length) {
 
-     var h0 = 1732584193,
 
-         h1 = -271733879,
 
-         h2 = -1732584194,
 
-         h3 = 271733878;
 
-     var paddedLength = length + 72 & ~63;
 
-     var padded = new Uint8Array(paddedLength);
 
-     var i, j, n;
 
-     for (i = 0; i < length; ++i) {
 
-       padded[i] = data[offset++];
 
-     }
 
-     padded[i++] = 0x80;
 
-     n = paddedLength - 8;
 
-     while (i < n) {
 
-       padded[i++] = 0;
 
-     }
 
-     padded[i++] = length << 3 & 0xff;
 
-     padded[i++] = length >> 5 & 0xff;
 
-     padded[i++] = length >> 13 & 0xff;
 
-     padded[i++] = length >> 21 & 0xff;
 
-     padded[i++] = length >>> 29 & 0xff;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     var w = new Int32Array(16);
 
-     for (i = 0; i < paddedLength;) {
 
-       for (j = 0; j < 16; ++j, i += 4) {
 
-         w[j] = padded[i] | padded[i + 1] << 8 | padded[i + 2] << 16 | padded[i + 3] << 24;
 
-       }
 
-       var a = h0,
 
-           b = h1,
 
-           c = h2,
 
-           d = h3,
 
-           f,
 
-           g;
 
-       for (j = 0; j < 64; ++j) {
 
-         if (j < 16) {
 
-           f = b & c | ~b & d;
 
-           g = j;
 
-         } else if (j < 32) {
 
-           f = d & b | ~d & c;
 
-           g = 5 * j + 1 & 15;
 
-         } else if (j < 48) {
 
-           f = b ^ c ^ d;
 
-           g = 3 * j + 5 & 15;
 
-         } else {
 
-           f = c ^ (b | ~d);
 
-           g = 7 * j & 15;
 
-         }
 
-         var tmp = d,
 
-             rotateArg = a + f + k[j] + w[g] | 0,
 
-             rotate = r[j];
 
-         d = c;
 
-         c = b;
 
-         b = b + (rotateArg << rotate | rotateArg >>> 32 - rotate) | 0;
 
-         a = tmp;
 
-       }
 
-       h0 = h0 + a | 0;
 
-       h1 = h1 + b | 0;
 
-       h2 = h2 + c | 0;
 
-       h3 = h3 + d | 0;
 
-     }
 
-     return new Uint8Array([h0 & 0xFF, h0 >> 8 & 0xFF, h0 >> 16 & 0xFF, h0 >>> 24 & 0xFF, h1 & 0xFF, h1 >> 8 & 0xFF, h1 >> 16 & 0xFF, h1 >>> 24 & 0xFF, h2 & 0xFF, h2 >> 8 & 0xFF, h2 >> 16 & 0xFF, h2 >>> 24 & 0xFF, h3 & 0xFF, h3 >> 8 & 0xFF, h3 >> 16 & 0xFF, h3 >>> 24 & 0xFF]);
 
-   }
 
-   return hash;
 
- }();
 
- exports.calculateMD5 = calculateMD5;
 
- var Word64 = function Word64Closure() {
 
-   function Word64(highInteger, lowInteger) {
 
-     this.high = highInteger | 0;
 
-     this.low = lowInteger | 0;
 
-   }
 
-   Word64.prototype = {
 
-     and: function Word64_and(word) {
 
-       this.high &= word.high;
 
-       this.low &= word.low;
 
-     },
 
-     xor: function Word64_xor(word) {
 
-       this.high ^= word.high;
 
-       this.low ^= word.low;
 
-     },
 
-     or: function Word64_or(word) {
 
-       this.high |= word.high;
 
-       this.low |= word.low;
 
-     },
 
-     shiftRight: function Word64_shiftRight(places) {
 
-       if (places >= 32) {
 
-         this.low = this.high >>> places - 32 | 0;
 
-         this.high = 0;
 
-       } else {
 
-         this.low = this.low >>> places | this.high << 32 - places;
 
-         this.high = this.high >>> places | 0;
 
-       }
 
-     },
 
-     shiftLeft: function Word64_shiftLeft(places) {
 
-       if (places >= 32) {
 
-         this.high = this.low << places - 32;
 
-         this.low = 0;
 
-       } else {
 
-         this.high = this.high << places | this.low >>> 32 - places;
 
-         this.low = this.low << places;
 
-       }
 
-     },
 
-     rotateRight: function Word64_rotateRight(places) {
 
-       var low, high;
 
-       if (places & 32) {
 
-         high = this.low;
 
-         low = this.high;
 
-       } else {
 
-         low = this.low;
 
-         high = this.high;
 
-       }
 
-       places &= 31;
 
-       this.low = low >>> places | high << 32 - places;
 
-       this.high = high >>> places | low << 32 - places;
 
-     },
 
-     not: function Word64_not() {
 
-       this.high = ~this.high;
 
-       this.low = ~this.low;
 
-     },
 
-     add: function Word64_add(word) {
 
-       var lowAdd = (this.low >>> 0) + (word.low >>> 0);
 
-       var highAdd = (this.high >>> 0) + (word.high >>> 0);
 
-       if (lowAdd > 0xffffffff) {
 
-         highAdd += 1;
 
-       }
 
-       this.low = lowAdd | 0;
 
-       this.high = highAdd | 0;
 
-     },
 
-     copyTo: function Word64_copyTo(bytes, offset) {
 
-       bytes[offset] = this.high >>> 24 & 0xff;
 
-       bytes[offset + 1] = this.high >> 16 & 0xff;
 
-       bytes[offset + 2] = this.high >> 8 & 0xff;
 
-       bytes[offset + 3] = this.high & 0xff;
 
-       bytes[offset + 4] = this.low >>> 24 & 0xff;
 
-       bytes[offset + 5] = this.low >> 16 & 0xff;
 
-       bytes[offset + 6] = this.low >> 8 & 0xff;
 
-       bytes[offset + 7] = this.low & 0xff;
 
-     },
 
-     assign: function Word64_assign(word) {
 
-       this.high = word.high;
 
-       this.low = word.low;
 
-     }
 
-   };
 
-   return Word64;
 
- }();
 
- var calculateSHA256 = function calculateSHA256Closure() {
 
-   function rotr(x, n) {
 
-     return x >>> n | x << 32 - n;
 
-   }
 
-   function ch(x, y, z) {
 
-     return x & y ^ ~x & z;
 
-   }
 
-   function maj(x, y, z) {
 
-     return x & y ^ x & z ^ y & z;
 
-   }
 
-   function sigma(x) {
 
-     return rotr(x, 2) ^ rotr(x, 13) ^ rotr(x, 22);
 
-   }
 
-   function sigmaPrime(x) {
 
-     return rotr(x, 6) ^ rotr(x, 11) ^ rotr(x, 25);
 
-   }
 
-   function littleSigma(x) {
 
-     return rotr(x, 7) ^ rotr(x, 18) ^ x >>> 3;
 
-   }
 
-   function littleSigmaPrime(x) {
 
-     return rotr(x, 17) ^ rotr(x, 19) ^ x >>> 10;
 
-   }
 
-   var k = [0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2];
 
-   function hash(data, offset, length) {
 
-     var h0 = 0x6a09e667,
 
-         h1 = 0xbb67ae85,
 
-         h2 = 0x3c6ef372,
 
-         h3 = 0xa54ff53a,
 
-         h4 = 0x510e527f,
 
-         h5 = 0x9b05688c,
 
-         h6 = 0x1f83d9ab,
 
-         h7 = 0x5be0cd19;
 
-     var paddedLength = Math.ceil((length + 9) / 64) * 64;
 
-     var padded = new Uint8Array(paddedLength);
 
-     var i, j, n;
 
-     for (i = 0; i < length; ++i) {
 
-       padded[i] = data[offset++];
 
-     }
 
-     padded[i++] = 0x80;
 
-     n = paddedLength - 8;
 
-     while (i < n) {
 
-       padded[i++] = 0;
 
-     }
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = length >>> 29 & 0xff;
 
-     padded[i++] = length >> 21 & 0xff;
 
-     padded[i++] = length >> 13 & 0xff;
 
-     padded[i++] = length >> 5 & 0xff;
 
-     padded[i++] = length << 3 & 0xff;
 
-     var w = new Uint32Array(64);
 
-     for (i = 0; i < paddedLength;) {
 
-       for (j = 0; j < 16; ++j) {
 
-         w[j] = padded[i] << 24 | padded[i + 1] << 16 | padded[i + 2] << 8 | padded[i + 3];
 
-         i += 4;
 
-       }
 
-       for (j = 16; j < 64; ++j) {
 
-         w[j] = littleSigmaPrime(w[j - 2]) + w[j - 7] + littleSigma(w[j - 15]) + w[j - 16] | 0;
 
-       }
 
-       var a = h0,
 
-           b = h1,
 
-           c = h2,
 
-           d = h3,
 
-           e = h4,
 
-           f = h5,
 
-           g = h6,
 
-           h = h7,
 
-           t1,
 
-           t2;
 
-       for (j = 0; j < 64; ++j) {
 
-         t1 = h + sigmaPrime(e) + ch(e, f, g) + k[j] + w[j];
 
-         t2 = sigma(a) + maj(a, b, c);
 
-         h = g;
 
-         g = f;
 
-         f = e;
 
-         e = d + t1 | 0;
 
-         d = c;
 
-         c = b;
 
-         b = a;
 
-         a = t1 + t2 | 0;
 
-       }
 
-       h0 = h0 + a | 0;
 
-       h1 = h1 + b | 0;
 
-       h2 = h2 + c | 0;
 
-       h3 = h3 + d | 0;
 
-       h4 = h4 + e | 0;
 
-       h5 = h5 + f | 0;
 
-       h6 = h6 + g | 0;
 
-       h7 = h7 + h | 0;
 
-     }
 
-     return new Uint8Array([h0 >> 24 & 0xFF, h0 >> 16 & 0xFF, h0 >> 8 & 0xFF, h0 & 0xFF, h1 >> 24 & 0xFF, h1 >> 16 & 0xFF, h1 >> 8 & 0xFF, h1 & 0xFF, h2 >> 24 & 0xFF, h2 >> 16 & 0xFF, h2 >> 8 & 0xFF, h2 & 0xFF, h3 >> 24 & 0xFF, h3 >> 16 & 0xFF, h3 >> 8 & 0xFF, h3 & 0xFF, h4 >> 24 & 0xFF, h4 >> 16 & 0xFF, h4 >> 8 & 0xFF, h4 & 0xFF, h5 >> 24 & 0xFF, h5 >> 16 & 0xFF, h5 >> 8 & 0xFF, h5 & 0xFF, h6 >> 24 & 0xFF, h6 >> 16 & 0xFF, h6 >> 8 & 0xFF, h6 & 0xFF, h7 >> 24 & 0xFF, h7 >> 16 & 0xFF, h7 >> 8 & 0xFF, h7 & 0xFF]);
 
-   }
 
-   return hash;
 
- }();
 
- exports.calculateSHA256 = calculateSHA256;
 
- var calculateSHA512 = function calculateSHA512Closure() {
 
-   function ch(result, x, y, z, tmp) {
 
-     result.assign(x);
 
-     result.and(y);
 
-     tmp.assign(x);
 
-     tmp.not();
 
-     tmp.and(z);
 
-     result.xor(tmp);
 
-   }
 
-   function maj(result, x, y, z, tmp) {
 
-     result.assign(x);
 
-     result.and(y);
 
-     tmp.assign(x);
 
-     tmp.and(z);
 
-     result.xor(tmp);
 
-     tmp.assign(y);
 
-     tmp.and(z);
 
-     result.xor(tmp);
 
-   }
 
-   function sigma(result, x, tmp) {
 
-     result.assign(x);
 
-     result.rotateRight(28);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(34);
 
-     result.xor(tmp);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(39);
 
-     result.xor(tmp);
 
-   }
 
-   function sigmaPrime(result, x, tmp) {
 
-     result.assign(x);
 
-     result.rotateRight(14);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(18);
 
-     result.xor(tmp);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(41);
 
-     result.xor(tmp);
 
-   }
 
-   function littleSigma(result, x, tmp) {
 
-     result.assign(x);
 
-     result.rotateRight(1);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(8);
 
-     result.xor(tmp);
 
-     tmp.assign(x);
 
-     tmp.shiftRight(7);
 
-     result.xor(tmp);
 
-   }
 
-   function littleSigmaPrime(result, x, tmp) {
 
-     result.assign(x);
 
-     result.rotateRight(19);
 
-     tmp.assign(x);
 
-     tmp.rotateRight(61);
 
-     result.xor(tmp);
 
-     tmp.assign(x);
 
-     tmp.shiftRight(6);
 
-     result.xor(tmp);
 
-   }
 
-   var k = [new Word64(0x428a2f98, 0xd728ae22), new Word64(0x71374491, 0x23ef65cd), new Word64(0xb5c0fbcf, 0xec4d3b2f), new Word64(0xe9b5dba5, 0x8189dbbc), new Word64(0x3956c25b, 0xf348b538), new Word64(0x59f111f1, 0xb605d019), new Word64(0x923f82a4, 0xaf194f9b), new Word64(0xab1c5ed5, 0xda6d8118), new Word64(0xd807aa98, 0xa3030242), new Word64(0x12835b01, 0x45706fbe), new Word64(0x243185be, 0x4ee4b28c), new Word64(0x550c7dc3, 0xd5ffb4e2), new Word64(0x72be5d74, 0xf27b896f), new Word64(0x80deb1fe, 0x3b1696b1), new Word64(0x9bdc06a7, 0x25c71235), new Word64(0xc19bf174, 0xcf692694), new Word64(0xe49b69c1, 0x9ef14ad2), new Word64(0xefbe4786, 0x384f25e3), new Word64(0x0fc19dc6, 0x8b8cd5b5), new Word64(0x240ca1cc, 0x77ac9c65), new Word64(0x2de92c6f, 0x592b0275), new Word64(0x4a7484aa, 0x6ea6e483), new Word64(0x5cb0a9dc, 0xbd41fbd4), new Word64(0x76f988da, 0x831153b5), new Word64(0x983e5152, 0xee66dfab), new Word64(0xa831c66d, 0x2db43210), new Word64(0xb00327c8, 0x98fb213f), new Word64(0xbf597fc7, 0xbeef0ee4), new Word64(0xc6e00bf3, 0x3da88fc2), new Word64(0xd5a79147, 0x930aa725), new Word64(0x06ca6351, 0xe003826f), new Word64(0x14292967, 0x0a0e6e70), new Word64(0x27b70a85, 0x46d22ffc), new Word64(0x2e1b2138, 0x5c26c926), new Word64(0x4d2c6dfc, 0x5ac42aed), new Word64(0x53380d13, 0x9d95b3df), new Word64(0x650a7354, 0x8baf63de), new Word64(0x766a0abb, 0x3c77b2a8), new Word64(0x81c2c92e, 0x47edaee6), new Word64(0x92722c85, 0x1482353b), new Word64(0xa2bfe8a1, 0x4cf10364), new Word64(0xa81a664b, 0xbc423001), new Word64(0xc24b8b70, 0xd0f89791), new Word64(0xc76c51a3, 0x0654be30), new Word64(0xd192e819, 0xd6ef5218), new Word64(0xd6990624, 0x5565a910), new Word64(0xf40e3585, 0x5771202a), new Word64(0x106aa070, 0x32bbd1b8), new Word64(0x19a4c116, 0xb8d2d0c8), new Word64(0x1e376c08, 0x5141ab53), new Word64(0x2748774c, 0xdf8eeb99), new Word64(0x34b0bcb5, 0xe19b48a8), new Word64(0x391c0cb3, 0xc5c95a63), new Word64(0x4ed8aa4a, 0xe3418acb), new Word64(0x5b9cca4f, 0x7763e373), new Word64(0x682e6ff3, 0xd6b2b8a3), new Word64(0x748f82ee, 0x5defb2fc), new Word64(0x78a5636f, 0x43172f60), new Word64(0x84c87814, 0xa1f0ab72), new Word64(0x8cc70208, 0x1a6439ec), new Word64(0x90befffa, 0x23631e28), new Word64(0xa4506ceb, 0xde82bde9), new Word64(0xbef9a3f7, 0xb2c67915), new Word64(0xc67178f2, 0xe372532b), new Word64(0xca273ece, 0xea26619c), new Word64(0xd186b8c7, 0x21c0c207), new Word64(0xeada7dd6, 0xcde0eb1e), new Word64(0xf57d4f7f, 0xee6ed178), new Word64(0x06f067aa, 0x72176fba), new Word64(0x0a637dc5, 0xa2c898a6), new Word64(0x113f9804, 0xbef90dae), new Word64(0x1b710b35, 0x131c471b), new Word64(0x28db77f5, 0x23047d84), new Word64(0x32caab7b, 0x40c72493), new Word64(0x3c9ebe0a, 0x15c9bebc), new Word64(0x431d67c4, 0x9c100d4c), new Word64(0x4cc5d4be, 0xcb3e42b6), new Word64(0x597f299c, 0xfc657e2a), new Word64(0x5fcb6fab, 0x3ad6faec), new Word64(0x6c44198c, 0x4a475817)];
 
-   function hash(data, offset, length, mode384) {
 
-     mode384 = !!mode384;
 
-     var h0, h1, h2, h3, h4, h5, h6, h7;
 
-     if (!mode384) {
 
-       h0 = new Word64(0x6a09e667, 0xf3bcc908);
 
-       h1 = new Word64(0xbb67ae85, 0x84caa73b);
 
-       h2 = new Word64(0x3c6ef372, 0xfe94f82b);
 
-       h3 = new Word64(0xa54ff53a, 0x5f1d36f1);
 
-       h4 = new Word64(0x510e527f, 0xade682d1);
 
-       h5 = new Word64(0x9b05688c, 0x2b3e6c1f);
 
-       h6 = new Word64(0x1f83d9ab, 0xfb41bd6b);
 
-       h7 = new Word64(0x5be0cd19, 0x137e2179);
 
-     } else {
 
-       h0 = new Word64(0xcbbb9d5d, 0xc1059ed8);
 
-       h1 = new Word64(0x629a292a, 0x367cd507);
 
-       h2 = new Word64(0x9159015a, 0x3070dd17);
 
-       h3 = new Word64(0x152fecd8, 0xf70e5939);
 
-       h4 = new Word64(0x67332667, 0xffc00b31);
 
-       h5 = new Word64(0x8eb44a87, 0x68581511);
 
-       h6 = new Word64(0xdb0c2e0d, 0x64f98fa7);
 
-       h7 = new Word64(0x47b5481d, 0xbefa4fa4);
 
-     }
 
-     var paddedLength = Math.ceil((length + 17) / 128) * 128;
 
-     var padded = new Uint8Array(paddedLength);
 
-     var i, j, n;
 
-     for (i = 0; i < length; ++i) {
 
-       padded[i] = data[offset++];
 
-     }
 
-     padded[i++] = 0x80;
 
-     n = paddedLength - 16;
 
-     while (i < n) {
 
-       padded[i++] = 0;
 
-     }
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = 0;
 
-     padded[i++] = length >>> 29 & 0xff;
 
-     padded[i++] = length >> 21 & 0xff;
 
-     padded[i++] = length >> 13 & 0xff;
 
-     padded[i++] = length >> 5 & 0xff;
 
-     padded[i++] = length << 3 & 0xff;
 
-     var w = new Array(80);
 
-     for (i = 0; i < 80; i++) {
 
-       w[i] = new Word64(0, 0);
 
-     }
 
-     var a = new Word64(0, 0),
 
-         b = new Word64(0, 0),
 
-         c = new Word64(0, 0);
 
-     var d = new Word64(0, 0),
 
-         e = new Word64(0, 0),
 
-         f = new Word64(0, 0);
 
-     var g = new Word64(0, 0),
 
-         h = new Word64(0, 0);
 
-     var t1 = new Word64(0, 0),
 
-         t2 = new Word64(0, 0);
 
-     var tmp1 = new Word64(0, 0),
 
-         tmp2 = new Word64(0, 0),
 
-         tmp3;
 
-     for (i = 0; i < paddedLength;) {
 
-       for (j = 0; j < 16; ++j) {
 
-         w[j].high = padded[i] << 24 | padded[i + 1] << 16 | padded[i + 2] << 8 | padded[i + 3];
 
-         w[j].low = padded[i + 4] << 24 | padded[i + 5] << 16 | padded[i + 6] << 8 | padded[i + 7];
 
-         i += 8;
 
-       }
 
-       for (j = 16; j < 80; ++j) {
 
-         tmp3 = w[j];
 
-         littleSigmaPrime(tmp3, w[j - 2], tmp2);
 
-         tmp3.add(w[j - 7]);
 
-         littleSigma(tmp1, w[j - 15], tmp2);
 
-         tmp3.add(tmp1);
 
-         tmp3.add(w[j - 16]);
 
-       }
 
-       a.assign(h0);
 
-       b.assign(h1);
 
-       c.assign(h2);
 
-       d.assign(h3);
 
-       e.assign(h4);
 
-       f.assign(h5);
 
-       g.assign(h6);
 
-       h.assign(h7);
 
-       for (j = 0; j < 80; ++j) {
 
-         t1.assign(h);
 
-         sigmaPrime(tmp1, e, tmp2);
 
-         t1.add(tmp1);
 
-         ch(tmp1, e, f, g, tmp2);
 
-         t1.add(tmp1);
 
-         t1.add(k[j]);
 
-         t1.add(w[j]);
 
-         sigma(t2, a, tmp2);
 
-         maj(tmp1, a, b, c, tmp2);
 
-         t2.add(tmp1);
 
-         tmp3 = h;
 
-         h = g;
 
-         g = f;
 
-         f = e;
 
-         d.add(t1);
 
-         e = d;
 
-         d = c;
 
-         c = b;
 
-         b = a;
 
-         tmp3.assign(t1);
 
-         tmp3.add(t2);
 
-         a = tmp3;
 
-       }
 
-       h0.add(a);
 
-       h1.add(b);
 
-       h2.add(c);
 
-       h3.add(d);
 
-       h4.add(e);
 
-       h5.add(f);
 
-       h6.add(g);
 
-       h7.add(h);
 
-     }
 
-     var result;
 
-     if (!mode384) {
 
-       result = new Uint8Array(64);
 
-       h0.copyTo(result, 0);
 
-       h1.copyTo(result, 8);
 
-       h2.copyTo(result, 16);
 
-       h3.copyTo(result, 24);
 
-       h4.copyTo(result, 32);
 
-       h5.copyTo(result, 40);
 
-       h6.copyTo(result, 48);
 
-       h7.copyTo(result, 56);
 
-     } else {
 
-       result = new Uint8Array(48);
 
-       h0.copyTo(result, 0);
 
-       h1.copyTo(result, 8);
 
-       h2.copyTo(result, 16);
 
-       h3.copyTo(result, 24);
 
-       h4.copyTo(result, 32);
 
-       h5.copyTo(result, 40);
 
-     }
 
-     return result;
 
-   }
 
-   return hash;
 
- }();
 
- exports.calculateSHA512 = calculateSHA512;
 
- var calculateSHA384 = function calculateSHA384Closure() {
 
-   function hash(data, offset, length) {
 
-     return calculateSHA512(data, offset, length, true);
 
-   }
 
-   return hash;
 
- }();
 
- exports.calculateSHA384 = calculateSHA384;
 
- var NullCipher = function NullCipherClosure() {
 
-   function NullCipher() {}
 
-   NullCipher.prototype = {
 
-     decryptBlock: function NullCipher_decryptBlock(data) {
 
-       return data;
 
-     }
 
-   };
 
-   return NullCipher;
 
- }();
 
- class AESBaseCipher {
 
-   constructor() {
 
-     if (this.constructor === AESBaseCipher) {
 
-       (0, _util.unreachable)("Cannot initialize AESBaseCipher.");
 
-     }
 
-     this._s = new Uint8Array([0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16]);
 
-     this._inv_s = new Uint8Array([0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d]);
 
-     this._mix = new Uint32Array([0x00000000, 0x0e090d0b, 0x1c121a16, 0x121b171d, 0x3824342c, 0x362d3927, 0x24362e3a, 0x2a3f2331, 0x70486858, 0x7e416553, 0x6c5a724e, 0x62537f45, 0x486c5c74, 0x4665517f, 0x547e4662, 0x5a774b69, 0xe090d0b0, 0xee99ddbb, 0xfc82caa6, 0xf28bc7ad, 0xd8b4e49c, 0xd6bde997, 0xc4a6fe8a, 0xcaaff381, 0x90d8b8e8, 0x9ed1b5e3, 0x8ccaa2fe, 0x82c3aff5, 0xa8fc8cc4, 0xa6f581cf, 0xb4ee96d2, 0xbae79bd9, 0xdb3bbb7b, 0xd532b670, 0xc729a16d, 0xc920ac66, 0xe31f8f57, 0xed16825c, 0xff0d9541, 0xf104984a, 0xab73d323, 0xa57ade28, 0xb761c935, 0xb968c43e, 0x9357e70f, 0x9d5eea04, 0x8f45fd19, 0x814cf012, 0x3bab6bcb, 0x35a266c0, 0x27b971dd, 0x29b07cd6, 0x038f5fe7, 0x0d8652ec, 0x1f9d45f1, 0x119448fa, 0x4be30393, 0x45ea0e98, 0x57f11985, 0x59f8148e, 0x73c737bf, 0x7dce3ab4, 0x6fd52da9, 0x61dc20a2, 0xad766df6, 0xa37f60fd, 0xb16477e0, 0xbf6d7aeb, 0x955259da, 0x9b5b54d1, 0x894043cc, 0x87494ec7, 0xdd3e05ae, 0xd33708a5, 0xc12c1fb8, 0xcf2512b3, 0xe51a3182, 0xeb133c89, 0xf9082b94, 0xf701269f, 0x4de6bd46, 0x43efb04d, 0x51f4a750, 0x5ffdaa5b, 0x75c2896a, 0x7bcb8461, 0x69d0937c, 0x67d99e77, 0x3daed51e, 0x33a7d815, 0x21bccf08, 0x2fb5c203, 0x058ae132, 0x0b83ec39, 0x1998fb24, 0x1791f62f, 0x764dd68d, 0x7844db86, 0x6a5fcc9b, 0x6456c190, 0x4e69e2a1, 0x4060efaa, 0x527bf8b7, 0x5c72f5bc, 0x0605bed5, 0x080cb3de, 0x1a17a4c3, 0x141ea9c8, 0x3e218af9, 0x302887f2, 0x223390ef, 0x2c3a9de4, 0x96dd063d, 0x98d40b36, 0x8acf1c2b, 0x84c61120, 0xaef93211, 0xa0f03f1a, 0xb2eb2807, 0xbce2250c, 0xe6956e65, 0xe89c636e, 0xfa877473, 0xf48e7978, 0xdeb15a49, 0xd0b85742, 0xc2a3405f, 0xccaa4d54, 0x41ecdaf7, 0x4fe5d7fc, 0x5dfec0e1, 0x53f7cdea, 0x79c8eedb, 0x77c1e3d0, 0x65daf4cd, 0x6bd3f9c6, 0x31a4b2af, 0x3fadbfa4, 0x2db6a8b9, 0x23bfa5b2, 0x09808683, 0x07898b88, 0x15929c95, 0x1b9b919e, 0xa17c0a47, 0xaf75074c, 0xbd6e1051, 0xb3671d5a, 0x99583e6b, 0x97513360, 0x854a247d, 0x8b432976, 0xd134621f, 0xdf3d6f14, 0xcd267809, 0xc32f7502, 0xe9105633, 0xe7195b38, 0xf5024c25, 0xfb0b412e, 0x9ad7618c, 0x94de6c87, 0x86c57b9a, 0x88cc7691, 0xa2f355a0, 0xacfa58ab, 0xbee14fb6, 0xb0e842bd, 0xea9f09d4, 0xe49604df, 0xf68d13c2, 0xf8841ec9, 0xd2bb3df8, 0xdcb230f3, 0xcea927ee, 0xc0a02ae5, 0x7a47b13c, 0x744ebc37, 0x6655ab2a, 0x685ca621, 0x42638510, 0x4c6a881b, 0x5e719f06, 0x5078920d, 0x0a0fd964, 0x0406d46f, 0x161dc372, 0x1814ce79, 0x322bed48, 0x3c22e043, 0x2e39f75e, 0x2030fa55, 0xec9ab701, 0xe293ba0a, 0xf088ad17, 0xfe81a01c, 0xd4be832d, 0xdab78e26, 0xc8ac993b, 0xc6a59430, 0x9cd2df59, 0x92dbd252, 0x80c0c54f, 0x8ec9c844, 0xa4f6eb75, 0xaaffe67e, 0xb8e4f163, 0xb6edfc68, 0x0c0a67b1, 0x02036aba, 0x10187da7, 0x1e1170ac, 0x342e539d, 0x3a275e96, 0x283c498b, 0x26354480, 0x7c420fe9, 0x724b02e2, 0x605015ff, 0x6e5918f4, 0x44663bc5, 0x4a6f36ce, 0x587421d3, 0x567d2cd8, 0x37a10c7a, 0x39a80171, 0x2bb3166c, 0x25ba1b67, 0x0f853856, 0x018c355d, 0x13972240, 0x1d9e2f4b, 0x47e96422, 0x49e06929, 0x5bfb7e34, 0x55f2733f, 0x7fcd500e, 0x71c45d05, 0x63df4a18, 0x6dd64713, 0xd731dcca, 0xd938d1c1, 0xcb23c6dc, 0xc52acbd7, 0xef15e8e6, 0xe11ce5ed, 0xf307f2f0, 0xfd0efffb, 0xa779b492, 0xa970b999, 0xbb6bae84, 0xb562a38f, 0x9f5d80be, 0x91548db5, 0x834f9aa8, 0x8d4697a3]);
 
-     this._mixCol = new Uint8Array(256);
 
-     for (let i = 0; i < 256; i++) {
 
-       if (i < 128) {
 
-         this._mixCol[i] = i << 1;
 
-       } else {
 
-         this._mixCol[i] = i << 1 ^ 0x1b;
 
-       }
 
-     }
 
-     this.buffer = new Uint8Array(16);
 
-     this.bufferPosition = 0;
 
-   }
 
-   _expandKey(cipherKey) {
 
-     (0, _util.unreachable)("Cannot call `_expandKey` on the base class");
 
-   }
 
-   _decrypt(input, key) {
 
-     let t, u, v;
 
-     const state = new Uint8Array(16);
 
-     state.set(input);
 
-     for (let j = 0, k = this._keySize; j < 16; ++j, ++k) {
 
-       state[j] ^= key[k];
 
-     }
 
-     for (let i = this._cyclesOfRepetition - 1; i >= 1; --i) {
 
-       t = state[13];
 
-       state[13] = state[9];
 
-       state[9] = state[5];
 
-       state[5] = state[1];
 
-       state[1] = t;
 
-       t = state[14];
 
-       u = state[10];
 
-       state[14] = state[6];
 
-       state[10] = state[2];
 
-       state[6] = t;
 
-       state[2] = u;
 
-       t = state[15];
 
-       u = state[11];
 
-       v = state[7];
 
-       state[15] = state[3];
 
-       state[11] = t;
 
-       state[7] = u;
 
-       state[3] = v;
 
-       for (let j = 0; j < 16; ++j) {
 
-         state[j] = this._inv_s[state[j]];
 
-       }
 
-       for (let j = 0, k = i * 16; j < 16; ++j, ++k) {
 
-         state[j] ^= key[k];
 
-       }
 
-       for (let j = 0; j < 16; j += 4) {
 
-         const s0 = this._mix[state[j]];
 
-         const s1 = this._mix[state[j + 1]];
 
-         const s2 = this._mix[state[j + 2]];
 
-         const s3 = this._mix[state[j + 3]];
 
-         t = s0 ^ s1 >>> 8 ^ s1 << 24 ^ s2 >>> 16 ^ s2 << 16 ^ s3 >>> 24 ^ s3 << 8;
 
-         state[j] = t >>> 24 & 0xff;
 
-         state[j + 1] = t >> 16 & 0xff;
 
-         state[j + 2] = t >> 8 & 0xff;
 
-         state[j + 3] = t & 0xff;
 
-       }
 
-     }
 
-     t = state[13];
 
-     state[13] = state[9];
 
-     state[9] = state[5];
 
-     state[5] = state[1];
 
-     state[1] = t;
 
-     t = state[14];
 
-     u = state[10];
 
-     state[14] = state[6];
 
-     state[10] = state[2];
 
-     state[6] = t;
 
-     state[2] = u;
 
-     t = state[15];
 
-     u = state[11];
 
-     v = state[7];
 
-     state[15] = state[3];
 
-     state[11] = t;
 
-     state[7] = u;
 
-     state[3] = v;
 
-     for (let j = 0; j < 16; ++j) {
 
-       state[j] = this._inv_s[state[j]];
 
-       state[j] ^= key[j];
 
-     }
 
-     return state;
 
-   }
 
-   _encrypt(input, key) {
 
-     const s = this._s;
 
-     let t, u, v;
 
-     const state = new Uint8Array(16);
 
-     state.set(input);
 
-     for (let j = 0; j < 16; ++j) {
 
-       state[j] ^= key[j];
 
-     }
 
-     for (let i = 1; i < this._cyclesOfRepetition; i++) {
 
-       for (let j = 0; j < 16; ++j) {
 
-         state[j] = s[state[j]];
 
-       }
 
-       v = state[1];
 
-       state[1] = state[5];
 
-       state[5] = state[9];
 
-       state[9] = state[13];
 
-       state[13] = v;
 
-       v = state[2];
 
-       u = state[6];
 
-       state[2] = state[10];
 
-       state[6] = state[14];
 
-       state[10] = v;
 
-       state[14] = u;
 
-       v = state[3];
 
-       u = state[7];
 
-       t = state[11];
 
-       state[3] = state[15];
 
-       state[7] = v;
 
-       state[11] = u;
 
-       state[15] = t;
 
-       for (let j = 0; j < 16; j += 4) {
 
-         const s0 = state[j + 0];
 
-         const s1 = state[j + 1];
 
-         const s2 = state[j + 2];
 
-         const s3 = state[j + 3];
 
-         t = s0 ^ s1 ^ s2 ^ s3;
 
-         state[j + 0] ^= t ^ this._mixCol[s0 ^ s1];
 
-         state[j + 1] ^= t ^ this._mixCol[s1 ^ s2];
 
-         state[j + 2] ^= t ^ this._mixCol[s2 ^ s3];
 
-         state[j + 3] ^= t ^ this._mixCol[s3 ^ s0];
 
-       }
 
-       for (let j = 0, k = i * 16; j < 16; ++j, ++k) {
 
-         state[j] ^= key[k];
 
-       }
 
-     }
 
-     for (let j = 0; j < 16; ++j) {
 
-       state[j] = s[state[j]];
 
-     }
 
-     v = state[1];
 
-     state[1] = state[5];
 
-     state[5] = state[9];
 
-     state[9] = state[13];
 
-     state[13] = v;
 
-     v = state[2];
 
-     u = state[6];
 
-     state[2] = state[10];
 
-     state[6] = state[14];
 
-     state[10] = v;
 
-     state[14] = u;
 
-     v = state[3];
 
-     u = state[7];
 
-     t = state[11];
 
-     state[3] = state[15];
 
-     state[7] = v;
 
-     state[11] = u;
 
-     state[15] = t;
 
-     for (let j = 0, k = this._keySize; j < 16; ++j, ++k) {
 
-       state[j] ^= key[k];
 
-     }
 
-     return state;
 
-   }
 
-   _decryptBlock2(data, finalize) {
 
-     const sourceLength = data.length;
 
-     let buffer = this.buffer,
 
-         bufferLength = this.bufferPosition;
 
-     const result = [];
 
-     let iv = this.iv;
 
-     for (let i = 0; i < sourceLength; ++i) {
 
-       buffer[bufferLength] = data[i];
 
-       ++bufferLength;
 
-       if (bufferLength < 16) {
 
-         continue;
 
-       }
 
-       const plain = this._decrypt(buffer, this._key);
 
-       for (let j = 0; j < 16; ++j) {
 
-         plain[j] ^= iv[j];
 
-       }
 
-       iv = buffer;
 
-       result.push(plain);
 
-       buffer = new Uint8Array(16);
 
-       bufferLength = 0;
 
-     }
 
-     this.buffer = buffer;
 
-     this.bufferLength = bufferLength;
 
-     this.iv = iv;
 
-     if (result.length === 0) {
 
-       return new Uint8Array(0);
 
-     }
 
-     let outputLength = 16 * result.length;
 
-     if (finalize) {
 
-       const lastBlock = result[result.length - 1];
 
-       let psLen = lastBlock[15];
 
-       if (psLen <= 16) {
 
-         for (let i = 15, ii = 16 - psLen; i >= ii; --i) {
 
-           if (lastBlock[i] !== psLen) {
 
-             psLen = 0;
 
-             break;
 
-           }
 
-         }
 
-         outputLength -= psLen;
 
-         result[result.length - 1] = lastBlock.subarray(0, 16 - psLen);
 
-       }
 
-     }
 
-     const output = new Uint8Array(outputLength);
 
-     for (let i = 0, j = 0, ii = result.length; i < ii; ++i, j += 16) {
 
-       output.set(result[i], j);
 
-     }
 
-     return output;
 
-   }
 
-   decryptBlock(data, finalize, iv = null) {
 
-     const sourceLength = data.length;
 
-     const buffer = this.buffer;
 
-     let bufferLength = this.bufferPosition;
 
-     if (iv) {
 
-       this.iv = iv;
 
-     } else {
 
-       for (let i = 0; bufferLength < 16 && i < sourceLength; ++i, ++bufferLength) {
 
-         buffer[bufferLength] = data[i];
 
-       }
 
-       if (bufferLength < 16) {
 
-         this.bufferLength = bufferLength;
 
-         return new Uint8Array(0);
 
-       }
 
-       this.iv = buffer;
 
-       data = data.subarray(16);
 
-     }
 
-     this.buffer = new Uint8Array(16);
 
-     this.bufferLength = 0;
 
-     this.decryptBlock = this._decryptBlock2;
 
-     return this.decryptBlock(data, finalize);
 
-   }
 
-   encrypt(data, iv) {
 
-     const sourceLength = data.length;
 
-     let buffer = this.buffer,
 
-         bufferLength = this.bufferPosition;
 
-     const result = [];
 
-     if (!iv) {
 
-       iv = new Uint8Array(16);
 
-     }
 
-     for (let i = 0; i < sourceLength; ++i) {
 
-       buffer[bufferLength] = data[i];
 
-       ++bufferLength;
 
-       if (bufferLength < 16) {
 
-         continue;
 
-       }
 
-       for (let j = 0; j < 16; ++j) {
 
-         buffer[j] ^= iv[j];
 
-       }
 
-       const cipher = this._encrypt(buffer, this._key);
 
-       iv = cipher;
 
-       result.push(cipher);
 
-       buffer = new Uint8Array(16);
 
-       bufferLength = 0;
 
-     }
 
-     this.buffer = buffer;
 
-     this.bufferLength = bufferLength;
 
-     this.iv = iv;
 
-     if (result.length === 0) {
 
-       return new Uint8Array(0);
 
-     }
 
-     const outputLength = 16 * result.length;
 
-     const output = new Uint8Array(outputLength);
 
-     for (let i = 0, j = 0, ii = result.length; i < ii; ++i, j += 16) {
 
-       output.set(result[i], j);
 
-     }
 
-     return output;
 
-   }
 
- }
 
- class AES128Cipher extends AESBaseCipher {
 
-   constructor(key) {
 
-     super();
 
-     this._cyclesOfRepetition = 10;
 
-     this._keySize = 160;
 
-     this._rcon = new Uint8Array([0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91, 0x39, 0x72, 0xe4, 0xd3, 0xbd, 0x61, 0xc2, 0x9f, 0x25, 0x4a, 0x94, 0x33, 0x66, 0xcc, 0x83, 0x1d, 0x3a, 0x74, 0xe8, 0xcb, 0x8d]);
 
-     this._key = this._expandKey(key);
 
-   }
 
-   _expandKey(cipherKey) {
 
-     const b = 176;
 
-     const s = this._s;
 
-     const rcon = this._rcon;
 
-     const result = new Uint8Array(b);
 
-     result.set(cipherKey);
 
-     for (let j = 16, i = 1; j < b; ++i) {
 
-       let t1 = result[j - 3];
 
-       let t2 = result[j - 2];
 
-       let t3 = result[j - 1];
 
-       let t4 = result[j - 4];
 
-       t1 = s[t1];
 
-       t2 = s[t2];
 
-       t3 = s[t3];
 
-       t4 = s[t4];
 
-       t1 = t1 ^ rcon[i];
 
-       for (let n = 0; n < 4; ++n) {
 
-         result[j] = t1 ^= result[j - 16];
 
-         j++;
 
-         result[j] = t2 ^= result[j - 16];
 
-         j++;
 
-         result[j] = t3 ^= result[j - 16];
 
-         j++;
 
-         result[j] = t4 ^= result[j - 16];
 
-         j++;
 
-       }
 
-     }
 
-     return result;
 
-   }
 
- }
 
- exports.AES128Cipher = AES128Cipher;
 
- class AES256Cipher extends AESBaseCipher {
 
-   constructor(key) {
 
-     super();
 
-     this._cyclesOfRepetition = 14;
 
-     this._keySize = 224;
 
-     this._key = this._expandKey(key);
 
-   }
 
-   _expandKey(cipherKey) {
 
-     const b = 240;
 
-     const s = this._s;
 
-     const result = new Uint8Array(b);
 
-     result.set(cipherKey);
 
-     let r = 1;
 
-     let t1, t2, t3, t4;
 
-     for (let j = 32, i = 1; j < b; ++i) {
 
-       if (j % 32 === 16) {
 
-         t1 = s[t1];
 
-         t2 = s[t2];
 
-         t3 = s[t3];
 
-         t4 = s[t4];
 
-       } else if (j % 32 === 0) {
 
-         t1 = result[j - 3];
 
-         t2 = result[j - 2];
 
-         t3 = result[j - 1];
 
-         t4 = result[j - 4];
 
-         t1 = s[t1];
 
-         t2 = s[t2];
 
-         t3 = s[t3];
 
-         t4 = s[t4];
 
-         t1 = t1 ^ r;
 
-         if ((r <<= 1) >= 256) {
 
-           r = (r ^ 0x1b) & 0xff;
 
-         }
 
-       }
 
-       for (let n = 0; n < 4; ++n) {
 
-         result[j] = t1 ^= result[j - 32];
 
-         j++;
 
-         result[j] = t2 ^= result[j - 32];
 
-         j++;
 
-         result[j] = t3 ^= result[j - 32];
 
-         j++;
 
-         result[j] = t4 ^= result[j - 32];
 
-         j++;
 
-       }
 
-     }
 
-     return result;
 
-   }
 
- }
 
- exports.AES256Cipher = AES256Cipher;
 
- var PDF17 = function PDF17Closure() {
 
-   function compareByteArrays(array1, array2) {
 
-     if (array1.length !== array2.length) {
 
-       return false;
 
-     }
 
-     for (var i = 0; i < array1.length; i++) {
 
-       if (array1[i] !== array2[i]) {
 
-         return false;
 
-       }
 
-     }
 
-     return true;
 
-   }
 
-   function PDF17() {}
 
-   PDF17.prototype = {
 
-     checkOwnerPassword: function PDF17_checkOwnerPassword(password, ownerValidationSalt, userBytes, ownerPassword) {
 
-       var hashData = new Uint8Array(password.length + 56);
 
-       hashData.set(password, 0);
 
-       hashData.set(ownerValidationSalt, password.length);
 
-       hashData.set(userBytes, password.length + ownerValidationSalt.length);
 
-       var result = calculateSHA256(hashData, 0, hashData.length);
 
-       return compareByteArrays(result, ownerPassword);
 
-     },
 
-     checkUserPassword: function PDF17_checkUserPassword(password, userValidationSalt, userPassword) {
 
-       var hashData = new Uint8Array(password.length + 8);
 
-       hashData.set(password, 0);
 
-       hashData.set(userValidationSalt, password.length);
 
-       var result = calculateSHA256(hashData, 0, hashData.length);
 
-       return compareByteArrays(result, userPassword);
 
-     },
 
-     getOwnerKey: function PDF17_getOwnerKey(password, ownerKeySalt, userBytes, ownerEncryption) {
 
-       var hashData = new Uint8Array(password.length + 56);
 
-       hashData.set(password, 0);
 
-       hashData.set(ownerKeySalt, password.length);
 
-       hashData.set(userBytes, password.length + ownerKeySalt.length);
 
-       var key = calculateSHA256(hashData, 0, hashData.length);
 
-       var cipher = new AES256Cipher(key);
 
-       return cipher.decryptBlock(ownerEncryption, false, new Uint8Array(16));
 
-     },
 
-     getUserKey: function PDF17_getUserKey(password, userKeySalt, userEncryption) {
 
-       var hashData = new Uint8Array(password.length + 8);
 
-       hashData.set(password, 0);
 
-       hashData.set(userKeySalt, password.length);
 
-       var key = calculateSHA256(hashData, 0, hashData.length);
 
-       var cipher = new AES256Cipher(key);
 
-       return cipher.decryptBlock(userEncryption, false, new Uint8Array(16));
 
-     }
 
-   };
 
-   return PDF17;
 
- }();
 
- exports.PDF17 = PDF17;
 
- var PDF20 = function PDF20Closure() {
 
-   function concatArrays(array1, array2) {
 
-     var t = new Uint8Array(array1.length + array2.length);
 
-     t.set(array1, 0);
 
-     t.set(array2, array1.length);
 
-     return t;
 
-   }
 
-   function calculatePDF20Hash(password, input, userBytes) {
 
-     var k = calculateSHA256(input, 0, input.length).subarray(0, 32);
 
-     var e = [0];
 
-     var i = 0;
 
-     while (i < 64 || e[e.length - 1] > i - 32) {
 
-       var arrayLength = password.length + k.length + userBytes.length;
 
-       var k1 = new Uint8Array(arrayLength * 64);
 
-       var array = concatArrays(password, k);
 
-       array = concatArrays(array, userBytes);
 
-       for (var j = 0, pos = 0; j < 64; j++, pos += arrayLength) {
 
-         k1.set(array, pos);
 
-       }
 
-       var cipher = new AES128Cipher(k.subarray(0, 16));
 
-       e = cipher.encrypt(k1, k.subarray(16, 32));
 
-       var remainder = 0;
 
-       for (var z = 0; z < 16; z++) {
 
-         remainder *= 256 % 3;
 
-         remainder %= 3;
 
-         remainder += (e[z] >>> 0) % 3;
 
-         remainder %= 3;
 
-       }
 
-       if (remainder === 0) {
 
-         k = calculateSHA256(e, 0, e.length);
 
-       } else if (remainder === 1) {
 
-         k = calculateSHA384(e, 0, e.length);
 
-       } else if (remainder === 2) {
 
-         k = calculateSHA512(e, 0, e.length);
 
-       }
 
-       i++;
 
-     }
 
-     return k.subarray(0, 32);
 
-   }
 
-   function PDF20() {}
 
-   function compareByteArrays(array1, array2) {
 
-     if (array1.length !== array2.length) {
 
-       return false;
 
-     }
 
-     for (var i = 0; i < array1.length; i++) {
 
-       if (array1[i] !== array2[i]) {
 
-         return false;
 
-       }
 
-     }
 
-     return true;
 
-   }
 
-   PDF20.prototype = {
 
-     hash: function PDF20_hash(password, concatBytes, userBytes) {
 
-       return calculatePDF20Hash(password, concatBytes, userBytes);
 
-     },
 
-     checkOwnerPassword: function PDF20_checkOwnerPassword(password, ownerValidationSalt, userBytes, ownerPassword) {
 
-       var hashData = new Uint8Array(password.length + 56);
 
-       hashData.set(password, 0);
 
-       hashData.set(ownerValidationSalt, password.length);
 
-       hashData.set(userBytes, password.length + ownerValidationSalt.length);
 
-       var result = calculatePDF20Hash(password, hashData, userBytes);
 
-       return compareByteArrays(result, ownerPassword);
 
-     },
 
-     checkUserPassword: function PDF20_checkUserPassword(password, userValidationSalt, userPassword) {
 
-       var hashData = new Uint8Array(password.length + 8);
 
-       hashData.set(password, 0);
 
-       hashData.set(userValidationSalt, password.length);
 
-       var result = calculatePDF20Hash(password, hashData, []);
 
-       return compareByteArrays(result, userPassword);
 
-     },
 
-     getOwnerKey: function PDF20_getOwnerKey(password, ownerKeySalt, userBytes, ownerEncryption) {
 
-       var hashData = new Uint8Array(password.length + 56);
 
-       hashData.set(password, 0);
 
-       hashData.set(ownerKeySalt, password.length);
 
-       hashData.set(userBytes, password.length + ownerKeySalt.length);
 
-       var key = calculatePDF20Hash(password, hashData, userBytes);
 
-       var cipher = new AES256Cipher(key);
 
-       return cipher.decryptBlock(ownerEncryption, false, new Uint8Array(16));
 
-     },
 
-     getUserKey: function PDF20_getUserKey(password, userKeySalt, userEncryption) {
 
-       var hashData = new Uint8Array(password.length + 8);
 
-       hashData.set(password, 0);
 
-       hashData.set(userKeySalt, password.length);
 
-       var key = calculatePDF20Hash(password, hashData, []);
 
-       var cipher = new AES256Cipher(key);
 
-       return cipher.decryptBlock(userEncryption, false, new Uint8Array(16));
 
-     }
 
-   };
 
-   return PDF20;
 
- }();
 
- exports.PDF20 = PDF20;
 
- var CipherTransform = function CipherTransformClosure() {
 
-   function CipherTransform(stringCipherConstructor, streamCipherConstructor) {
 
-     this.StringCipherConstructor = stringCipherConstructor;
 
-     this.StreamCipherConstructor = streamCipherConstructor;
 
-   }
 
-   CipherTransform.prototype = {
 
-     createStream: function CipherTransform_createStream(stream, length) {
 
-       var cipher = new this.StreamCipherConstructor();
 
-       return new _stream.DecryptStream(stream, length, function cipherTransformDecryptStream(data, finalize) {
 
-         return cipher.decryptBlock(data, finalize);
 
-       });
 
-     },
 
-     decryptString: function CipherTransform_decryptString(s) {
 
-       var cipher = new this.StringCipherConstructor();
 
-       var data = (0, _util.stringToBytes)(s);
 
-       data = cipher.decryptBlock(data, true);
 
-       return (0, _util.bytesToString)(data);
 
-     }
 
-   };
 
-   return CipherTransform;
 
- }();
 
- var CipherTransformFactory = function CipherTransformFactoryClosure() {
 
-   var defaultPasswordBytes = new Uint8Array([0x28, 0xBF, 0x4E, 0x5E, 0x4E, 0x75, 0x8A, 0x41, 0x64, 0x00, 0x4E, 0x56, 0xFF, 0xFA, 0x01, 0x08, 0x2E, 0x2E, 0x00, 0xB6, 0xD0, 0x68, 0x3E, 0x80, 0x2F, 0x0C, 0xA9, 0xFE, 0x64, 0x53, 0x69, 0x7A]);
 
-   function createEncryptionKey20(revision, password, ownerPassword, ownerValidationSalt, ownerKeySalt, uBytes, userPassword, userValidationSalt, userKeySalt, ownerEncryption, userEncryption, perms) {
 
-     if (password) {
 
-       var passwordLength = Math.min(127, password.length);
 
-       password = password.subarray(0, passwordLength);
 
-     } else {
 
-       password = [];
 
-     }
 
-     var pdfAlgorithm;
 
-     if (revision === 6) {
 
-       pdfAlgorithm = new PDF20();
 
-     } else {
 
-       pdfAlgorithm = new PDF17();
 
-     }
 
-     if (pdfAlgorithm.checkUserPassword(password, userValidationSalt, userPassword)) {
 
-       return pdfAlgorithm.getUserKey(password, userKeySalt, userEncryption);
 
-     } else if (password.length && pdfAlgorithm.checkOwnerPassword(password, ownerValidationSalt, uBytes, ownerPassword)) {
 
-       return pdfAlgorithm.getOwnerKey(password, ownerKeySalt, uBytes, ownerEncryption);
 
-     }
 
-     return null;
 
-   }
 
-   function prepareKeyData(fileId, password, ownerPassword, userPassword, flags, revision, keyLength, encryptMetadata) {
 
-     var hashDataSize = 40 + ownerPassword.length + fileId.length;
 
-     var hashData = new Uint8Array(hashDataSize),
 
-         i = 0,
 
-         j,
 
-         n;
 
-     if (password) {
 
-       n = Math.min(32, password.length);
 
-       for (; i < n; ++i) {
 
-         hashData[i] = password[i];
 
-       }
 
-     }
 
-     j = 0;
 
-     while (i < 32) {
 
-       hashData[i++] = defaultPasswordBytes[j++];
 
-     }
 
-     for (j = 0, n = ownerPassword.length; j < n; ++j) {
 
-       hashData[i++] = ownerPassword[j];
 
-     }
 
-     hashData[i++] = flags & 0xff;
 
-     hashData[i++] = flags >> 8 & 0xff;
 
-     hashData[i++] = flags >> 16 & 0xff;
 
-     hashData[i++] = flags >>> 24 & 0xff;
 
-     for (j = 0, n = fileId.length; j < n; ++j) {
 
-       hashData[i++] = fileId[j];
 
-     }
 
-     if (revision >= 4 && !encryptMetadata) {
 
-       hashData[i++] = 0xff;
 
-       hashData[i++] = 0xff;
 
-       hashData[i++] = 0xff;
 
-       hashData[i++] = 0xff;
 
-     }
 
-     var hash = calculateMD5(hashData, 0, i);
 
-     var keyLengthInBytes = keyLength >> 3;
 
-     if (revision >= 3) {
 
-       for (j = 0; j < 50; ++j) {
 
-         hash = calculateMD5(hash, 0, keyLengthInBytes);
 
-       }
 
-     }
 
-     var encryptionKey = hash.subarray(0, keyLengthInBytes);
 
-     var cipher, checkData;
 
-     if (revision >= 3) {
 
-       for (i = 0; i < 32; ++i) {
 
-         hashData[i] = defaultPasswordBytes[i];
 
-       }
 
-       for (j = 0, n = fileId.length; j < n; ++j) {
 
-         hashData[i++] = fileId[j];
 
-       }
 
-       cipher = new ARCFourCipher(encryptionKey);
 
-       checkData = cipher.encryptBlock(calculateMD5(hashData, 0, i));
 
-       n = encryptionKey.length;
 
-       var derivedKey = new Uint8Array(n),
 
-           k;
 
-       for (j = 1; j <= 19; ++j) {
 
-         for (k = 0; k < n; ++k) {
 
-           derivedKey[k] = encryptionKey[k] ^ j;
 
-         }
 
-         cipher = new ARCFourCipher(derivedKey);
 
-         checkData = cipher.encryptBlock(checkData);
 
-       }
 
-       for (j = 0, n = checkData.length; j < n; ++j) {
 
-         if (userPassword[j] !== checkData[j]) {
 
-           return null;
 
-         }
 
-       }
 
-     } else {
 
-       cipher = new ARCFourCipher(encryptionKey);
 
-       checkData = cipher.encryptBlock(defaultPasswordBytes);
 
-       for (j = 0, n = checkData.length; j < n; ++j) {
 
-         if (userPassword[j] !== checkData[j]) {
 
-           return null;
 
-         }
 
-       }
 
-     }
 
-     return encryptionKey;
 
-   }
 
-   function decodeUserPassword(password, ownerPassword, revision, keyLength) {
 
-     var hashData = new Uint8Array(32),
 
-         i = 0,
 
-         j,
 
-         n;
 
-     n = Math.min(32, password.length);
 
-     for (; i < n; ++i) {
 
-       hashData[i] = password[i];
 
-     }
 
-     j = 0;
 
-     while (i < 32) {
 
-       hashData[i++] = defaultPasswordBytes[j++];
 
-     }
 
-     var hash = calculateMD5(hashData, 0, i);
 
-     var keyLengthInBytes = keyLength >> 3;
 
-     if (revision >= 3) {
 
-       for (j = 0; j < 50; ++j) {
 
-         hash = calculateMD5(hash, 0, hash.length);
 
-       }
 
-     }
 
-     var cipher, userPassword;
 
-     if (revision >= 3) {
 
-       userPassword = ownerPassword;
 
-       var derivedKey = new Uint8Array(keyLengthInBytes),
 
-           k;
 
-       for (j = 19; j >= 0; j--) {
 
-         for (k = 0; k < keyLengthInBytes; ++k) {
 
-           derivedKey[k] = hash[k] ^ j;
 
-         }
 
-         cipher = new ARCFourCipher(derivedKey);
 
-         userPassword = cipher.encryptBlock(userPassword);
 
-       }
 
-     } else {
 
-       cipher = new ARCFourCipher(hash.subarray(0, keyLengthInBytes));
 
-       userPassword = cipher.encryptBlock(ownerPassword);
 
-     }
 
-     return userPassword;
 
-   }
 
-   var identityName = _primitives.Name.get("Identity");
 
-   function CipherTransformFactory(dict, fileId, password) {
 
-     var filter = dict.get("Filter");
 
-     if (!(0, _primitives.isName)(filter, "Standard")) {
 
-       throw new _util.FormatError("unknown encryption method");
 
-     }
 
-     this.dict = dict;
 
-     var algorithm = dict.get("V");
 
-     if (!Number.isInteger(algorithm) || algorithm !== 1 && algorithm !== 2 && algorithm !== 4 && algorithm !== 5) {
 
-       throw new _util.FormatError("unsupported encryption algorithm");
 
-     }
 
-     this.algorithm = algorithm;
 
-     var keyLength = dict.get("Length");
 
-     if (!keyLength) {
 
-       if (algorithm <= 3) {
 
-         keyLength = 40;
 
-       } else {
 
-         var cfDict = dict.get("CF");
 
-         var streamCryptoName = dict.get("StmF");
 
-         if ((0, _primitives.isDict)(cfDict) && (0, _primitives.isName)(streamCryptoName)) {
 
-           cfDict.suppressEncryption = true;
 
-           var handlerDict = cfDict.get(streamCryptoName.name);
 
-           keyLength = handlerDict && handlerDict.get("Length") || 128;
 
-           if (keyLength < 40) {
 
-             keyLength <<= 3;
 
-           }
 
-         }
 
-       }
 
-     }
 
-     if (!Number.isInteger(keyLength) || keyLength < 40 || keyLength % 8 !== 0) {
 
-       throw new _util.FormatError("invalid key length");
 
-     }
 
-     var ownerPassword = (0, _util.stringToBytes)(dict.get("O")).subarray(0, 32);
 
-     var userPassword = (0, _util.stringToBytes)(dict.get("U")).subarray(0, 32);
 
-     var flags = dict.get("P");
 
-     var revision = dict.get("R");
 
-     var encryptMetadata = (algorithm === 4 || algorithm === 5) && dict.get("EncryptMetadata") !== false;
 
-     this.encryptMetadata = encryptMetadata;
 
-     var fileIdBytes = (0, _util.stringToBytes)(fileId);
 
-     var passwordBytes;
 
-     if (password) {
 
-       if (revision === 6) {
 
-         try {
 
-           password = (0, _util.utf8StringToString)(password);
 
-         } catch (ex) {
 
-           (0, _util.warn)("CipherTransformFactory: " + "Unable to convert UTF8 encoded password.");
 
-         }
 
-       }
 
-       passwordBytes = (0, _util.stringToBytes)(password);
 
-     }
 
-     var encryptionKey;
 
-     if (algorithm !== 5) {
 
-       encryptionKey = prepareKeyData(fileIdBytes, passwordBytes, ownerPassword, userPassword, flags, revision, keyLength, encryptMetadata);
 
-     } else {
 
-       var ownerValidationSalt = (0, _util.stringToBytes)(dict.get("O")).subarray(32, 40);
 
-       var ownerKeySalt = (0, _util.stringToBytes)(dict.get("O")).subarray(40, 48);
 
-       var uBytes = (0, _util.stringToBytes)(dict.get("U")).subarray(0, 48);
 
-       var userValidationSalt = (0, _util.stringToBytes)(dict.get("U")).subarray(32, 40);
 
-       var userKeySalt = (0, _util.stringToBytes)(dict.get("U")).subarray(40, 48);
 
-       var ownerEncryption = (0, _util.stringToBytes)(dict.get("OE"));
 
-       var userEncryption = (0, _util.stringToBytes)(dict.get("UE"));
 
-       var perms = (0, _util.stringToBytes)(dict.get("Perms"));
 
-       encryptionKey = createEncryptionKey20(revision, passwordBytes, ownerPassword, ownerValidationSalt, ownerKeySalt, uBytes, userPassword, userValidationSalt, userKeySalt, ownerEncryption, userEncryption, perms);
 
-     }
 
-     if (!encryptionKey && !password) {
 
-       throw new _util.PasswordException("No password given", _util.PasswordResponses.NEED_PASSWORD);
 
-     } else if (!encryptionKey && password) {
 
-       var decodedPassword = decodeUserPassword(passwordBytes, ownerPassword, revision, keyLength);
 
-       encryptionKey = prepareKeyData(fileIdBytes, decodedPassword, ownerPassword, userPassword, flags, revision, keyLength, encryptMetadata);
 
-     }
 
-     if (!encryptionKey) {
 
-       throw new _util.PasswordException("Incorrect Password", _util.PasswordResponses.INCORRECT_PASSWORD);
 
-     }
 
-     this.encryptionKey = encryptionKey;
 
-     if (algorithm >= 4) {
 
-       var cf = dict.get("CF");
 
-       if ((0, _primitives.isDict)(cf)) {
 
-         cf.suppressEncryption = true;
 
-       }
 
-       this.cf = cf;
 
-       this.stmf = dict.get("StmF") || identityName;
 
-       this.strf = dict.get("StrF") || identityName;
 
-       this.eff = dict.get("EFF") || this.stmf;
 
-     }
 
-   }
 
-   function buildObjectKey(num, gen, encryptionKey, isAes) {
 
-     var key = new Uint8Array(encryptionKey.length + 9),
 
-         i,
 
-         n;
 
-     for (i = 0, n = encryptionKey.length; i < n; ++i) {
 
-       key[i] = encryptionKey[i];
 
-     }
 
-     key[i++] = num & 0xff;
 
-     key[i++] = num >> 8 & 0xff;
 
-     key[i++] = num >> 16 & 0xff;
 
-     key[i++] = gen & 0xff;
 
-     key[i++] = gen >> 8 & 0xff;
 
-     if (isAes) {
 
-       key[i++] = 0x73;
 
-       key[i++] = 0x41;
 
-       key[i++] = 0x6c;
 
-       key[i++] = 0x54;
 
-     }
 
-     var hash = calculateMD5(key, 0, i);
 
-     return hash.subarray(0, Math.min(encryptionKey.length + 5, 16));
 
-   }
 
-   function buildCipherConstructor(cf, name, num, gen, key) {
 
-     if (!(0, _primitives.isName)(name)) {
 
-       throw new _util.FormatError("Invalid crypt filter name.");
 
-     }
 
-     var cryptFilter = cf.get(name.name);
 
-     var cfm;
 
-     if (cryptFilter !== null && cryptFilter !== undefined) {
 
-       cfm = cryptFilter.get("CFM");
 
-     }
 
-     if (!cfm || cfm.name === "None") {
 
-       return function cipherTransformFactoryBuildCipherConstructorNone() {
 
-         return new NullCipher();
 
-       };
 
-     }
 
-     if (cfm.name === "V2") {
 
-       return function cipherTransformFactoryBuildCipherConstructorV2() {
 
-         return new ARCFourCipher(buildObjectKey(num, gen, key, false));
 
-       };
 
-     }
 
-     if (cfm.name === "AESV2") {
 
-       return function cipherTransformFactoryBuildCipherConstructorAESV2() {
 
-         return new AES128Cipher(buildObjectKey(num, gen, key, true));
 
-       };
 
-     }
 
-     if (cfm.name === "AESV3") {
 
-       return function cipherTransformFactoryBuildCipherConstructorAESV3() {
 
-         return new AES256Cipher(key);
 
-       };
 
-     }
 
-     throw new _util.FormatError("Unknown crypto method");
 
-   }
 
-   CipherTransformFactory.prototype = {
 
-     createCipherTransform: function CipherTransformFactory_createCipherTransform(num, gen) {
 
-       if (this.algorithm === 4 || this.algorithm === 5) {
 
-         return new CipherTransform(buildCipherConstructor(this.cf, this.stmf, num, gen, this.encryptionKey), buildCipherConstructor(this.cf, this.strf, num, gen, this.encryptionKey));
 
-       }
 
-       var key = buildObjectKey(num, gen, this.encryptionKey, false);
 
-       var cipherConstructor = function buildCipherCipherConstructor() {
 
-         return new ARCFourCipher(key);
 
-       };
 
-       return new CipherTransform(cipherConstructor, cipherConstructor);
 
-     }
 
-   };
 
-   return CipherTransformFactory;
 
- }();
 
- exports.CipherTransformFactory = CipherTransformFactory;
 
- /***/ }),
 
- /* 22 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.ColorSpace = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- function resizeRgbImage(src, dest, w1, h1, w2, h2, alpha01) {
 
-   const COMPONENTS = 3;
 
-   alpha01 = alpha01 !== 1 ? 0 : alpha01;
 
-   const xRatio = w1 / w2;
 
-   const yRatio = h1 / h2;
 
-   let newIndex = 0,
 
-       oldIndex;
 
-   const xScaled = new Uint16Array(w2);
 
-   const w1Scanline = w1 * COMPONENTS;
 
-   for (let i = 0; i < w2; i++) {
 
-     xScaled[i] = Math.floor(i * xRatio) * COMPONENTS;
 
-   }
 
-   for (let i = 0; i < h2; i++) {
 
-     const py = Math.floor(i * yRatio) * w1Scanline;
 
-     for (let j = 0; j < w2; j++) {
 
-       oldIndex = py + xScaled[j];
 
-       dest[newIndex++] = src[oldIndex++];
 
-       dest[newIndex++] = src[oldIndex++];
 
-       dest[newIndex++] = src[oldIndex++];
 
-       newIndex += alpha01;
 
-     }
 
-   }
 
- }
 
- class ColorSpace {
 
-   constructor(name, numComps) {
 
-     if (this.constructor === ColorSpace) {
 
-       (0, _util.unreachable)("Cannot initialize ColorSpace.");
 
-     }
 
-     this.name = name;
 
-     this.numComps = numComps;
 
-   }
 
-   getRgb(src, srcOffset) {
 
-     const rgb = new Uint8ClampedArray(3);
 
-     this.getRgbItem(src, srcOffset, rgb, 0);
 
-     return rgb;
 
-   }
 
-   getRgbItem(src, srcOffset, dest, destOffset) {
 
-     (0, _util.unreachable)("Should not call ColorSpace.getRgbItem");
 
-   }
 
-   getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-     (0, _util.unreachable)("Should not call ColorSpace.getRgbBuffer");
 
-   }
 
-   getOutputLength(inputLength, alpha01) {
 
-     (0, _util.unreachable)("Should not call ColorSpace.getOutputLength");
 
-   }
 
-   isPassthrough(bits) {
 
-     return false;
 
-   }
 
-   isDefaultDecode(decodeMap, bpc) {
 
-     return ColorSpace.isDefaultDecode(decodeMap, this.numComps);
 
-   }
 
-   fillRgb(dest, originalWidth, originalHeight, width, height, actualHeight, bpc, comps, alpha01) {
 
-     const count = originalWidth * originalHeight;
 
-     let rgbBuf = null;
 
-     const numComponentColors = 1 << bpc;
 
-     const needsResizing = originalHeight !== height || originalWidth !== width;
 
-     if (this.isPassthrough(bpc)) {
 
-       rgbBuf = comps;
 
-     } else if (this.numComps === 1 && count > numComponentColors && this.name !== "DeviceGray" && this.name !== "DeviceRGB") {
 
-       const allColors = bpc <= 8 ? new Uint8Array(numComponentColors) : new Uint16Array(numComponentColors);
 
-       for (let i = 0; i < numComponentColors; i++) {
 
-         allColors[i] = i;
 
-       }
 
-       const colorMap = new Uint8ClampedArray(numComponentColors * 3);
 
-       this.getRgbBuffer(allColors, 0, numComponentColors, colorMap, 0, bpc, 0);
 
-       if (!needsResizing) {
 
-         let destPos = 0;
 
-         for (let i = 0; i < count; ++i) {
 
-           const key = comps[i] * 3;
 
-           dest[destPos++] = colorMap[key];
 
-           dest[destPos++] = colorMap[key + 1];
 
-           dest[destPos++] = colorMap[key + 2];
 
-           destPos += alpha01;
 
-         }
 
-       } else {
 
-         rgbBuf = new Uint8Array(count * 3);
 
-         let rgbPos = 0;
 
-         for (let i = 0; i < count; ++i) {
 
-           const key = comps[i] * 3;
 
-           rgbBuf[rgbPos++] = colorMap[key];
 
-           rgbBuf[rgbPos++] = colorMap[key + 1];
 
-           rgbBuf[rgbPos++] = colorMap[key + 2];
 
-         }
 
-       }
 
-     } else {
 
-       if (!needsResizing) {
 
-         this.getRgbBuffer(comps, 0, width * actualHeight, dest, 0, bpc, alpha01);
 
-       } else {
 
-         rgbBuf = new Uint8ClampedArray(count * 3);
 
-         this.getRgbBuffer(comps, 0, count, rgbBuf, 0, bpc, 0);
 
-       }
 
-     }
 
-     if (rgbBuf) {
 
-       if (needsResizing) {
 
-         resizeRgbImage(rgbBuf, dest, originalWidth, originalHeight, width, height, alpha01);
 
-       } else {
 
-         let destPos = 0,
 
-             rgbPos = 0;
 
-         for (let i = 0, ii = width * actualHeight; i < ii; i++) {
 
-           dest[destPos++] = rgbBuf[rgbPos++];
 
-           dest[destPos++] = rgbBuf[rgbPos++];
 
-           dest[destPos++] = rgbBuf[rgbPos++];
 
-           destPos += alpha01;
 
-         }
 
-       }
 
-     }
 
-   }
 
-   get usesZeroToOneRange() {
 
-     return (0, _util.shadow)(this, "usesZeroToOneRange", true);
 
-   }
 
-   static parse(cs, xref, res, pdfFunctionFactory) {
 
-     const IR = this.parseToIR(cs, xref, res, pdfFunctionFactory);
 
-     return this.fromIR(IR);
 
-   }
 
-   static fromIR(IR) {
 
-     const name = Array.isArray(IR) ? IR[0] : IR;
 
-     let whitePoint, blackPoint, gamma;
 
-     switch (name) {
 
-       case "DeviceGrayCS":
 
-         return this.singletons.gray;
 
-       case "DeviceRgbCS":
 
-         return this.singletons.rgb;
 
-       case "DeviceCmykCS":
 
-         return this.singletons.cmyk;
 
-       case "CalGrayCS":
 
-         whitePoint = IR[1];
 
-         blackPoint = IR[2];
 
-         gamma = IR[3];
 
-         return new CalGrayCS(whitePoint, blackPoint, gamma);
 
-       case "CalRGBCS":
 
-         whitePoint = IR[1];
 
-         blackPoint = IR[2];
 
-         gamma = IR[3];
 
-         const matrix = IR[4];
 
-         return new CalRGBCS(whitePoint, blackPoint, gamma, matrix);
 
-       case "PatternCS":
 
-         let basePatternCS = IR[1];
 
-         if (basePatternCS) {
 
-           basePatternCS = this.fromIR(basePatternCS);
 
-         }
 
-         return new PatternCS(basePatternCS);
 
-       case "IndexedCS":
 
-         const baseIndexedCS = IR[1];
 
-         const hiVal = IR[2];
 
-         const lookup = IR[3];
 
-         return new IndexedCS(this.fromIR(baseIndexedCS), hiVal, lookup);
 
-       case "AlternateCS":
 
-         const numComps = IR[1];
 
-         const alt = IR[2];
 
-         const tintFn = IR[3];
 
-         return new AlternateCS(numComps, this.fromIR(alt), tintFn);
 
-       case "LabCS":
 
-         whitePoint = IR[1];
 
-         blackPoint = IR[2];
 
-         const range = IR[3];
 
-         return new LabCS(whitePoint, blackPoint, range);
 
-       default:
 
-         throw new _util.FormatError(`Unknown colorspace name: ${name}`);
 
-     }
 
-   }
 
-   static parseToIR(cs, xref, res = null, pdfFunctionFactory) {
 
-     cs = xref.fetchIfRef(cs);
 
-     if ((0, _primitives.isName)(cs)) {
 
-       switch (cs.name) {
 
-         case "DeviceGray":
 
-         case "G":
 
-           return "DeviceGrayCS";
 
-         case "DeviceRGB":
 
-         case "RGB":
 
-           return "DeviceRgbCS";
 
-         case "DeviceCMYK":
 
-         case "CMYK":
 
-           return "DeviceCmykCS";
 
-         case "Pattern":
 
-           return ["PatternCS", null];
 
-         default:
 
-           if ((0, _primitives.isDict)(res)) {
 
-             const colorSpaces = res.get("ColorSpace");
 
-             if ((0, _primitives.isDict)(colorSpaces)) {
 
-               const resCS = colorSpaces.get(cs.name);
 
-               if (resCS) {
 
-                 if ((0, _primitives.isName)(resCS)) {
 
-                   return this.parseToIR(resCS, xref, res, pdfFunctionFactory);
 
-                 }
 
-                 cs = resCS;
 
-                 break;
 
-               }
 
-             }
 
-           }
 
-           throw new _util.FormatError(`unrecognized colorspace ${cs.name}`);
 
-       }
 
-     }
 
-     if (Array.isArray(cs)) {
 
-       const mode = xref.fetchIfRef(cs[0]).name;
 
-       let numComps, params, alt, whitePoint, blackPoint, gamma;
 
-       switch (mode) {
 
-         case "DeviceGray":
 
-         case "G":
 
-           return "DeviceGrayCS";
 
-         case "DeviceRGB":
 
-         case "RGB":
 
-           return "DeviceRgbCS";
 
-         case "DeviceCMYK":
 
-         case "CMYK":
 
-           return "DeviceCmykCS";
 
-         case "CalGray":
 
-           params = xref.fetchIfRef(cs[1]);
 
-           whitePoint = params.getArray("WhitePoint");
 
-           blackPoint = params.getArray("BlackPoint");
 
-           gamma = params.get("Gamma");
 
-           return ["CalGrayCS", whitePoint, blackPoint, gamma];
 
-         case "CalRGB":
 
-           params = xref.fetchIfRef(cs[1]);
 
-           whitePoint = params.getArray("WhitePoint");
 
-           blackPoint = params.getArray("BlackPoint");
 
-           gamma = params.getArray("Gamma");
 
-           const matrix = params.getArray("Matrix");
 
-           return ["CalRGBCS", whitePoint, blackPoint, gamma, matrix];
 
-         case "ICCBased":
 
-           const stream = xref.fetchIfRef(cs[1]);
 
-           const dict = stream.dict;
 
-           numComps = dict.get("N");
 
-           alt = dict.get("Alternate");
 
-           if (alt) {
 
-             const altIR = this.parseToIR(alt, xref, res, pdfFunctionFactory);
 
-             const altCS = this.fromIR(altIR, pdfFunctionFactory);
 
-             if (altCS.numComps === numComps) {
 
-               return altIR;
 
-             }
 
-             (0, _util.warn)("ICCBased color space: Ignoring incorrect /Alternate entry.");
 
-           }
 
-           if (numComps === 1) {
 
-             return "DeviceGrayCS";
 
-           } else if (numComps === 3) {
 
-             return "DeviceRgbCS";
 
-           } else if (numComps === 4) {
 
-             return "DeviceCmykCS";
 
-           }
 
-           break;
 
-         case "Pattern":
 
-           let basePatternCS = cs[1] || null;
 
-           if (basePatternCS) {
 
-             basePatternCS = this.parseToIR(basePatternCS, xref, res, pdfFunctionFactory);
 
-           }
 
-           return ["PatternCS", basePatternCS];
 
-         case "Indexed":
 
-         case "I":
 
-           const baseIndexedCS = this.parseToIR(cs[1], xref, res, pdfFunctionFactory);
 
-           const hiVal = xref.fetchIfRef(cs[2]) + 1;
 
-           let lookup = xref.fetchIfRef(cs[3]);
 
-           if ((0, _primitives.isStream)(lookup)) {
 
-             lookup = lookup.getBytes();
 
-           }
 
-           return ["IndexedCS", baseIndexedCS, hiVal, lookup];
 
-         case "Separation":
 
-         case "DeviceN":
 
-           const name = xref.fetchIfRef(cs[1]);
 
-           numComps = Array.isArray(name) ? name.length : 1;
 
-           alt = this.parseToIR(cs[2], xref, res, pdfFunctionFactory);
 
-           const tintFn = pdfFunctionFactory.create(xref.fetchIfRef(cs[3]));
 
-           return ["AlternateCS", numComps, alt, tintFn];
 
-         case "Lab":
 
-           params = xref.fetchIfRef(cs[1]);
 
-           whitePoint = params.getArray("WhitePoint");
 
-           blackPoint = params.getArray("BlackPoint");
 
-           const range = params.getArray("Range");
 
-           return ["LabCS", whitePoint, blackPoint, range];
 
-         default:
 
-           throw new _util.FormatError(`unimplemented color space object "${mode}"`);
 
-       }
 
-     }
 
-     throw new _util.FormatError(`unrecognized color space object: "${cs}"`);
 
-   }
 
-   static isDefaultDecode(decode, numComps) {
 
-     if (!Array.isArray(decode)) {
 
-       return true;
 
-     }
 
-     if (numComps * 2 !== decode.length) {
 
-       (0, _util.warn)("The decode map is not the correct length");
 
-       return true;
 
-     }
 
-     for (let i = 0, ii = decode.length; i < ii; i += 2) {
 
-       if (decode[i] !== 0 || decode[i + 1] !== 1) {
 
-         return false;
 
-       }
 
-     }
 
-     return true;
 
-   }
 
-   static get singletons() {
 
-     return (0, _util.shadow)(this, "singletons", {
 
-       get gray() {
 
-         return (0, _util.shadow)(this, "gray", new DeviceGrayCS());
 
-       },
 
-       get rgb() {
 
-         return (0, _util.shadow)(this, "rgb", new DeviceRgbCS());
 
-       },
 
-       get cmyk() {
 
-         return (0, _util.shadow)(this, "cmyk", new DeviceCmykCS());
 
-       }
 
-     });
 
-   }
 
- }
 
- exports.ColorSpace = ColorSpace;
 
- class AlternateCS extends ColorSpace {
 
-   constructor(numComps, base, tintFn) {
 
-     super("Alternate", numComps);
 
-     this.base = base;
 
-     this.tintFn = tintFn;
 
-     this.tmpBuf = new Float32Array(base.numComps);
 
-   }
 
-   getRgbItem(src, srcOffset, dest, destOffset) {
 
-     const tmpBuf = this.tmpBuf;
 
-     this.tintFn(src, srcOffset, tmpBuf, 0);
 
-     this.base.getRgbItem(tmpBuf, 0, dest, destOffset);
 
-   }
 
-   getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-     const tintFn = this.tintFn;
 
-     const base = this.base;
 
-     const scale = 1 / ((1 << bits) - 1);
 
-     const baseNumComps = base.numComps;
 
-     const usesZeroToOneRange = base.usesZeroToOneRange;
 
-     const isPassthrough = (base.isPassthrough(8) || !usesZeroToOneRange) && alpha01 === 0;
 
-     let pos = isPassthrough ? destOffset : 0;
 
-     const baseBuf = isPassthrough ? dest : new Uint8ClampedArray(baseNumComps * count);
 
-     const numComps = this.numComps;
 
-     const scaled = new Float32Array(numComps);
 
-     const tinted = new Float32Array(baseNumComps);
 
-     let i, j;
 
-     for (i = 0; i < count; i++) {
 
-       for (j = 0; j < numComps; j++) {
 
-         scaled[j] = src[srcOffset++] * scale;
 
-       }
 
-       tintFn(scaled, 0, tinted, 0);
 
-       if (usesZeroToOneRange) {
 
-         for (j = 0; j < baseNumComps; j++) {
 
-           baseBuf[pos++] = tinted[j] * 255;
 
-         }
 
-       } else {
 
-         base.getRgbItem(tinted, 0, baseBuf, pos);
 
-         pos += baseNumComps;
 
-       }
 
-     }
 
-     if (!isPassthrough) {
 
-       base.getRgbBuffer(baseBuf, 0, count, dest, destOffset, 8, alpha01);
 
-     }
 
-   }
 
-   getOutputLength(inputLength, alpha01) {
 
-     return this.base.getOutputLength(inputLength * this.base.numComps / this.numComps, alpha01);
 
-   }
 
- }
 
- class PatternCS extends ColorSpace {
 
-   constructor(baseCS) {
 
-     super("Pattern", null);
 
-     this.base = baseCS;
 
-   }
 
-   isDefaultDecode(decodeMap, bpc) {
 
-     (0, _util.unreachable)("Should not call PatternCS.isDefaultDecode");
 
-   }
 
- }
 
- class IndexedCS extends ColorSpace {
 
-   constructor(base, highVal, lookup) {
 
-     super("Indexed", 1);
 
-     this.base = base;
 
-     this.highVal = highVal;
 
-     const baseNumComps = base.numComps;
 
-     const length = baseNumComps * highVal;
 
-     if ((0, _primitives.isStream)(lookup)) {
 
-       this.lookup = new Uint8Array(length);
 
-       const bytes = lookup.getBytes(length);
 
-       this.lookup.set(bytes);
 
-     } else if ((0, _util.isString)(lookup)) {
 
-       this.lookup = new Uint8Array(length);
 
-       for (let i = 0; i < length; ++i) {
 
-         this.lookup[i] = lookup.charCodeAt(i);
 
-       }
 
-     } else if (lookup instanceof Uint8Array) {
 
-       this.lookup = lookup;
 
-     } else {
 
-       throw new _util.FormatError(`Unrecognized lookup table: ${lookup}`);
 
-     }
 
-   }
 
-   getRgbItem(src, srcOffset, dest, destOffset) {
 
-     const numComps = this.base.numComps;
 
-     const start = src[srcOffset] * numComps;
 
-     this.base.getRgbBuffer(this.lookup, start, 1, dest, destOffset, 8, 0);
 
-   }
 
-   getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-     const base = this.base;
 
-     const numComps = base.numComps;
 
-     const outputDelta = base.getOutputLength(numComps, alpha01);
 
-     const lookup = this.lookup;
 
-     for (let i = 0; i < count; ++i) {
 
-       const lookupPos = src[srcOffset++] * numComps;
 
-       base.getRgbBuffer(lookup, lookupPos, 1, dest, destOffset, 8, alpha01);
 
-       destOffset += outputDelta;
 
-     }
 
-   }
 
-   getOutputLength(inputLength, alpha01) {
 
-     return this.base.getOutputLength(inputLength * this.base.numComps, alpha01);
 
-   }
 
-   isDefaultDecode(decodeMap, bpc) {
 
-     if (!Array.isArray(decodeMap)) {
 
-       return true;
 
-     }
 
-     if (decodeMap.length !== 2) {
 
-       (0, _util.warn)("Decode map length is not correct");
 
-       return true;
 
-     }
 
-     if (!Number.isInteger(bpc) || bpc < 1) {
 
-       (0, _util.warn)("Bits per component is not correct");
 
-       return true;
 
-     }
 
-     return decodeMap[0] === 0 && decodeMap[1] === (1 << bpc) - 1;
 
-   }
 
- }
 
- class DeviceGrayCS extends ColorSpace {
 
-   constructor() {
 
-     super("DeviceGray", 1);
 
-   }
 
-   getRgbItem(src, srcOffset, dest, destOffset) {
 
-     const c = src[srcOffset] * 255;
 
-     dest[destOffset] = dest[destOffset + 1] = dest[destOffset + 2] = c;
 
-   }
 
-   getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-     const scale = 255 / ((1 << bits) - 1);
 
-     let j = srcOffset,
 
-         q = destOffset;
 
-     for (let i = 0; i < count; ++i) {
 
-       const c = scale * src[j++];
 
-       dest[q++] = c;
 
-       dest[q++] = c;
 
-       dest[q++] = c;
 
-       q += alpha01;
 
-     }
 
-   }
 
-   getOutputLength(inputLength, alpha01) {
 
-     return inputLength * (3 + alpha01);
 
-   }
 
- }
 
- class DeviceRgbCS extends ColorSpace {
 
-   constructor() {
 
-     super("DeviceRGB", 3);
 
-   }
 
-   getRgbItem(src, srcOffset, dest, destOffset) {
 
-     dest[destOffset] = src[srcOffset] * 255;
 
-     dest[destOffset + 1] = src[srcOffset + 1] * 255;
 
-     dest[destOffset + 2] = src[srcOffset + 2] * 255;
 
-   }
 
-   getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-     if (bits === 8 && alpha01 === 0) {
 
-       dest.set(src.subarray(srcOffset, srcOffset + count * 3), destOffset);
 
-       return;
 
-     }
 
-     const scale = 255 / ((1 << bits) - 1);
 
-     let j = srcOffset,
 
-         q = destOffset;
 
-     for (let i = 0; i < count; ++i) {
 
-       dest[q++] = scale * src[j++];
 
-       dest[q++] = scale * src[j++];
 
-       dest[q++] = scale * src[j++];
 
-       q += alpha01;
 
-     }
 
-   }
 
-   getOutputLength(inputLength, alpha01) {
 
-     return inputLength * (3 + alpha01) / 3 | 0;
 
-   }
 
-   isPassthrough(bits) {
 
-     return bits === 8;
 
-   }
 
- }
 
- const DeviceCmykCS = function DeviceCmykCSClosure() {
 
-   function convertToRgb(src, srcOffset, srcScale, dest, destOffset) {
 
-     const c = src[srcOffset] * srcScale;
 
-     const m = src[srcOffset + 1] * srcScale;
 
-     const y = src[srcOffset + 2] * srcScale;
 
-     const k = src[srcOffset + 3] * srcScale;
 
-     dest[destOffset] = 255 + c * (-4.387332384609988 * c + 54.48615194189176 * m + 18.82290502165302 * y + 212.25662451639585 * k + -285.2331026137004) + m * (1.7149763477362134 * m - 5.6096736904047315 * y + -17.873870861415444 * k - 5.497006427196366) + y * (-2.5217340131683033 * y - 21.248923337353073 * k + 17.5119270841813) + k * (-21.86122147463605 * k - 189.48180835922747);
 
-     dest[destOffset + 1] = 255 + c * (8.841041422036149 * c + 60.118027045597366 * m + 6.871425592049007 * y + 31.159100130055922 * k + -79.2970844816548) + m * (-15.310361306967817 * m + 17.575251261109482 * y + 131.35250912493976 * k - 190.9453302588951) + y * (4.444339102852739 * y + 9.8632861493405 * k - 24.86741582555878) + k * (-20.737325471181034 * k - 187.80453709719578);
 
-     dest[destOffset + 2] = 255 + c * (0.8842522430003296 * c + 8.078677503112928 * m + 30.89978309703729 * y - 0.23883238689178934 * k + -14.183576799673286) + m * (10.49593273432072 * m + 63.02378494754052 * y + 50.606957656360734 * k - 112.23884253719248) + y * (0.03296041114873217 * y + 115.60384449646641 * k + -193.58209356861505) + k * (-22.33816807309886 * k - 180.12613974708367);
 
-   }
 
-   class DeviceCmykCS extends ColorSpace {
 
-     constructor() {
 
-       super("DeviceCMYK", 4);
 
-     }
 
-     getRgbItem(src, srcOffset, dest, destOffset) {
 
-       convertToRgb(src, srcOffset, 1, dest, destOffset);
 
-     }
 
-     getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-       const scale = 1 / ((1 << bits) - 1);
 
-       for (let i = 0; i < count; i++) {
 
-         convertToRgb(src, srcOffset, scale, dest, destOffset);
 
-         srcOffset += 4;
 
-         destOffset += 3 + alpha01;
 
-       }
 
-     }
 
-     getOutputLength(inputLength, alpha01) {
 
-       return inputLength / 4 * (3 + alpha01) | 0;
 
-     }
 
-   }
 
-   return DeviceCmykCS;
 
- }();
 
- const CalGrayCS = function CalGrayCSClosure() {
 
-   function convertToRgb(cs, src, srcOffset, dest, destOffset, scale) {
 
-     const A = src[srcOffset] * scale;
 
-     const AG = A ** cs.G;
 
-     const L = cs.YW * AG;
 
-     const val = Math.max(295.8 * L ** 0.333333333333333333 - 40.8, 0);
 
-     dest[destOffset] = val;
 
-     dest[destOffset + 1] = val;
 
-     dest[destOffset + 2] = val;
 
-   }
 
-   class CalGrayCS extends ColorSpace {
 
-     constructor(whitePoint, blackPoint, gamma) {
 
-       super("CalGray", 1);
 
-       if (!whitePoint) {
 
-         throw new _util.FormatError("WhitePoint missing - required for color space CalGray");
 
-       }
 
-       blackPoint = blackPoint || [0, 0, 0];
 
-       gamma = gamma || 1;
 
-       this.XW = whitePoint[0];
 
-       this.YW = whitePoint[1];
 
-       this.ZW = whitePoint[2];
 
-       this.XB = blackPoint[0];
 
-       this.YB = blackPoint[1];
 
-       this.ZB = blackPoint[2];
 
-       this.G = gamma;
 
-       if (this.XW < 0 || this.ZW < 0 || this.YW !== 1) {
 
-         throw new _util.FormatError(`Invalid WhitePoint components for ${this.name}` + ", no fallback available");
 
-       }
 
-       if (this.XB < 0 || this.YB < 0 || this.ZB < 0) {
 
-         (0, _util.info)(`Invalid BlackPoint for ${this.name}, falling back to default.`);
 
-         this.XB = this.YB = this.ZB = 0;
 
-       }
 
-       if (this.XB !== 0 || this.YB !== 0 || this.ZB !== 0) {
 
-         (0, _util.warn)(`${this.name}, BlackPoint: XB: ${this.XB}, YB: ${this.YB}, ` + `ZB: ${this.ZB}, only default values are supported.`);
 
-       }
 
-       if (this.G < 1) {
 
-         (0, _util.info)(`Invalid Gamma: ${this.G} for ${this.name}, ` + "falling back to default.");
 
-         this.G = 1;
 
-       }
 
-     }
 
-     getRgbItem(src, srcOffset, dest, destOffset) {
 
-       convertToRgb(this, src, srcOffset, dest, destOffset, 1);
 
-     }
 
-     getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-       const scale = 1 / ((1 << bits) - 1);
 
-       for (let i = 0; i < count; ++i) {
 
-         convertToRgb(this, src, srcOffset, dest, destOffset, scale);
 
-         srcOffset += 1;
 
-         destOffset += 3 + alpha01;
 
-       }
 
-     }
 
-     getOutputLength(inputLength, alpha01) {
 
-       return inputLength * (3 + alpha01);
 
-     }
 
-   }
 
-   return CalGrayCS;
 
- }();
 
- const CalRGBCS = function CalRGBCSClosure() {
 
-   const BRADFORD_SCALE_MATRIX = new Float32Array([0.8951, 0.2664, -0.1614, -0.7502, 1.7135, 0.0367, 0.0389, -0.0685, 1.0296]);
 
-   const BRADFORD_SCALE_INVERSE_MATRIX = new Float32Array([0.9869929, -0.1470543, 0.1599627, 0.4323053, 0.5183603, 0.0492912, -0.0085287, 0.0400428, 0.9684867]);
 
-   const SRGB_D65_XYZ_TO_RGB_MATRIX = new Float32Array([3.2404542, -1.5371385, -0.4985314, -0.9692660, 1.8760108, 0.0415560, 0.0556434, -0.2040259, 1.0572252]);
 
-   const FLAT_WHITEPOINT_MATRIX = new Float32Array([1, 1, 1]);
 
-   const tempNormalizeMatrix = new Float32Array(3);
 
-   const tempConvertMatrix1 = new Float32Array(3);
 
-   const tempConvertMatrix2 = new Float32Array(3);
 
-   const DECODE_L_CONSTANT = ((8 + 16) / 116) ** 3 / 8.0;
 
-   function matrixProduct(a, b, result) {
 
-     result[0] = a[0] * b[0] + a[1] * b[1] + a[2] * b[2];
 
-     result[1] = a[3] * b[0] + a[4] * b[1] + a[5] * b[2];
 
-     result[2] = a[6] * b[0] + a[7] * b[1] + a[8] * b[2];
 
-   }
 
-   function convertToFlat(sourceWhitePoint, LMS, result) {
 
-     result[0] = LMS[0] * 1 / sourceWhitePoint[0];
 
-     result[1] = LMS[1] * 1 / sourceWhitePoint[1];
 
-     result[2] = LMS[2] * 1 / sourceWhitePoint[2];
 
-   }
 
-   function convertToD65(sourceWhitePoint, LMS, result) {
 
-     const D65X = 0.95047;
 
-     const D65Y = 1;
 
-     const D65Z = 1.08883;
 
-     result[0] = LMS[0] * D65X / sourceWhitePoint[0];
 
-     result[1] = LMS[1] * D65Y / sourceWhitePoint[1];
 
-     result[2] = LMS[2] * D65Z / sourceWhitePoint[2];
 
-   }
 
-   function sRGBTransferFunction(color) {
 
-     if (color <= 0.0031308) {
 
-       return adjustToRange(0, 1, 12.92 * color);
 
-     }
 
-     return adjustToRange(0, 1, (1 + 0.055) * color ** (1 / 2.4) - 0.055);
 
-   }
 
-   function adjustToRange(min, max, value) {
 
-     return Math.max(min, Math.min(max, value));
 
-   }
 
-   function decodeL(L) {
 
-     if (L < 0) {
 
-       return -decodeL(-L);
 
-     }
 
-     if (L > 8.0) {
 
-       return ((L + 16) / 116) ** 3;
 
-     }
 
-     return L * DECODE_L_CONSTANT;
 
-   }
 
-   function compensateBlackPoint(sourceBlackPoint, XYZ_Flat, result) {
 
-     if (sourceBlackPoint[0] === 0 && sourceBlackPoint[1] === 0 && sourceBlackPoint[2] === 0) {
 
-       result[0] = XYZ_Flat[0];
 
-       result[1] = XYZ_Flat[1];
 
-       result[2] = XYZ_Flat[2];
 
-       return;
 
-     }
 
-     const zeroDecodeL = decodeL(0);
 
-     const X_DST = zeroDecodeL;
 
-     const X_SRC = decodeL(sourceBlackPoint[0]);
 
-     const Y_DST = zeroDecodeL;
 
-     const Y_SRC = decodeL(sourceBlackPoint[1]);
 
-     const Z_DST = zeroDecodeL;
 
-     const Z_SRC = decodeL(sourceBlackPoint[2]);
 
-     const X_Scale = (1 - X_DST) / (1 - X_SRC);
 
-     const X_Offset = 1 - X_Scale;
 
-     const Y_Scale = (1 - Y_DST) / (1 - Y_SRC);
 
-     const Y_Offset = 1 - Y_Scale;
 
-     const Z_Scale = (1 - Z_DST) / (1 - Z_SRC);
 
-     const Z_Offset = 1 - Z_Scale;
 
-     result[0] = XYZ_Flat[0] * X_Scale + X_Offset;
 
-     result[1] = XYZ_Flat[1] * Y_Scale + Y_Offset;
 
-     result[2] = XYZ_Flat[2] * Z_Scale + Z_Offset;
 
-   }
 
-   function normalizeWhitePointToFlat(sourceWhitePoint, XYZ_In, result) {
 
-     if (sourceWhitePoint[0] === 1 && sourceWhitePoint[2] === 1) {
 
-       result[0] = XYZ_In[0];
 
-       result[1] = XYZ_In[1];
 
-       result[2] = XYZ_In[2];
 
-       return;
 
-     }
 
-     const LMS = result;
 
-     matrixProduct(BRADFORD_SCALE_MATRIX, XYZ_In, LMS);
 
-     const LMS_Flat = tempNormalizeMatrix;
 
-     convertToFlat(sourceWhitePoint, LMS, LMS_Flat);
 
-     matrixProduct(BRADFORD_SCALE_INVERSE_MATRIX, LMS_Flat, result);
 
-   }
 
-   function normalizeWhitePointToD65(sourceWhitePoint, XYZ_In, result) {
 
-     const LMS = result;
 
-     matrixProduct(BRADFORD_SCALE_MATRIX, XYZ_In, LMS);
 
-     const LMS_D65 = tempNormalizeMatrix;
 
-     convertToD65(sourceWhitePoint, LMS, LMS_D65);
 
-     matrixProduct(BRADFORD_SCALE_INVERSE_MATRIX, LMS_D65, result);
 
-   }
 
-   function convertToRgb(cs, src, srcOffset, dest, destOffset, scale) {
 
-     const A = adjustToRange(0, 1, src[srcOffset] * scale);
 
-     const B = adjustToRange(0, 1, src[srcOffset + 1] * scale);
 
-     const C = adjustToRange(0, 1, src[srcOffset + 2] * scale);
 
-     const AGR = A ** cs.GR;
 
-     const BGG = B ** cs.GG;
 
-     const CGB = C ** cs.GB;
 
-     const X = cs.MXA * AGR + cs.MXB * BGG + cs.MXC * CGB;
 
-     const Y = cs.MYA * AGR + cs.MYB * BGG + cs.MYC * CGB;
 
-     const Z = cs.MZA * AGR + cs.MZB * BGG + cs.MZC * CGB;
 
-     const XYZ = tempConvertMatrix1;
 
-     XYZ[0] = X;
 
-     XYZ[1] = Y;
 
-     XYZ[2] = Z;
 
-     const XYZ_Flat = tempConvertMatrix2;
 
-     normalizeWhitePointToFlat(cs.whitePoint, XYZ, XYZ_Flat);
 
-     const XYZ_Black = tempConvertMatrix1;
 
-     compensateBlackPoint(cs.blackPoint, XYZ_Flat, XYZ_Black);
 
-     const XYZ_D65 = tempConvertMatrix2;
 
-     normalizeWhitePointToD65(FLAT_WHITEPOINT_MATRIX, XYZ_Black, XYZ_D65);
 
-     const SRGB = tempConvertMatrix1;
 
-     matrixProduct(SRGB_D65_XYZ_TO_RGB_MATRIX, XYZ_D65, SRGB);
 
-     dest[destOffset] = sRGBTransferFunction(SRGB[0]) * 255;
 
-     dest[destOffset + 1] = sRGBTransferFunction(SRGB[1]) * 255;
 
-     dest[destOffset + 2] = sRGBTransferFunction(SRGB[2]) * 255;
 
-   }
 
-   class CalRGBCS extends ColorSpace {
 
-     constructor(whitePoint, blackPoint, gamma, matrix) {
 
-       super("CalRGB", 3);
 
-       if (!whitePoint) {
 
-         throw new _util.FormatError("WhitePoint missing - required for color space CalRGB");
 
-       }
 
-       blackPoint = blackPoint || new Float32Array(3);
 
-       gamma = gamma || new Float32Array([1, 1, 1]);
 
-       matrix = matrix || new Float32Array([1, 0, 0, 0, 1, 0, 0, 0, 1]);
 
-       const XW = whitePoint[0];
 
-       const YW = whitePoint[1];
 
-       const ZW = whitePoint[2];
 
-       this.whitePoint = whitePoint;
 
-       const XB = blackPoint[0];
 
-       const YB = blackPoint[1];
 
-       const ZB = blackPoint[2];
 
-       this.blackPoint = blackPoint;
 
-       this.GR = gamma[0];
 
-       this.GG = gamma[1];
 
-       this.GB = gamma[2];
 
-       this.MXA = matrix[0];
 
-       this.MYA = matrix[1];
 
-       this.MZA = matrix[2];
 
-       this.MXB = matrix[3];
 
-       this.MYB = matrix[4];
 
-       this.MZB = matrix[5];
 
-       this.MXC = matrix[6];
 
-       this.MYC = matrix[7];
 
-       this.MZC = matrix[8];
 
-       if (XW < 0 || ZW < 0 || YW !== 1) {
 
-         throw new _util.FormatError(`Invalid WhitePoint components for ${this.name}` + ", no fallback available");
 
-       }
 
-       if (XB < 0 || YB < 0 || ZB < 0) {
 
-         (0, _util.info)(`Invalid BlackPoint for ${this.name} [${XB}, ${YB}, ${ZB}], ` + "falling back to default.");
 
-         this.blackPoint = new Float32Array(3);
 
-       }
 
-       if (this.GR < 0 || this.GG < 0 || this.GB < 0) {
 
-         (0, _util.info)(`Invalid Gamma [${this.GR}, ${this.GG}, ${this.GB}] for ` + `${this.name}, falling back to default.`);
 
-         this.GR = this.GG = this.GB = 1;
 
-       }
 
-     }
 
-     getRgbItem(src, srcOffset, dest, destOffset) {
 
-       convertToRgb(this, src, srcOffset, dest, destOffset, 1);
 
-     }
 
-     getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-       const scale = 1 / ((1 << bits) - 1);
 
-       for (let i = 0; i < count; ++i) {
 
-         convertToRgb(this, src, srcOffset, dest, destOffset, scale);
 
-         srcOffset += 3;
 
-         destOffset += 3 + alpha01;
 
-       }
 
-     }
 
-     getOutputLength(inputLength, alpha01) {
 
-       return inputLength * (3 + alpha01) / 3 | 0;
 
-     }
 
-   }
 
-   return CalRGBCS;
 
- }();
 
- const LabCS = function LabCSClosure() {
 
-   function fn_g(x) {
 
-     let result;
 
-     if (x >= 6 / 29) {
 
-       result = x * x * x;
 
-     } else {
 
-       result = 108 / 841 * (x - 4 / 29);
 
-     }
 
-     return result;
 
-   }
 
-   function decode(value, high1, low2, high2) {
 
-     return low2 + value * (high2 - low2) / high1;
 
-   }
 
-   function convertToRgb(cs, src, srcOffset, maxVal, dest, destOffset) {
 
-     let Ls = src[srcOffset];
 
-     let as = src[srcOffset + 1];
 
-     let bs = src[srcOffset + 2];
 
-     if (maxVal !== false) {
 
-       Ls = decode(Ls, maxVal, 0, 100);
 
-       as = decode(as, maxVal, cs.amin, cs.amax);
 
-       bs = decode(bs, maxVal, cs.bmin, cs.bmax);
 
-     }
 
-     if (as > cs.amax) {
 
-       as = cs.amax;
 
-     } else if (as < cs.amin) {
 
-       as = cs.amin;
 
-     }
 
-     if (bs > cs.bmax) {
 
-       bs = cs.bmax;
 
-     } else if (bs < cs.bmin) {
 
-       bs = cs.bmin;
 
-     }
 
-     const M = (Ls + 16) / 116;
 
-     const L = M + as / 500;
 
-     const N = M - bs / 200;
 
-     const X = cs.XW * fn_g(L);
 
-     const Y = cs.YW * fn_g(M);
 
-     const Z = cs.ZW * fn_g(N);
 
-     let r, g, b;
 
-     if (cs.ZW < 1) {
 
-       r = X * 3.1339 + Y * -1.617 + Z * -0.4906;
 
-       g = X * -0.9785 + Y * 1.916 + Z * 0.0333;
 
-       b = X * 0.072 + Y * -0.229 + Z * 1.4057;
 
-     } else {
 
-       r = X * 3.2406 + Y * -1.5372 + Z * -0.4986;
 
-       g = X * -0.9689 + Y * 1.8758 + Z * 0.0415;
 
-       b = X * 0.0557 + Y * -0.204 + Z * 1.057;
 
-     }
 
-     dest[destOffset] = Math.sqrt(r) * 255;
 
-     dest[destOffset + 1] = Math.sqrt(g) * 255;
 
-     dest[destOffset + 2] = Math.sqrt(b) * 255;
 
-   }
 
-   class LabCS extends ColorSpace {
 
-     constructor(whitePoint, blackPoint, range) {
 
-       super("Lab", 3);
 
-       if (!whitePoint) {
 
-         throw new _util.FormatError("WhitePoint missing - required for color space Lab");
 
-       }
 
-       blackPoint = blackPoint || [0, 0, 0];
 
-       range = range || [-100, 100, -100, 100];
 
-       this.XW = whitePoint[0];
 
-       this.YW = whitePoint[1];
 
-       this.ZW = whitePoint[2];
 
-       this.amin = range[0];
 
-       this.amax = range[1];
 
-       this.bmin = range[2];
 
-       this.bmax = range[3];
 
-       this.XB = blackPoint[0];
 
-       this.YB = blackPoint[1];
 
-       this.ZB = blackPoint[2];
 
-       if (this.XW < 0 || this.ZW < 0 || this.YW !== 1) {
 
-         throw new _util.FormatError("Invalid WhitePoint components, no fallback available");
 
-       }
 
-       if (this.XB < 0 || this.YB < 0 || this.ZB < 0) {
 
-         (0, _util.info)("Invalid BlackPoint, falling back to default");
 
-         this.XB = this.YB = this.ZB = 0;
 
-       }
 
-       if (this.amin > this.amax || this.bmin > this.bmax) {
 
-         (0, _util.info)("Invalid Range, falling back to defaults");
 
-         this.amin = -100;
 
-         this.amax = 100;
 
-         this.bmin = -100;
 
-         this.bmax = 100;
 
-       }
 
-     }
 
-     getRgbItem(src, srcOffset, dest, destOffset) {
 
-       convertToRgb(this, src, srcOffset, false, dest, destOffset);
 
-     }
 
-     getRgbBuffer(src, srcOffset, count, dest, destOffset, bits, alpha01) {
 
-       const maxVal = (1 << bits) - 1;
 
-       for (let i = 0; i < count; i++) {
 
-         convertToRgb(this, src, srcOffset, maxVal, dest, destOffset);
 
-         srcOffset += 3;
 
-         destOffset += 3 + alpha01;
 
-       }
 
-     }
 
-     getOutputLength(inputLength, alpha01) {
 
-       return inputLength * (3 + alpha01) / 3 | 0;
 
-     }
 
-     isDefaultDecode(decodeMap, bpc) {
 
-       return true;
 
-     }
 
-     get usesZeroToOneRange() {
 
-       return (0, _util.shadow)(this, "usesZeroToOneRange", false);
 
-     }
 
-   }
 
-   return LabCS;
 
- }();
 
- /***/ }),
 
- /* 23 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getQuadPoints = getQuadPoints;
 
- exports.MarkupAnnotation = exports.AnnotationFactory = exports.AnnotationBorderStyle = exports.Annotation = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _obj = __w_pdfjs_require__(9);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _colorspace = __w_pdfjs_require__(22);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _operator_list = __w_pdfjs_require__(24);
 
- var _stream = __w_pdfjs_require__(11);
 
- class AnnotationFactory {
 
-   static create(xref, ref, pdfManager, idFactory) {
 
-     return pdfManager.ensure(this, "_create", [xref, ref, pdfManager, idFactory]);
 
-   }
 
-   static _create(xref, ref, pdfManager, idFactory) {
 
-     const dict = xref.fetchIfRef(ref);
 
-     if (!(0, _primitives.isDict)(dict)) {
 
-       return undefined;
 
-     }
 
-     const id = (0, _primitives.isRef)(ref) ? ref.toString() : `annot_${idFactory.createObjId()}`;
 
-     let subtype = dict.get("Subtype");
 
-     subtype = (0, _primitives.isName)(subtype) ? subtype.name : null;
 
-     const parameters = {
 
-       xref,
 
-       dict,
 
-       subtype,
 
-       id,
 
-       pdfManager
 
-     };
 
-     switch (subtype) {
 
-       case "Link":
 
-         return new LinkAnnotation(parameters);
 
-       case "Text":
 
-         return new TextAnnotation(parameters);
 
-       case "Widget":
 
-         let fieldType = (0, _core_utils.getInheritableProperty)({
 
-           dict,
 
-           key: "FT"
 
-         });
 
-         fieldType = (0, _primitives.isName)(fieldType) ? fieldType.name : null;
 
-         switch (fieldType) {
 
-           case "Tx":
 
-             return new TextWidgetAnnotation(parameters);
 
-           case "Btn":
 
-             return new ButtonWidgetAnnotation(parameters);
 
-           case "Ch":
 
-             return new ChoiceWidgetAnnotation(parameters);
 
-         }
 
-         (0, _util.warn)('Unimplemented widget field type "' + fieldType + '", ' + "falling back to base field type.");
 
-         return new WidgetAnnotation(parameters);
 
-       case "Popup":
 
-         return new PopupAnnotation(parameters);
 
-       case "FreeText":
 
-         return new FreeTextAnnotation(parameters);
 
-       case "Line":
 
-         return new LineAnnotation(parameters);
 
-       case "Square":
 
-         return new SquareAnnotation(parameters);
 
-       case "Circle":
 
-         return new CircleAnnotation(parameters);
 
-       case "PolyLine":
 
-         return new PolylineAnnotation(parameters);
 
-       case "Polygon":
 
-         return new PolygonAnnotation(parameters);
 
-       case "Caret":
 
-         return new CaretAnnotation(parameters);
 
-       case "Ink":
 
-         return new InkAnnotation(parameters);
 
-       case "Highlight":
 
-         return new HighlightAnnotation(parameters);
 
-       case "Underline":
 
-         return new UnderlineAnnotation(parameters);
 
-       case "Squiggly":
 
-         return new SquigglyAnnotation(parameters);
 
-       case "StrikeOut":
 
-         return new StrikeOutAnnotation(parameters);
 
-       case "Stamp":
 
-         return new StampAnnotation(parameters);
 
-       case "FileAttachment":
 
-         return new FileAttachmentAnnotation(parameters);
 
-       default:
 
-         if (!subtype) {
 
-           (0, _util.warn)("Annotation is missing the required /Subtype.");
 
-         } else {
 
-           (0, _util.warn)('Unimplemented annotation type "' + subtype + '", ' + "falling back to base annotation.");
 
-         }
 
-         return new Annotation(parameters);
 
-     }
 
-   }
 
- }
 
- exports.AnnotationFactory = AnnotationFactory;
 
- function getQuadPoints(dict, rect) {
 
-   if (!dict.has("QuadPoints")) {
 
-     return null;
 
-   }
 
-   const quadPoints = dict.getArray("QuadPoints");
 
-   if (!Array.isArray(quadPoints) || quadPoints.length % 8 > 0) {
 
-     return null;
 
-   }
 
-   const quadPointsLists = [];
 
-   for (let i = 0, ii = quadPoints.length / 8; i < ii; i++) {
 
-     quadPointsLists.push([]);
 
-     for (let j = i * 8, jj = i * 8 + 8; j < jj; j += 2) {
 
-       const x = quadPoints[j];
 
-       const y = quadPoints[j + 1];
 
-       if (x < rect[0] || x > rect[2] || y < rect[1] || y > rect[3]) {
 
-         return null;
 
-       }
 
-       quadPointsLists[i].push({
 
-         x,
 
-         y
 
-       });
 
-     }
 
-   }
 
-   return quadPointsLists;
 
- }
 
- function getTransformMatrix(rect, bbox, matrix) {
 
-   const [minX, minY, maxX, maxY] = _util.Util.getAxialAlignedBoundingBox(bbox, matrix);
 
-   if (minX === maxX || minY === maxY) {
 
-     return [1, 0, 0, 1, rect[0], rect[1]];
 
-   }
 
-   const xRatio = (rect[2] - rect[0]) / (maxX - minX);
 
-   const yRatio = (rect[3] - rect[1]) / (maxY - minY);
 
-   return [xRatio, 0, 0, yRatio, rect[0] - minX * xRatio, rect[1] - minY * yRatio];
 
- }
 
- class Annotation {
 
-   constructor(params) {
 
-     const dict = params.dict;
 
-     this.setContents(dict.get("Contents"));
 
-     this.setModificationDate(dict.get("M"));
 
-     this.setFlags(dict.get("F"));
 
-     this.setRectangle(dict.getArray("Rect"));
 
-     this.setColor(dict.getArray("C"));
 
-     this.setBorderStyle(dict);
 
-     this.setAppearance(dict);
 
-     this.data = {
 
-       annotationFlags: this.flags,
 
-       borderStyle: this.borderStyle,
 
-       color: this.color,
 
-       contents: this.contents,
 
-       hasAppearance: !!this.appearance,
 
-       id: params.id,
 
-       modificationDate: this.modificationDate,
 
-       rect: this.rectangle,
 
-       subtype: params.subtype
 
-     };
 
-   }
 
-   _hasFlag(flags, flag) {
 
-     return !!(flags & flag);
 
-   }
 
-   _isViewable(flags) {
 
-     return !this._hasFlag(flags, _util.AnnotationFlag.INVISIBLE) && !this._hasFlag(flags, _util.AnnotationFlag.HIDDEN) && !this._hasFlag(flags, _util.AnnotationFlag.NOVIEW);
 
-   }
 
-   _isPrintable(flags) {
 
-     return this._hasFlag(flags, _util.AnnotationFlag.PRINT) && !this._hasFlag(flags, _util.AnnotationFlag.INVISIBLE) && !this._hasFlag(flags, _util.AnnotationFlag.HIDDEN);
 
-   }
 
-   get viewable() {
 
-     if (this.flags === 0) {
 
-       return true;
 
-     }
 
-     return this._isViewable(this.flags);
 
-   }
 
-   get printable() {
 
-     if (this.flags === 0) {
 
-       return false;
 
-     }
 
-     return this._isPrintable(this.flags);
 
-   }
 
-   setContents(contents) {
 
-     this.contents = (0, _util.stringToPDFString)(contents || "");
 
-   }
 
-   setModificationDate(modificationDate) {
 
-     this.modificationDate = (0, _util.isString)(modificationDate) ? modificationDate : null;
 
-   }
 
-   setFlags(flags) {
 
-     this.flags = Number.isInteger(flags) && flags > 0 ? flags : 0;
 
-   }
 
-   hasFlag(flag) {
 
-     return this._hasFlag(this.flags, flag);
 
-   }
 
-   setRectangle(rectangle) {
 
-     if (Array.isArray(rectangle) && rectangle.length === 4) {
 
-       this.rectangle = _util.Util.normalizeRect(rectangle);
 
-     } else {
 
-       this.rectangle = [0, 0, 0, 0];
 
-     }
 
-   }
 
-   setColor(color) {
 
-     const rgbColor = new Uint8ClampedArray(3);
 
-     if (!Array.isArray(color)) {
 
-       this.color = rgbColor;
 
-       return;
 
-     }
 
-     switch (color.length) {
 
-       case 0:
 
-         this.color = null;
 
-         break;
 
-       case 1:
 
-         _colorspace.ColorSpace.singletons.gray.getRgbItem(color, 0, rgbColor, 0);
 
-         this.color = rgbColor;
 
-         break;
 
-       case 3:
 
-         _colorspace.ColorSpace.singletons.rgb.getRgbItem(color, 0, rgbColor, 0);
 
-         this.color = rgbColor;
 
-         break;
 
-       case 4:
 
-         _colorspace.ColorSpace.singletons.cmyk.getRgbItem(color, 0, rgbColor, 0);
 
-         this.color = rgbColor;
 
-         break;
 
-       default:
 
-         this.color = rgbColor;
 
-         break;
 
-     }
 
-   }
 
-   setBorderStyle(borderStyle) {
 
-     this.borderStyle = new AnnotationBorderStyle();
 
-     if (!(0, _primitives.isDict)(borderStyle)) {
 
-       return;
 
-     }
 
-     if (borderStyle.has("BS")) {
 
-       const dict = borderStyle.get("BS");
 
-       const dictType = dict.get("Type");
 
-       if (!dictType || (0, _primitives.isName)(dictType, "Border")) {
 
-         this.borderStyle.setWidth(dict.get("W"), this.rectangle);
 
-         this.borderStyle.setStyle(dict.get("S"));
 
-         this.borderStyle.setDashArray(dict.getArray("D"));
 
-       }
 
-     } else if (borderStyle.has("Border")) {
 
-       const array = borderStyle.getArray("Border");
 
-       if (Array.isArray(array) && array.length >= 3) {
 
-         this.borderStyle.setHorizontalCornerRadius(array[0]);
 
-         this.borderStyle.setVerticalCornerRadius(array[1]);
 
-         this.borderStyle.setWidth(array[2], this.rectangle);
 
-         if (array.length === 4) {
 
-           this.borderStyle.setDashArray(array[3]);
 
-         }
 
-       }
 
-     } else {
 
-       this.borderStyle.setWidth(0);
 
-     }
 
-   }
 
-   setAppearance(dict) {
 
-     this.appearance = null;
 
-     const appearanceStates = dict.get("AP");
 
-     if (!(0, _primitives.isDict)(appearanceStates)) {
 
-       return;
 
-     }
 
-     const normalAppearanceState = appearanceStates.get("N");
 
-     if ((0, _primitives.isStream)(normalAppearanceState)) {
 
-       this.appearance = normalAppearanceState;
 
-       return;
 
-     }
 
-     if (!(0, _primitives.isDict)(normalAppearanceState)) {
 
-       return;
 
-     }
 
-     const as = dict.get("AS");
 
-     if (!(0, _primitives.isName)(as) || !normalAppearanceState.has(as.name)) {
 
-       return;
 
-     }
 
-     this.appearance = normalAppearanceState.get(as.name);
 
-   }
 
-   loadResources(keys) {
 
-     return this.appearance.dict.getAsync("Resources").then(resources => {
 
-       if (!resources) {
 
-         return undefined;
 
-       }
 
-       const objectLoader = new _obj.ObjectLoader(resources, keys, resources.xref);
 
-       return objectLoader.load().then(function () {
 
-         return resources;
 
-       });
 
-     });
 
-   }
 
-   getOperatorList(evaluator, task, renderForms) {
 
-     if (!this.appearance) {
 
-       return Promise.resolve(new _operator_list.OperatorList());
 
-     }
 
-     const data = this.data;
 
-     const appearanceDict = this.appearance.dict;
 
-     const resourcesPromise = this.loadResources(["ExtGState", "ColorSpace", "Pattern", "Shading", "XObject", "Font"]);
 
-     const bbox = appearanceDict.getArray("BBox") || [0, 0, 1, 1];
 
-     const matrix = appearanceDict.getArray("Matrix") || [1, 0, 0, 1, 0, 0];
 
-     const transform = getTransformMatrix(data.rect, bbox, matrix);
 
-     return resourcesPromise.then(resources => {
 
-       const opList = new _operator_list.OperatorList();
 
-       opList.addOp(_util.OPS.beginAnnotation, [data.rect, transform, matrix]);
 
-       return evaluator.getOperatorList({
 
-         stream: this.appearance,
 
-         task,
 
-         resources,
 
-         operatorList: opList
 
-       }).then(() => {
 
-         opList.addOp(_util.OPS.endAnnotation, []);
 
-         this.appearance.reset();
 
-         return opList;
 
-       });
 
-     });
 
-   }
 
- }
 
- exports.Annotation = Annotation;
 
- class AnnotationBorderStyle {
 
-   constructor() {
 
-     this.width = 1;
 
-     this.style = _util.AnnotationBorderStyleType.SOLID;
 
-     this.dashArray = [3];
 
-     this.horizontalCornerRadius = 0;
 
-     this.verticalCornerRadius = 0;
 
-   }
 
-   setWidth(width, rect = [0, 0, 0, 0]) {
 
-     if ((0, _primitives.isName)(width)) {
 
-       this.width = 0;
 
-       return;
 
-     }
 
-     if (Number.isInteger(width)) {
 
-       if (width > 0) {
 
-         const maxWidth = (rect[2] - rect[0]) / 2;
 
-         const maxHeight = (rect[3] - rect[1]) / 2;
 
-         if (maxWidth > 0 && maxHeight > 0 && (width > maxWidth || width > maxHeight)) {
 
-           (0, _util.warn)(`AnnotationBorderStyle.setWidth - ignoring width: ${width}`);
 
-           width = 1;
 
-         }
 
-       }
 
-       this.width = width;
 
-     }
 
-   }
 
-   setStyle(style) {
 
-     if (!(0, _primitives.isName)(style)) {
 
-       return;
 
-     }
 
-     switch (style.name) {
 
-       case "S":
 
-         this.style = _util.AnnotationBorderStyleType.SOLID;
 
-         break;
 
-       case "D":
 
-         this.style = _util.AnnotationBorderStyleType.DASHED;
 
-         break;
 
-       case "B":
 
-         this.style = _util.AnnotationBorderStyleType.BEVELED;
 
-         break;
 
-       case "I":
 
-         this.style = _util.AnnotationBorderStyleType.INSET;
 
-         break;
 
-       case "U":
 
-         this.style = _util.AnnotationBorderStyleType.UNDERLINE;
 
-         break;
 
-       default:
 
-         break;
 
-     }
 
-   }
 
-   setDashArray(dashArray) {
 
-     if (Array.isArray(dashArray) && dashArray.length > 0) {
 
-       let isValid = true;
 
-       let allZeros = true;
 
-       for (const element of dashArray) {
 
-         const validNumber = +element >= 0;
 
-         if (!validNumber) {
 
-           isValid = false;
 
-           break;
 
-         } else if (element > 0) {
 
-           allZeros = false;
 
-         }
 
-       }
 
-       if (isValid && !allZeros) {
 
-         this.dashArray = dashArray;
 
-       } else {
 
-         this.width = 0;
 
-       }
 
-     } else if (dashArray) {
 
-       this.width = 0;
 
-     }
 
-   }
 
-   setHorizontalCornerRadius(radius) {
 
-     if (Number.isInteger(radius)) {
 
-       this.horizontalCornerRadius = radius;
 
-     }
 
-   }
 
-   setVerticalCornerRadius(radius) {
 
-     if (Number.isInteger(radius)) {
 
-       this.verticalCornerRadius = radius;
 
-     }
 
-   }
 
- }
 
- exports.AnnotationBorderStyle = AnnotationBorderStyle;
 
- class MarkupAnnotation extends Annotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     const dict = parameters.dict;
 
-     if (dict.has("IRT")) {
 
-       const rawIRT = dict.getRaw("IRT");
 
-       this.data.inReplyTo = (0, _primitives.isRef)(rawIRT) ? rawIRT.toString() : null;
 
-       const rt = dict.get("RT");
 
-       this.data.replyType = (0, _primitives.isName)(rt) ? rt.name : _util.AnnotationReplyType.REPLY;
 
-     }
 
-     if (this.data.replyType === _util.AnnotationReplyType.GROUP) {
 
-       const parent = dict.get("IRT");
 
-       this.data.title = (0, _util.stringToPDFString)(parent.get("T") || "");
 
-       this.setContents(parent.get("Contents"));
 
-       this.data.contents = this.contents;
 
-       if (!parent.has("CreationDate")) {
 
-         this.data.creationDate = null;
 
-       } else {
 
-         this.setCreationDate(parent.get("CreationDate"));
 
-         this.data.creationDate = this.creationDate;
 
-       }
 
-       if (!parent.has("M")) {
 
-         this.data.modificationDate = null;
 
-       } else {
 
-         this.setModificationDate(parent.get("M"));
 
-         this.data.modificationDate = this.modificationDate;
 
-       }
 
-       this.data.hasPopup = parent.has("Popup");
 
-       if (!parent.has("C")) {
 
-         this.data.color = null;
 
-       } else {
 
-         this.setColor(parent.getArray("C"));
 
-         this.data.color = this.color;
 
-       }
 
-     } else {
 
-       this.data.title = (0, _util.stringToPDFString)(dict.get("T") || "");
 
-       this.setCreationDate(dict.get("CreationDate"));
 
-       this.data.creationDate = this.creationDate;
 
-       this.data.hasPopup = dict.has("Popup");
 
-       if (!dict.has("C")) {
 
-         this.data.color = null;
 
-       }
 
-     }
 
-   }
 
-   setCreationDate(creationDate) {
 
-     this.creationDate = (0, _util.isString)(creationDate) ? creationDate : null;
 
-   }
 
- }
 
- exports.MarkupAnnotation = MarkupAnnotation;
 
- class WidgetAnnotation extends Annotation {
 
-   constructor(params) {
 
-     super(params);
 
-     const dict = params.dict;
 
-     const data = this.data;
 
-     data.annotationType = _util.AnnotationType.WIDGET;
 
-     data.fieldName = this._constructFieldName(dict);
 
-     data.fieldValue = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "V",
 
-       getArray: true
 
-     });
 
-     data.alternativeText = (0, _util.stringToPDFString)(dict.get("TU") || "");
 
-     data.defaultAppearance = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "DA"
 
-     }) || "";
 
-     const fieldType = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "FT"
 
-     });
 
-     data.fieldType = (0, _primitives.isName)(fieldType) ? fieldType.name : null;
 
-     this.fieldResources = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "DR"
 
-     }) || _primitives.Dict.empty;
 
-     data.fieldFlags = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "Ff"
 
-     });
 
-     if (!Number.isInteger(data.fieldFlags) || data.fieldFlags < 0) {
 
-       data.fieldFlags = 0;
 
-     }
 
-     data.readOnly = this.hasFieldFlag(_util.AnnotationFieldFlag.READONLY);
 
-     if (data.fieldType === "Sig") {
 
-       data.fieldValue = null;
 
-       this.setFlags(_util.AnnotationFlag.HIDDEN);
 
-     }
 
-   }
 
-   _constructFieldName(dict) {
 
-     if (!dict.has("T") && !dict.has("Parent")) {
 
-       (0, _util.warn)("Unknown field name, falling back to empty field name.");
 
-       return "";
 
-     }
 
-     if (!dict.has("Parent")) {
 
-       return (0, _util.stringToPDFString)(dict.get("T"));
 
-     }
 
-     const fieldName = [];
 
-     if (dict.has("T")) {
 
-       fieldName.unshift((0, _util.stringToPDFString)(dict.get("T")));
 
-     }
 
-     let loopDict = dict;
 
-     while (loopDict.has("Parent")) {
 
-       loopDict = loopDict.get("Parent");
 
-       if (!(0, _primitives.isDict)(loopDict)) {
 
-         break;
 
-       }
 
-       if (loopDict.has("T")) {
 
-         fieldName.unshift((0, _util.stringToPDFString)(loopDict.get("T")));
 
-       }
 
-     }
 
-     return fieldName.join(".");
 
-   }
 
-   hasFieldFlag(flag) {
 
-     return !!(this.data.fieldFlags & flag);
 
-   }
 
-   getOperatorList(evaluator, task, renderForms) {
 
-     if (renderForms) {
 
-       return Promise.resolve(new _operator_list.OperatorList());
 
-     }
 
-     return super.getOperatorList(evaluator, task, renderForms);
 
-   }
 
- }
 
- class TextWidgetAnnotation extends WidgetAnnotation {
 
-   constructor(params) {
 
-     super(params);
 
-     const dict = params.dict;
 
-     this.data.fieldValue = (0, _util.stringToPDFString)(this.data.fieldValue || "");
 
-     let alignment = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "Q"
 
-     });
 
-     if (!Number.isInteger(alignment) || alignment < 0 || alignment > 2) {
 
-       alignment = null;
 
-     }
 
-     this.data.textAlignment = alignment;
 
-     let maximumLength = (0, _core_utils.getInheritableProperty)({
 
-       dict,
 
-       key: "MaxLen"
 
-     });
 
-     if (!Number.isInteger(maximumLength) || maximumLength < 0) {
 
-       maximumLength = null;
 
-     }
 
-     this.data.maxLen = maximumLength;
 
-     this.data.multiLine = this.hasFieldFlag(_util.AnnotationFieldFlag.MULTILINE);
 
-     this.data.comb = this.hasFieldFlag(_util.AnnotationFieldFlag.COMB) && !this.hasFieldFlag(_util.AnnotationFieldFlag.MULTILINE) && !this.hasFieldFlag(_util.AnnotationFieldFlag.PASSWORD) && !this.hasFieldFlag(_util.AnnotationFieldFlag.FILESELECT) && this.data.maxLen !== null;
 
-   }
 
-   getOperatorList(evaluator, task, renderForms) {
 
-     if (renderForms || this.appearance) {
 
-       return super.getOperatorList(evaluator, task, renderForms);
 
-     }
 
-     const operatorList = new _operator_list.OperatorList();
 
-     if (!this.data.defaultAppearance) {
 
-       return Promise.resolve(operatorList);
 
-     }
 
-     const stream = new _stream.Stream((0, _util.stringToBytes)(this.data.defaultAppearance));
 
-     return evaluator.getOperatorList({
 
-       stream,
 
-       task,
 
-       resources: this.fieldResources,
 
-       operatorList
 
-     }).then(function () {
 
-       return operatorList;
 
-     });
 
-   }
 
- }
 
- class ButtonWidgetAnnotation extends WidgetAnnotation {
 
-   constructor(params) {
 
-     super(params);
 
-     this.data.checkBox = !this.hasFieldFlag(_util.AnnotationFieldFlag.RADIO) && !this.hasFieldFlag(_util.AnnotationFieldFlag.PUSHBUTTON);
 
-     this.data.radioButton = this.hasFieldFlag(_util.AnnotationFieldFlag.RADIO) && !this.hasFieldFlag(_util.AnnotationFieldFlag.PUSHBUTTON);
 
-     this.data.pushButton = this.hasFieldFlag(_util.AnnotationFieldFlag.PUSHBUTTON);
 
-     if (this.data.checkBox) {
 
-       this._processCheckBox(params);
 
-     } else if (this.data.radioButton) {
 
-       this._processRadioButton(params);
 
-     } else if (this.data.pushButton) {
 
-       this._processPushButton(params);
 
-     } else {
 
-       (0, _util.warn)("Invalid field flags for button widget annotation");
 
-     }
 
-   }
 
-   _processCheckBox(params) {
 
-     if ((0, _primitives.isName)(this.data.fieldValue)) {
 
-       this.data.fieldValue = this.data.fieldValue.name;
 
-     }
 
-     const customAppearance = params.dict.get("AP");
 
-     if (!(0, _primitives.isDict)(customAppearance)) {
 
-       return;
 
-     }
 
-     const exportValueOptionsDict = customAppearance.get("D");
 
-     if (!(0, _primitives.isDict)(exportValueOptionsDict)) {
 
-       return;
 
-     }
 
-     const exportValues = exportValueOptionsDict.getKeys();
 
-     const hasCorrectOptionCount = exportValues.length === 2;
 
-     if (!hasCorrectOptionCount) {
 
-       return;
 
-     }
 
-     this.data.exportValue = exportValues[0] === "Off" ? exportValues[1] : exportValues[0];
 
-   }
 
-   _processRadioButton(params) {
 
-     this.data.fieldValue = this.data.buttonValue = null;
 
-     const fieldParent = params.dict.get("Parent");
 
-     if ((0, _primitives.isDict)(fieldParent) && fieldParent.has("V")) {
 
-       const fieldParentValue = fieldParent.get("V");
 
-       if ((0, _primitives.isName)(fieldParentValue)) {
 
-         this.data.fieldValue = fieldParentValue.name;
 
-       }
 
-     }
 
-     const appearanceStates = params.dict.get("AP");
 
-     if (!(0, _primitives.isDict)(appearanceStates)) {
 
-       return;
 
-     }
 
-     const normalAppearanceState = appearanceStates.get("N");
 
-     if (!(0, _primitives.isDict)(normalAppearanceState)) {
 
-       return;
 
-     }
 
-     for (const key of normalAppearanceState.getKeys()) {
 
-       if (key !== "Off") {
 
-         this.data.buttonValue = key;
 
-         break;
 
-       }
 
-     }
 
-   }
 
-   _processPushButton(params) {
 
-     if (!params.dict.has("A")) {
 
-       (0, _util.warn)("Push buttons without action dictionaries are not supported");
 
-       return;
 
-     }
 
-     _obj.Catalog.parseDestDictionary({
 
-       destDict: params.dict,
 
-       resultObj: this.data,
 
-       docBaseUrl: params.pdfManager.docBaseUrl
 
-     });
 
-   }
 
- }
 
- class ChoiceWidgetAnnotation extends WidgetAnnotation {
 
-   constructor(params) {
 
-     super(params);
 
-     this.data.options = [];
 
-     const options = (0, _core_utils.getInheritableProperty)({
 
-       dict: params.dict,
 
-       key: "Opt"
 
-     });
 
-     if (Array.isArray(options)) {
 
-       const xref = params.xref;
 
-       for (let i = 0, ii = options.length; i < ii; i++) {
 
-         const option = xref.fetchIfRef(options[i]);
 
-         const isOptionArray = Array.isArray(option);
 
-         this.data.options[i] = {
 
-           exportValue: isOptionArray ? xref.fetchIfRef(option[0]) : option,
 
-           displayValue: (0, _util.stringToPDFString)(isOptionArray ? xref.fetchIfRef(option[1]) : option)
 
-         };
 
-       }
 
-     }
 
-     if (!Array.isArray(this.data.fieldValue)) {
 
-       this.data.fieldValue = [this.data.fieldValue];
 
-     }
 
-     this.data.combo = this.hasFieldFlag(_util.AnnotationFieldFlag.COMBO);
 
-     this.data.multiSelect = this.hasFieldFlag(_util.AnnotationFieldFlag.MULTISELECT);
 
-   }
 
- }
 
- class TextAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     const DEFAULT_ICON_SIZE = 22;
 
-     super(parameters);
 
-     const dict = parameters.dict;
 
-     this.data.annotationType = _util.AnnotationType.TEXT;
 
-     if (this.data.hasAppearance) {
 
-       this.data.name = "NoIcon";
 
-     } else {
 
-       this.data.rect[1] = this.data.rect[3] - DEFAULT_ICON_SIZE;
 
-       this.data.rect[2] = this.data.rect[0] + DEFAULT_ICON_SIZE;
 
-       this.data.name = dict.has("Name") ? dict.get("Name").name : "Note";
 
-     }
 
-     if (dict.has("State")) {
 
-       this.data.state = dict.get("State") || null;
 
-       this.data.stateModel = dict.get("StateModel") || null;
 
-     } else {
 
-       this.data.state = null;
 
-       this.data.stateModel = null;
 
-     }
 
-   }
 
- }
 
- class LinkAnnotation extends Annotation {
 
-   constructor(params) {
 
-     super(params);
 
-     this.data.annotationType = _util.AnnotationType.LINK;
 
-     const quadPoints = getQuadPoints(params.dict, this.rectangle);
 
-     if (quadPoints) {
 
-       this.data.quadPoints = quadPoints;
 
-     }
 
-     _obj.Catalog.parseDestDictionary({
 
-       destDict: params.dict,
 
-       resultObj: this.data,
 
-       docBaseUrl: params.pdfManager.docBaseUrl
 
-     });
 
-   }
 
- }
 
- class PopupAnnotation extends Annotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.POPUP;
 
-     let parentItem = parameters.dict.get("Parent");
 
-     if (!parentItem) {
 
-       (0, _util.warn)("Popup annotation has a missing or invalid parent annotation.");
 
-       return;
 
-     }
 
-     const parentSubtype = parentItem.get("Subtype");
 
-     this.data.parentType = (0, _primitives.isName)(parentSubtype) ? parentSubtype.name : null;
 
-     const rawParent = parameters.dict.getRaw("Parent");
 
-     this.data.parentId = (0, _primitives.isRef)(rawParent) ? rawParent.toString() : null;
 
-     const rt = parentItem.get("RT");
 
-     if ((0, _primitives.isName)(rt, _util.AnnotationReplyType.GROUP)) {
 
-       parentItem = parentItem.get("IRT");
 
-     }
 
-     if (!parentItem.has("M")) {
 
-       this.data.modificationDate = null;
 
-     } else {
 
-       this.setModificationDate(parentItem.get("M"));
 
-       this.data.modificationDate = this.modificationDate;
 
-     }
 
-     if (!parentItem.has("C")) {
 
-       this.data.color = null;
 
-     } else {
 
-       this.setColor(parentItem.getArray("C"));
 
-       this.data.color = this.color;
 
-     }
 
-     if (!this.viewable) {
 
-       const parentFlags = parentItem.get("F");
 
-       if (this._isViewable(parentFlags)) {
 
-         this.setFlags(parentFlags);
 
-       }
 
-     }
 
-     this.data.title = (0, _util.stringToPDFString)(parentItem.get("T") || "");
 
-     this.data.contents = (0, _util.stringToPDFString)(parentItem.get("Contents") || "");
 
-   }
 
- }
 
- class FreeTextAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.FREETEXT;
 
-   }
 
- }
 
- class LineAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.LINE;
 
-     this.data.lineCoordinates = _util.Util.normalizeRect(parameters.dict.getArray("L"));
 
-   }
 
- }
 
- class SquareAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.SQUARE;
 
-   }
 
- }
 
- class CircleAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.CIRCLE;
 
-   }
 
- }
 
- class PolylineAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.POLYLINE;
 
-     const rawVertices = parameters.dict.getArray("Vertices");
 
-     this.data.vertices = [];
 
-     for (let i = 0, ii = rawVertices.length; i < ii; i += 2) {
 
-       this.data.vertices.push({
 
-         x: rawVertices[i],
 
-         y: rawVertices[i + 1]
 
-       });
 
-     }
 
-   }
 
- }
 
- class PolygonAnnotation extends PolylineAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.POLYGON;
 
-   }
 
- }
 
- class CaretAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.CARET;
 
-   }
 
- }
 
- class InkAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.INK;
 
-     const xref = parameters.xref;
 
-     const originalInkLists = parameters.dict.getArray("InkList");
 
-     this.data.inkLists = [];
 
-     for (let i = 0, ii = originalInkLists.length; i < ii; ++i) {
 
-       this.data.inkLists.push([]);
 
-       for (let j = 0, jj = originalInkLists[i].length; j < jj; j += 2) {
 
-         this.data.inkLists[i].push({
 
-           x: xref.fetchIfRef(originalInkLists[i][j]),
 
-           y: xref.fetchIfRef(originalInkLists[i][j + 1])
 
-         });
 
-       }
 
-     }
 
-   }
 
- }
 
- class HighlightAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.HIGHLIGHT;
 
-     const quadPoints = getQuadPoints(parameters.dict, this.rectangle);
 
-     if (quadPoints) {
 
-       this.data.quadPoints = quadPoints;
 
-     }
 
-   }
 
- }
 
- class UnderlineAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.UNDERLINE;
 
-     const quadPoints = getQuadPoints(parameters.dict, this.rectangle);
 
-     if (quadPoints) {
 
-       this.data.quadPoints = quadPoints;
 
-     }
 
-   }
 
- }
 
- class SquigglyAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.SQUIGGLY;
 
-     const quadPoints = getQuadPoints(parameters.dict, this.rectangle);
 
-     if (quadPoints) {
 
-       this.data.quadPoints = quadPoints;
 
-     }
 
-   }
 
- }
 
- class StrikeOutAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.STRIKEOUT;
 
-     const quadPoints = getQuadPoints(parameters.dict, this.rectangle);
 
-     if (quadPoints) {
 
-       this.data.quadPoints = quadPoints;
 
-     }
 
-   }
 
- }
 
- class StampAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     this.data.annotationType = _util.AnnotationType.STAMP;
 
-   }
 
- }
 
- class FileAttachmentAnnotation extends MarkupAnnotation {
 
-   constructor(parameters) {
 
-     super(parameters);
 
-     const file = new _obj.FileSpec(parameters.dict.get("FS"), parameters.xref);
 
-     this.data.annotationType = _util.AnnotationType.FILEATTACHMENT;
 
-     this.data.file = file.serializable;
 
-   }
 
- }
 
- /***/ }),
 
- /* 24 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.OperatorList = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var QueueOptimizer = function QueueOptimizerClosure() {
 
-   function addState(parentState, pattern, checkFn, iterateFn, processFn) {
 
-     var state = parentState;
 
-     for (var i = 0, ii = pattern.length - 1; i < ii; i++) {
 
-       var item = pattern[i];
 
-       state = state[item] || (state[item] = []);
 
-     }
 
-     state[pattern[pattern.length - 1]] = {
 
-       checkFn,
 
-       iterateFn,
 
-       processFn
 
-     };
 
-   }
 
-   function handlePaintSolidColorImageMask(iFirstSave, count, fnArray, argsArray) {
 
-     var iFirstPIMXO = iFirstSave + 2;
 
-     for (var i = 0; i < count; i++) {
 
-       var arg = argsArray[iFirstPIMXO + 4 * i];
 
-       var imageMask = arg.length === 1 && arg[0];
 
-       if (imageMask && imageMask.width === 1 && imageMask.height === 1 && (!imageMask.data.length || imageMask.data.length === 1 && imageMask.data[0] === 0)) {
 
-         fnArray[iFirstPIMXO + 4 * i] = _util.OPS.paintSolidColorImageMask;
 
-         continue;
 
-       }
 
-       break;
 
-     }
 
-     return count - i;
 
-   }
 
-   var InitialState = [];
 
-   addState(InitialState, [_util.OPS.save, _util.OPS.transform, _util.OPS.paintInlineImageXObject, _util.OPS.restore], null, function iterateInlineImageGroup(context, i) {
 
-     var fnArray = context.fnArray;
 
-     var iFirstSave = context.iCurr - 3;
 
-     var pos = (i - iFirstSave) % 4;
 
-     switch (pos) {
 
-       case 0:
 
-         return fnArray[i] === _util.OPS.save;
 
-       case 1:
 
-         return fnArray[i] === _util.OPS.transform;
 
-       case 2:
 
-         return fnArray[i] === _util.OPS.paintInlineImageXObject;
 
-       case 3:
 
-         return fnArray[i] === _util.OPS.restore;
 
-     }
 
-     throw new Error(`iterateInlineImageGroup - invalid pos: ${pos}`);
 
-   }, function foundInlineImageGroup(context, i) {
 
-     var MIN_IMAGES_IN_INLINE_IMAGES_BLOCK = 10;
 
-     var MAX_IMAGES_IN_INLINE_IMAGES_BLOCK = 200;
 
-     var MAX_WIDTH = 1000;
 
-     var IMAGE_PADDING = 1;
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var curr = context.iCurr;
 
-     var iFirstSave = curr - 3;
 
-     var iFirstTransform = curr - 2;
 
-     var iFirstPIIXO = curr - 1;
 
-     var count = Math.min(Math.floor((i - iFirstSave) / 4), MAX_IMAGES_IN_INLINE_IMAGES_BLOCK);
 
-     if (count < MIN_IMAGES_IN_INLINE_IMAGES_BLOCK) {
 
-       return i - (i - iFirstSave) % 4;
 
-     }
 
-     var maxX = 0;
 
-     var map = [],
 
-         maxLineHeight = 0;
 
-     var currentX = IMAGE_PADDING,
 
-         currentY = IMAGE_PADDING;
 
-     var q;
 
-     for (q = 0; q < count; q++) {
 
-       var transform = argsArray[iFirstTransform + (q << 2)];
 
-       var img = argsArray[iFirstPIIXO + (q << 2)][0];
 
-       if (currentX + img.width > MAX_WIDTH) {
 
-         maxX = Math.max(maxX, currentX);
 
-         currentY += maxLineHeight + 2 * IMAGE_PADDING;
 
-         currentX = 0;
 
-         maxLineHeight = 0;
 
-       }
 
-       map.push({
 
-         transform,
 
-         x: currentX,
 
-         y: currentY,
 
-         w: img.width,
 
-         h: img.height
 
-       });
 
-       currentX += img.width + 2 * IMAGE_PADDING;
 
-       maxLineHeight = Math.max(maxLineHeight, img.height);
 
-     }
 
-     var imgWidth = Math.max(maxX, currentX) + IMAGE_PADDING;
 
-     var imgHeight = currentY + maxLineHeight + IMAGE_PADDING;
 
-     var imgData = new Uint8ClampedArray(imgWidth * imgHeight * 4);
 
-     var imgRowSize = imgWidth << 2;
 
-     for (q = 0; q < count; q++) {
 
-       var data = argsArray[iFirstPIIXO + (q << 2)][0].data;
 
-       var rowSize = map[q].w << 2;
 
-       var dataOffset = 0;
 
-       var offset = map[q].x + map[q].y * imgWidth << 2;
 
-       imgData.set(data.subarray(0, rowSize), offset - imgRowSize);
 
-       for (var k = 0, kk = map[q].h; k < kk; k++) {
 
-         imgData.set(data.subarray(dataOffset, dataOffset + rowSize), offset);
 
-         dataOffset += rowSize;
 
-         offset += imgRowSize;
 
-       }
 
-       imgData.set(data.subarray(dataOffset - rowSize, dataOffset), offset);
 
-       while (offset >= 0) {
 
-         data[offset - 4] = data[offset];
 
-         data[offset - 3] = data[offset + 1];
 
-         data[offset - 2] = data[offset + 2];
 
-         data[offset - 1] = data[offset + 3];
 
-         data[offset + rowSize] = data[offset + rowSize - 4];
 
-         data[offset + rowSize + 1] = data[offset + rowSize - 3];
 
-         data[offset + rowSize + 2] = data[offset + rowSize - 2];
 
-         data[offset + rowSize + 3] = data[offset + rowSize - 1];
 
-         offset -= imgRowSize;
 
-       }
 
-     }
 
-     fnArray.splice(iFirstSave, count * 4, _util.OPS.paintInlineImageXObjectGroup);
 
-     argsArray.splice(iFirstSave, count * 4, [{
 
-       width: imgWidth,
 
-       height: imgHeight,
 
-       kind: _util.ImageKind.RGBA_32BPP,
 
-       data: imgData
 
-     }, map]);
 
-     return iFirstSave + 1;
 
-   });
 
-   addState(InitialState, [_util.OPS.save, _util.OPS.transform, _util.OPS.paintImageMaskXObject, _util.OPS.restore], null, function iterateImageMaskGroup(context, i) {
 
-     var fnArray = context.fnArray;
 
-     var iFirstSave = context.iCurr - 3;
 
-     var pos = (i - iFirstSave) % 4;
 
-     switch (pos) {
 
-       case 0:
 
-         return fnArray[i] === _util.OPS.save;
 
-       case 1:
 
-         return fnArray[i] === _util.OPS.transform;
 
-       case 2:
 
-         return fnArray[i] === _util.OPS.paintImageMaskXObject;
 
-       case 3:
 
-         return fnArray[i] === _util.OPS.restore;
 
-     }
 
-     throw new Error(`iterateImageMaskGroup - invalid pos: ${pos}`);
 
-   }, function foundImageMaskGroup(context, i) {
 
-     var MIN_IMAGES_IN_MASKS_BLOCK = 10;
 
-     var MAX_IMAGES_IN_MASKS_BLOCK = 100;
 
-     var MAX_SAME_IMAGES_IN_MASKS_BLOCK = 1000;
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var curr = context.iCurr;
 
-     var iFirstSave = curr - 3;
 
-     var iFirstTransform = curr - 2;
 
-     var iFirstPIMXO = curr - 1;
 
-     var count = Math.floor((i - iFirstSave) / 4);
 
-     count = handlePaintSolidColorImageMask(iFirstSave, count, fnArray, argsArray);
 
-     if (count < MIN_IMAGES_IN_MASKS_BLOCK) {
 
-       return i - (i - iFirstSave) % 4;
 
-     }
 
-     var q;
 
-     var isSameImage = false;
 
-     var iTransform, transformArgs;
 
-     var firstPIMXOArg0 = argsArray[iFirstPIMXO][0];
 
-     if (argsArray[iFirstTransform][1] === 0 && argsArray[iFirstTransform][2] === 0) {
 
-       isSameImage = true;
 
-       var firstTransformArg0 = argsArray[iFirstTransform][0];
 
-       var firstTransformArg3 = argsArray[iFirstTransform][3];
 
-       iTransform = iFirstTransform + 4;
 
-       var iPIMXO = iFirstPIMXO + 4;
 
-       for (q = 1; q < count; q++, iTransform += 4, iPIMXO += 4) {
 
-         transformArgs = argsArray[iTransform];
 
-         if (argsArray[iPIMXO][0] !== firstPIMXOArg0 || transformArgs[0] !== firstTransformArg0 || transformArgs[1] !== 0 || transformArgs[2] !== 0 || transformArgs[3] !== firstTransformArg3) {
 
-           if (q < MIN_IMAGES_IN_MASKS_BLOCK) {
 
-             isSameImage = false;
 
-           } else {
 
-             count = q;
 
-           }
 
-           break;
 
-         }
 
-       }
 
-     }
 
-     if (isSameImage) {
 
-       count = Math.min(count, MAX_SAME_IMAGES_IN_MASKS_BLOCK);
 
-       var positions = new Float32Array(count * 2);
 
-       iTransform = iFirstTransform;
 
-       for (q = 0; q < count; q++, iTransform += 4) {
 
-         transformArgs = argsArray[iTransform];
 
-         positions[q << 1] = transformArgs[4];
 
-         positions[(q << 1) + 1] = transformArgs[5];
 
-       }
 
-       fnArray.splice(iFirstSave, count * 4, _util.OPS.paintImageMaskXObjectRepeat);
 
-       argsArray.splice(iFirstSave, count * 4, [firstPIMXOArg0, firstTransformArg0, firstTransformArg3, positions]);
 
-     } else {
 
-       count = Math.min(count, MAX_IMAGES_IN_MASKS_BLOCK);
 
-       var images = [];
 
-       for (q = 0; q < count; q++) {
 
-         transformArgs = argsArray[iFirstTransform + (q << 2)];
 
-         var maskParams = argsArray[iFirstPIMXO + (q << 2)][0];
 
-         images.push({
 
-           data: maskParams.data,
 
-           width: maskParams.width,
 
-           height: maskParams.height,
 
-           transform: transformArgs
 
-         });
 
-       }
 
-       fnArray.splice(iFirstSave, count * 4, _util.OPS.paintImageMaskXObjectGroup);
 
-       argsArray.splice(iFirstSave, count * 4, [images]);
 
-     }
 
-     return iFirstSave + 1;
 
-   });
 
-   addState(InitialState, [_util.OPS.save, _util.OPS.transform, _util.OPS.paintImageXObject, _util.OPS.restore], function (context) {
 
-     var argsArray = context.argsArray;
 
-     var iFirstTransform = context.iCurr - 2;
 
-     return argsArray[iFirstTransform][1] === 0 && argsArray[iFirstTransform][2] === 0;
 
-   }, function iterateImageGroup(context, i) {
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var iFirstSave = context.iCurr - 3;
 
-     var pos = (i - iFirstSave) % 4;
 
-     switch (pos) {
 
-       case 0:
 
-         return fnArray[i] === _util.OPS.save;
 
-       case 1:
 
-         if (fnArray[i] !== _util.OPS.transform) {
 
-           return false;
 
-         }
 
-         var iFirstTransform = context.iCurr - 2;
 
-         var firstTransformArg0 = argsArray[iFirstTransform][0];
 
-         var firstTransformArg3 = argsArray[iFirstTransform][3];
 
-         if (argsArray[i][0] !== firstTransformArg0 || argsArray[i][1] !== 0 || argsArray[i][2] !== 0 || argsArray[i][3] !== firstTransformArg3) {
 
-           return false;
 
-         }
 
-         return true;
 
-       case 2:
 
-         if (fnArray[i] !== _util.OPS.paintImageXObject) {
 
-           return false;
 
-         }
 
-         var iFirstPIXO = context.iCurr - 1;
 
-         var firstPIXOArg0 = argsArray[iFirstPIXO][0];
 
-         if (argsArray[i][0] !== firstPIXOArg0) {
 
-           return false;
 
-         }
 
-         return true;
 
-       case 3:
 
-         return fnArray[i] === _util.OPS.restore;
 
-     }
 
-     throw new Error(`iterateImageGroup - invalid pos: ${pos}`);
 
-   }, function (context, i) {
 
-     var MIN_IMAGES_IN_BLOCK = 3;
 
-     var MAX_IMAGES_IN_BLOCK = 1000;
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var curr = context.iCurr;
 
-     var iFirstSave = curr - 3;
 
-     var iFirstTransform = curr - 2;
 
-     var iFirstPIXO = curr - 1;
 
-     var firstPIXOArg0 = argsArray[iFirstPIXO][0];
 
-     var firstTransformArg0 = argsArray[iFirstTransform][0];
 
-     var firstTransformArg3 = argsArray[iFirstTransform][3];
 
-     var count = Math.min(Math.floor((i - iFirstSave) / 4), MAX_IMAGES_IN_BLOCK);
 
-     if (count < MIN_IMAGES_IN_BLOCK) {
 
-       return i - (i - iFirstSave) % 4;
 
-     }
 
-     var positions = new Float32Array(count * 2);
 
-     var iTransform = iFirstTransform;
 
-     for (var q = 0; q < count; q++, iTransform += 4) {
 
-       var transformArgs = argsArray[iTransform];
 
-       positions[q << 1] = transformArgs[4];
 
-       positions[(q << 1) + 1] = transformArgs[5];
 
-     }
 
-     var args = [firstPIXOArg0, firstTransformArg0, firstTransformArg3, positions];
 
-     fnArray.splice(iFirstSave, count * 4, _util.OPS.paintImageXObjectRepeat);
 
-     argsArray.splice(iFirstSave, count * 4, args);
 
-     return iFirstSave + 1;
 
-   });
 
-   addState(InitialState, [_util.OPS.beginText, _util.OPS.setFont, _util.OPS.setTextMatrix, _util.OPS.showText, _util.OPS.endText], null, function iterateShowTextGroup(context, i) {
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var iFirstSave = context.iCurr - 4;
 
-     var pos = (i - iFirstSave) % 5;
 
-     switch (pos) {
 
-       case 0:
 
-         return fnArray[i] === _util.OPS.beginText;
 
-       case 1:
 
-         return fnArray[i] === _util.OPS.setFont;
 
-       case 2:
 
-         return fnArray[i] === _util.OPS.setTextMatrix;
 
-       case 3:
 
-         if (fnArray[i] !== _util.OPS.showText) {
 
-           return false;
 
-         }
 
-         var iFirstSetFont = context.iCurr - 3;
 
-         var firstSetFontArg0 = argsArray[iFirstSetFont][0];
 
-         var firstSetFontArg1 = argsArray[iFirstSetFont][1];
 
-         if (argsArray[i][0] !== firstSetFontArg0 || argsArray[i][1] !== firstSetFontArg1) {
 
-           return false;
 
-         }
 
-         return true;
 
-       case 4:
 
-         return fnArray[i] === _util.OPS.endText;
 
-     }
 
-     throw new Error(`iterateShowTextGroup - invalid pos: ${pos}`);
 
-   }, function (context, i) {
 
-     var MIN_CHARS_IN_BLOCK = 3;
 
-     var MAX_CHARS_IN_BLOCK = 1000;
 
-     var fnArray = context.fnArray,
 
-         argsArray = context.argsArray;
 
-     var curr = context.iCurr;
 
-     var iFirstBeginText = curr - 4;
 
-     var iFirstSetFont = curr - 3;
 
-     var iFirstSetTextMatrix = curr - 2;
 
-     var iFirstShowText = curr - 1;
 
-     var iFirstEndText = curr;
 
-     var firstSetFontArg0 = argsArray[iFirstSetFont][0];
 
-     var firstSetFontArg1 = argsArray[iFirstSetFont][1];
 
-     var count = Math.min(Math.floor((i - iFirstBeginText) / 5), MAX_CHARS_IN_BLOCK);
 
-     if (count < MIN_CHARS_IN_BLOCK) {
 
-       return i - (i - iFirstBeginText) % 5;
 
-     }
 
-     var iFirst = iFirstBeginText;
 
-     if (iFirstBeginText >= 4 && fnArray[iFirstBeginText - 4] === fnArray[iFirstSetFont] && fnArray[iFirstBeginText - 3] === fnArray[iFirstSetTextMatrix] && fnArray[iFirstBeginText - 2] === fnArray[iFirstShowText] && fnArray[iFirstBeginText - 1] === fnArray[iFirstEndText] && argsArray[iFirstBeginText - 4][0] === firstSetFontArg0 && argsArray[iFirstBeginText - 4][1] === firstSetFontArg1) {
 
-       count++;
 
-       iFirst -= 5;
 
-     }
 
-     var iEndText = iFirst + 4;
 
-     for (var q = 1; q < count; q++) {
 
-       fnArray.splice(iEndText, 3);
 
-       argsArray.splice(iEndText, 3);
 
-       iEndText += 2;
 
-     }
 
-     return iEndText + 1;
 
-   });
 
-   function QueueOptimizer(queue) {
 
-     this.queue = queue;
 
-     this.state = null;
 
-     this.context = {
 
-       iCurr: 0,
 
-       fnArray: queue.fnArray,
 
-       argsArray: queue.argsArray
 
-     };
 
-     this.match = null;
 
-     this.lastProcessed = 0;
 
-   }
 
-   QueueOptimizer.prototype = {
 
-     _optimize() {
 
-       const fnArray = this.queue.fnArray;
 
-       let i = this.lastProcessed,
 
-           ii = fnArray.length;
 
-       let state = this.state;
 
-       let match = this.match;
 
-       if (!state && !match && i + 1 === ii && !InitialState[fnArray[i]]) {
 
-         this.lastProcessed = ii;
 
-         return;
 
-       }
 
-       const context = this.context;
 
-       while (i < ii) {
 
-         if (match) {
 
-           const iterate = (0, match.iterateFn)(context, i);
 
-           if (iterate) {
 
-             i++;
 
-             continue;
 
-           }
 
-           i = (0, match.processFn)(context, i + 1);
 
-           ii = fnArray.length;
 
-           match = null;
 
-           state = null;
 
-           if (i >= ii) {
 
-             break;
 
-           }
 
-         }
 
-         state = (state || InitialState)[fnArray[i]];
 
-         if (!state || Array.isArray(state)) {
 
-           i++;
 
-           continue;
 
-         }
 
-         context.iCurr = i;
 
-         i++;
 
-         if (state.checkFn && !(0, state.checkFn)(context)) {
 
-           state = null;
 
-           continue;
 
-         }
 
-         match = state;
 
-         state = null;
 
-       }
 
-       this.state = state;
 
-       this.match = match;
 
-       this.lastProcessed = i;
 
-     },
 
-     push(fn, args) {
 
-       this.queue.fnArray.push(fn);
 
-       this.queue.argsArray.push(args);
 
-       this._optimize();
 
-     },
 
-     flush() {
 
-       while (this.match) {
 
-         const length = this.queue.fnArray.length;
 
-         this.lastProcessed = (0, this.match.processFn)(this.context, length);
 
-         this.match = null;
 
-         this.state = null;
 
-         this._optimize();
 
-       }
 
-     },
 
-     reset() {
 
-       this.state = null;
 
-       this.match = null;
 
-       this.lastProcessed = 0;
 
-     }
 
-   };
 
-   return QueueOptimizer;
 
- }();
 
- var NullOptimizer = function NullOptimizerClosure() {
 
-   function NullOptimizer(queue) {
 
-     this.queue = queue;
 
-   }
 
-   NullOptimizer.prototype = {
 
-     push(fn, args) {
 
-       this.queue.fnArray.push(fn);
 
-       this.queue.argsArray.push(args);
 
-     },
 
-     flush() {},
 
-     reset() {}
 
-   };
 
-   return NullOptimizer;
 
- }();
 
- var OperatorList = function OperatorListClosure() {
 
-   var CHUNK_SIZE = 1000;
 
-   var CHUNK_SIZE_ABOUT = CHUNK_SIZE - 5;
 
-   function OperatorList(intent, streamSink, pageIndex) {
 
-     this._streamSink = streamSink;
 
-     this.fnArray = [];
 
-     this.argsArray = [];
 
-     if (streamSink && intent !== "oplist") {
 
-       this.optimizer = new QueueOptimizer(this);
 
-     } else {
 
-       this.optimizer = new NullOptimizer(this);
 
-     }
 
-     this.dependencies = Object.create(null);
 
-     this._totalLength = 0;
 
-     this.pageIndex = pageIndex;
 
-     this.intent = intent;
 
-     this.weight = 0;
 
-     this._resolved = streamSink ? null : Promise.resolve();
 
-   }
 
-   OperatorList.prototype = {
 
-     get length() {
 
-       return this.argsArray.length;
 
-     },
 
-     get ready() {
 
-       return this._resolved || this._streamSink.ready;
 
-     },
 
-     get totalLength() {
 
-       return this._totalLength + this.length;
 
-     },
 
-     addOp(fn, args) {
 
-       this.optimizer.push(fn, args);
 
-       this.weight++;
 
-       if (this._streamSink) {
 
-         if (this.weight >= CHUNK_SIZE) {
 
-           this.flush();
 
-         } else if (this.weight >= CHUNK_SIZE_ABOUT && (fn === _util.OPS.restore || fn === _util.OPS.endText)) {
 
-           this.flush();
 
-         }
 
-       }
 
-     },
 
-     addDependency(dependency) {
 
-       if (dependency in this.dependencies) {
 
-         return;
 
-       }
 
-       this.dependencies[dependency] = true;
 
-       this.addOp(_util.OPS.dependency, [dependency]);
 
-     },
 
-     addDependencies(dependencies) {
 
-       for (var key in dependencies) {
 
-         this.addDependency(key);
 
-       }
 
-     },
 
-     addOpList(opList) {
 
-       Object.assign(this.dependencies, opList.dependencies);
 
-       for (var i = 0, ii = opList.length; i < ii; i++) {
 
-         this.addOp(opList.fnArray[i], opList.argsArray[i]);
 
-       }
 
-     },
 
-     getIR() {
 
-       return {
 
-         fnArray: this.fnArray,
 
-         argsArray: this.argsArray,
 
-         length: this.length
 
-       };
 
-     },
 
-     get _transfers() {
 
-       const transfers = [];
 
-       const {
 
-         fnArray,
 
-         argsArray,
 
-         length
 
-       } = this;
 
-       for (let i = 0; i < length; i++) {
 
-         switch (fnArray[i]) {
 
-           case _util.OPS.paintInlineImageXObject:
 
-           case _util.OPS.paintInlineImageXObjectGroup:
 
-           case _util.OPS.paintImageMaskXObject:
 
-             const arg = argsArray[i][0];
 
-             ;
 
-             if (!arg.cached) {
 
-               transfers.push(arg.data.buffer);
 
-             }
 
-             break;
 
-         }
 
-       }
 
-       return transfers;
 
-     },
 
-     flush(lastChunk = false) {
 
-       this.optimizer.flush();
 
-       const length = this.length;
 
-       this._totalLength += length;
 
-       this._streamSink.enqueue({
 
-         fnArray: this.fnArray,
 
-         argsArray: this.argsArray,
 
-         lastChunk,
 
-         length
 
-       }, 1, this._transfers);
 
-       this.dependencies = Object.create(null);
 
-       this.fnArray.length = 0;
 
-       this.argsArray.length = 0;
 
-       this.weight = 0;
 
-       this.optimizer.reset();
 
-     }
 
-   };
 
-   return OperatorList;
 
- }();
 
- exports.OperatorList = OperatorList;
 
- /***/ }),
 
- /* 25 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.PartialEvaluator = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _cmap = __w_pdfjs_require__(26);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _fonts = __w_pdfjs_require__(27);
 
- var _encodings = __w_pdfjs_require__(30);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _unicode = __w_pdfjs_require__(33);
 
- var _standard_fonts = __w_pdfjs_require__(32);
 
- var _pattern = __w_pdfjs_require__(36);
 
- var _parser = __w_pdfjs_require__(10);
 
- var _bidi = __w_pdfjs_require__(37);
 
- var _colorspace = __w_pdfjs_require__(22);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _glyphlist = __w_pdfjs_require__(31);
 
- var _metrics = __w_pdfjs_require__(38);
 
- var _function = __w_pdfjs_require__(39);
 
- var _jpeg_stream = __w_pdfjs_require__(17);
 
- var _murmurhash = __w_pdfjs_require__(41);
 
- var _image_utils = __w_pdfjs_require__(42);
 
- var _operator_list = __w_pdfjs_require__(24);
 
- var _image = __w_pdfjs_require__(43);
 
- var PartialEvaluator = function PartialEvaluatorClosure() {
 
-   const DefaultPartialEvaluatorOptions = {
 
-     forceDataSchema: false,
 
-     maxImageSize: -1,
 
-     disableFontFace: false,
 
-     nativeImageDecoderSupport: _util.NativeImageDecoding.DECODE,
 
-     ignoreErrors: false,
 
-     isEvalSupported: true
 
-   };
 
-   function PartialEvaluator({
 
-     xref,
 
-     handler,
 
-     pageIndex,
 
-     idFactory,
 
-     fontCache,
 
-     builtInCMapCache,
 
-     options = null,
 
-     pdfFunctionFactory
 
-   }) {
 
-     this.xref = xref;
 
-     this.handler = handler;
 
-     this.pageIndex = pageIndex;
 
-     this.idFactory = idFactory;
 
-     this.fontCache = fontCache;
 
-     this.builtInCMapCache = builtInCMapCache;
 
-     this.options = options || DefaultPartialEvaluatorOptions;
 
-     this.pdfFunctionFactory = pdfFunctionFactory;
 
-     this.parsingType3Font = false;
 
-     this.fetchBuiltInCMap = async name => {
 
-       if (this.builtInCMapCache.has(name)) {
 
-         return this.builtInCMapCache.get(name);
 
-       }
 
-       const readableStream = this.handler.sendWithStream("FetchBuiltInCMap", {
 
-         name
 
-       });
 
-       const reader = readableStream.getReader();
 
-       const data = await new Promise(function (resolve, reject) {
 
-         function pump() {
 
-           reader.read().then(function ({
 
-             value,
 
-             done
 
-           }) {
 
-             if (done) {
 
-               return;
 
-             }
 
-             resolve(value);
 
-             pump();
 
-           }, reject);
 
-         }
 
-         pump();
 
-       });
 
-       if (data.compressionType !== _util.CMapCompressionType.NONE) {
 
-         this.builtInCMapCache.set(name, data);
 
-       }
 
-       return data;
 
-     };
 
-   }
 
-   var TIME_SLOT_DURATION_MS = 20;
 
-   var CHECK_TIME_EVERY = 100;
 
-   function TimeSlotManager() {
 
-     this.reset();
 
-   }
 
-   TimeSlotManager.prototype = {
 
-     check: function TimeSlotManager_check() {
 
-       if (++this.checked < CHECK_TIME_EVERY) {
 
-         return false;
 
-       }
 
-       this.checked = 0;
 
-       return this.endTime <= Date.now();
 
-     },
 
-     reset: function TimeSlotManager_reset() {
 
-       this.endTime = Date.now() + TIME_SLOT_DURATION_MS;
 
-       this.checked = 0;
 
-     }
 
-   };
 
-   function normalizeBlendMode(value, parsingArray = false) {
 
-     if (Array.isArray(value)) {
 
-       for (let i = 0, ii = value.length; i < ii; i++) {
 
-         const maybeBM = normalizeBlendMode(value[i], true);
 
-         if (maybeBM) {
 
-           return maybeBM;
 
-         }
 
-       }
 
-       (0, _util.warn)(`Unsupported blend mode Array: ${value}`);
 
-       return "source-over";
 
-     }
 
-     if (!(0, _primitives.isName)(value)) {
 
-       if (parsingArray) {
 
-         return null;
 
-       }
 
-       return "source-over";
 
-     }
 
-     switch (value.name) {
 
-       case "Normal":
 
-       case "Compatible":
 
-         return "source-over";
 
-       case "Multiply":
 
-         return "multiply";
 
-       case "Screen":
 
-         return "screen";
 
-       case "Overlay":
 
-         return "overlay";
 
-       case "Darken":
 
-         return "darken";
 
-       case "Lighten":
 
-         return "lighten";
 
-       case "ColorDodge":
 
-         return "color-dodge";
 
-       case "ColorBurn":
 
-         return "color-burn";
 
-       case "HardLight":
 
-         return "hard-light";
 
-       case "SoftLight":
 
-         return "soft-light";
 
-       case "Difference":
 
-         return "difference";
 
-       case "Exclusion":
 
-         return "exclusion";
 
-       case "Hue":
 
-         return "hue";
 
-       case "Saturation":
 
-         return "saturation";
 
-       case "Color":
 
-         return "color";
 
-       case "Luminosity":
 
-         return "luminosity";
 
-     }
 
-     if (parsingArray) {
 
-       return null;
 
-     }
 
-     (0, _util.warn)(`Unsupported blend mode: ${value.name}`);
 
-     return "source-over";
 
-   }
 
-   var deferred = Promise.resolve();
 
-   var TILING_PATTERN = 1,
 
-       SHADING_PATTERN = 2;
 
-   PartialEvaluator.prototype = {
 
-     clone(newOptions = DefaultPartialEvaluatorOptions) {
 
-       var newEvaluator = Object.create(this);
 
-       newEvaluator.options = newOptions;
 
-       return newEvaluator;
 
-     },
 
-     hasBlendModes: function PartialEvaluator_hasBlendModes(resources) {
 
-       if (!(resources instanceof _primitives.Dict)) {
 
-         return false;
 
-       }
 
-       var processed = Object.create(null);
 
-       if (resources.objId) {
 
-         processed[resources.objId] = true;
 
-       }
 
-       var nodes = [resources],
 
-           xref = this.xref;
 
-       while (nodes.length) {
 
-         var node = nodes.shift();
 
-         var graphicStates = node.get("ExtGState");
 
-         if (graphicStates instanceof _primitives.Dict) {
 
-           var graphicStatesKeys = graphicStates.getKeys();
 
-           for (let i = 0, ii = graphicStatesKeys.length; i < ii; i++) {
 
-             const key = graphicStatesKeys[i];
 
-             let graphicState = graphicStates.getRaw(key);
 
-             if (graphicState instanceof _primitives.Ref) {
 
-               if (processed[graphicState.toString()]) {
 
-                 continue;
 
-               }
 
-               try {
 
-                 graphicState = xref.fetch(graphicState);
 
-               } catch (ex) {
 
-                 if (ex instanceof _core_utils.MissingDataException) {
 
-                   throw ex;
 
-                 }
 
-                 if (this.options.ignoreErrors) {
 
-                   if (graphicState instanceof _primitives.Ref) {
 
-                     processed[graphicState.toString()] = true;
 
-                   }
 
-                   this.handler.send("UnsupportedFeature", {
 
-                     featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-                   });
 
-                   (0, _util.warn)(`hasBlendModes - ignoring ExtGState: "${ex}".`);
 
-                   continue;
 
-                 }
 
-                 throw ex;
 
-               }
 
-             }
 
-             if (!(graphicState instanceof _primitives.Dict)) {
 
-               continue;
 
-             }
 
-             if (graphicState.objId) {
 
-               processed[graphicState.objId] = true;
 
-             }
 
-             const bm = graphicState.get("BM");
 
-             if (bm instanceof _primitives.Name) {
 
-               if (bm.name !== "Normal") {
 
-                 return true;
 
-               }
 
-               continue;
 
-             }
 
-             if (bm !== undefined && Array.isArray(bm)) {
 
-               for (let j = 0, jj = bm.length; j < jj; j++) {
 
-                 if (bm[j] instanceof _primitives.Name && bm[j].name !== "Normal") {
 
-                   return true;
 
-                 }
 
-               }
 
-             }
 
-           }
 
-         }
 
-         var xObjects = node.get("XObject");
 
-         if (!(xObjects instanceof _primitives.Dict)) {
 
-           continue;
 
-         }
 
-         var xObjectsKeys = xObjects.getKeys();
 
-         for (let i = 0, ii = xObjectsKeys.length; i < ii; i++) {
 
-           const key = xObjectsKeys[i];
 
-           var xObject = xObjects.getRaw(key);
 
-           if (xObject instanceof _primitives.Ref) {
 
-             if (processed[xObject.toString()]) {
 
-               continue;
 
-             }
 
-             try {
 
-               xObject = xref.fetch(xObject);
 
-             } catch (ex) {
 
-               if (ex instanceof _core_utils.MissingDataException) {
 
-                 throw ex;
 
-               }
 
-               if (this.options.ignoreErrors) {
 
-                 if (xObject instanceof _primitives.Ref) {
 
-                   processed[xObject.toString()] = true;
 
-                 }
 
-                 this.handler.send("UnsupportedFeature", {
 
-                   featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-                 });
 
-                 (0, _util.warn)(`hasBlendModes - ignoring XObject: "${ex}".`);
 
-                 continue;
 
-               }
 
-               throw ex;
 
-             }
 
-           }
 
-           if (!(0, _primitives.isStream)(xObject)) {
 
-             continue;
 
-           }
 
-           if (xObject.dict.objId) {
 
-             if (processed[xObject.dict.objId]) {
 
-               continue;
 
-             }
 
-             processed[xObject.dict.objId] = true;
 
-           }
 
-           var xResources = xObject.dict.get("Resources");
 
-           if (xResources instanceof _primitives.Dict && (!xResources.objId || !processed[xResources.objId])) {
 
-             nodes.push(xResources);
 
-             if (xResources.objId) {
 
-               processed[xResources.objId] = true;
 
-             }
 
-           }
 
-         }
 
-       }
 
-       return false;
 
-     },
 
-     async buildFormXObject(resources, xobj, smask, operatorList, task, initialState) {
 
-       var dict = xobj.dict;
 
-       var matrix = dict.getArray("Matrix");
 
-       var bbox = dict.getArray("BBox");
 
-       if (Array.isArray(bbox) && bbox.length === 4) {
 
-         bbox = _util.Util.normalizeRect(bbox);
 
-       } else {
 
-         bbox = null;
 
-       }
 
-       var group = dict.get("Group");
 
-       if (group) {
 
-         var groupOptions = {
 
-           matrix,
 
-           bbox,
 
-           smask,
 
-           isolated: false,
 
-           knockout: false
 
-         };
 
-         var groupSubtype = group.get("S");
 
-         var colorSpace = null;
 
-         if ((0, _primitives.isName)(groupSubtype, "Transparency")) {
 
-           groupOptions.isolated = group.get("I") || false;
 
-           groupOptions.knockout = group.get("K") || false;
 
-           if (group.has("CS")) {
 
-             colorSpace = await this.parseColorSpace({
 
-               cs: group.get("CS"),
 
-               resources
 
-             });
 
-           }
 
-         }
 
-         if (smask && smask.backdrop) {
 
-           colorSpace = colorSpace || _colorspace.ColorSpace.singletons.rgb;
 
-           smask.backdrop = colorSpace.getRgb(smask.backdrop, 0);
 
-         }
 
-         operatorList.addOp(_util.OPS.beginGroup, [groupOptions]);
 
-       }
 
-       operatorList.addOp(_util.OPS.paintFormXObjectBegin, [matrix, bbox]);
 
-       return this.getOperatorList({
 
-         stream: xobj,
 
-         task,
 
-         resources: dict.get("Resources") || resources,
 
-         operatorList,
 
-         initialState
 
-       }).then(function () {
 
-         operatorList.addOp(_util.OPS.paintFormXObjectEnd, []);
 
-         if (group) {
 
-           operatorList.addOp(_util.OPS.endGroup, [groupOptions]);
 
-         }
 
-       });
 
-     },
 
-     async buildPaintImageXObject({
 
-       resources,
 
-       image,
 
-       isInline = false,
 
-       operatorList,
 
-       cacheKey,
 
-       imageCache,
 
-       forceDisableNativeImageDecoder = false
 
-     }) {
 
-       var dict = image.dict;
 
-       var w = dict.get("Width", "W");
 
-       var h = dict.get("Height", "H");
 
-       if (!(w && (0, _util.isNum)(w)) || !(h && (0, _util.isNum)(h))) {
 
-         (0, _util.warn)("Image dimensions are missing, or not numbers.");
 
-         return undefined;
 
-       }
 
-       var maxImageSize = this.options.maxImageSize;
 
-       if (maxImageSize !== -1 && w * h > maxImageSize) {
 
-         (0, _util.warn)("Image exceeded maximum allowed size and was removed.");
 
-         return undefined;
 
-       }
 
-       var imageMask = dict.get("ImageMask", "IM") || false;
 
-       var imgData, args;
 
-       if (imageMask) {
 
-         var width = dict.get("Width", "W");
 
-         var height = dict.get("Height", "H");
 
-         var bitStrideLength = width + 7 >> 3;
 
-         var imgArray = image.getBytes(bitStrideLength * height, true);
 
-         var decode = dict.getArray("Decode", "D");
 
-         imgData = _image.PDFImage.createMask({
 
-           imgArray,
 
-           width,
 
-           height,
 
-           imageIsFromDecodeStream: image instanceof _stream.DecodeStream,
 
-           inverseDecode: !!decode && decode[0] > 0
 
-         });
 
-         imgData.cached = !!cacheKey;
 
-         args = [imgData];
 
-         operatorList.addOp(_util.OPS.paintImageMaskXObject, args);
 
-         if (cacheKey) {
 
-           imageCache[cacheKey] = {
 
-             fn: _util.OPS.paintImageMaskXObject,
 
-             args
 
-           };
 
-         }
 
-         return undefined;
 
-       }
 
-       var softMask = dict.get("SMask", "SM") || false;
 
-       var mask = dict.get("Mask") || false;
 
-       var SMALL_IMAGE_DIMENSIONS = 200;
 
-       if (isInline && !softMask && !mask && !(image instanceof _jpeg_stream.JpegStream) && w + h < SMALL_IMAGE_DIMENSIONS) {
 
-         const imageObj = new _image.PDFImage({
 
-           xref: this.xref,
 
-           res: resources,
 
-           image,
 
-           isInline,
 
-           pdfFunctionFactory: this.pdfFunctionFactory
 
-         });
 
-         imgData = imageObj.createImageData(true);
 
-         operatorList.addOp(_util.OPS.paintInlineImageXObject, [imgData]);
 
-         return undefined;
 
-       }
 
-       const nativeImageDecoderSupport = forceDisableNativeImageDecoder ? _util.NativeImageDecoding.NONE : this.options.nativeImageDecoderSupport;
 
-       let objId = `img_${this.idFactory.createObjId()}`;
 
-       if (this.parsingType3Font) {
 
-         (0, _util.assert)(nativeImageDecoderSupport === _util.NativeImageDecoding.NONE, "Type3 image resources should be completely decoded in the worker.");
 
-         objId = `${this.idFactory.getDocId()}_type3res_${objId}`;
 
-       }
 
-       if (nativeImageDecoderSupport !== _util.NativeImageDecoding.NONE && !softMask && !mask && image instanceof _jpeg_stream.JpegStream && _image_utils.NativeImageDecoder.isSupported(image, this.xref, resources, this.pdfFunctionFactory) && image.maybeValidDimensions) {
 
-         return this.handler.sendWithPromise("obj", [objId, this.pageIndex, "JpegStream", image.getIR(this.options.forceDataSchema)]).then(function () {
 
-           operatorList.addDependency(objId);
 
-           args = [objId, w, h];
 
-           operatorList.addOp(_util.OPS.paintJpegXObject, args);
 
-           if (cacheKey) {
 
-             imageCache[cacheKey] = {
 
-               fn: _util.OPS.paintJpegXObject,
 
-               args
 
-             };
 
-           }
 
-         }, reason => {
 
-           (0, _util.warn)("Native JPEG decoding failed -- trying to recover: " + (reason && reason.message));
 
-           return this.buildPaintImageXObject({
 
-             resources,
 
-             image,
 
-             isInline,
 
-             operatorList,
 
-             cacheKey,
 
-             imageCache,
 
-             forceDisableNativeImageDecoder: true
 
-           });
 
-         });
 
-       }
 
-       var nativeImageDecoder = null;
 
-       if (nativeImageDecoderSupport === _util.NativeImageDecoding.DECODE && (image instanceof _jpeg_stream.JpegStream || mask instanceof _jpeg_stream.JpegStream || softMask instanceof _jpeg_stream.JpegStream)) {
 
-         nativeImageDecoder = new _image_utils.NativeImageDecoder({
 
-           xref: this.xref,
 
-           resources,
 
-           handler: this.handler,
 
-           forceDataSchema: this.options.forceDataSchema,
 
-           pdfFunctionFactory: this.pdfFunctionFactory
 
-         });
 
-       }
 
-       operatorList.addDependency(objId);
 
-       args = [objId, w, h];
 
-       const imgPromise = _image.PDFImage.buildImage({
 
-         handler: this.handler,
 
-         xref: this.xref,
 
-         res: resources,
 
-         image,
 
-         isInline,
 
-         nativeDecoder: nativeImageDecoder,
 
-         pdfFunctionFactory: this.pdfFunctionFactory
 
-       }).then(imageObj => {
 
-         var imgData = imageObj.createImageData(false);
 
-         if (this.parsingType3Font) {
 
-           return this.handler.sendWithPromise("commonobj", [objId, "FontType3Res", imgData], [imgData.data.buffer]);
 
-         }
 
-         this.handler.send("obj", [objId, this.pageIndex, "Image", imgData], [imgData.data.buffer]);
 
-         return undefined;
 
-       }).catch(reason => {
 
-         (0, _util.warn)("Unable to decode image: " + reason);
 
-         if (this.parsingType3Font) {
 
-           return this.handler.sendWithPromise("commonobj", [objId, "FontType3Res", null]);
 
-         }
 
-         this.handler.send("obj", [objId, this.pageIndex, "Image", null]);
 
-         return undefined;
 
-       });
 
-       if (this.parsingType3Font) {
 
-         await imgPromise;
 
-       }
 
-       operatorList.addOp(_util.OPS.paintImageXObject, args);
 
-       if (cacheKey) {
 
-         imageCache[cacheKey] = {
 
-           fn: _util.OPS.paintImageXObject,
 
-           args
 
-         };
 
-       }
 
-       return undefined;
 
-     },
 
-     handleSMask: function PartialEvaluator_handleSmask(smask, resources, operatorList, task, stateManager) {
 
-       var smaskContent = smask.get("G");
 
-       var smaskOptions = {
 
-         subtype: smask.get("S").name,
 
-         backdrop: smask.get("BC")
 
-       };
 
-       var transferObj = smask.get("TR");
 
-       if ((0, _function.isPDFFunction)(transferObj)) {
 
-         const transferFn = this.pdfFunctionFactory.create(transferObj);
 
-         var transferMap = new Uint8Array(256);
 
-         var tmp = new Float32Array(1);
 
-         for (var i = 0; i < 256; i++) {
 
-           tmp[0] = i / 255;
 
-           transferFn(tmp, 0, tmp, 0);
 
-           transferMap[i] = tmp[0] * 255 | 0;
 
-         }
 
-         smaskOptions.transferMap = transferMap;
 
-       }
 
-       return this.buildFormXObject(resources, smaskContent, smaskOptions, operatorList, task, stateManager.state.clone());
 
-     },
 
-     handleTilingType(fn, args, resources, pattern, patternDict, operatorList, task) {
 
-       const tilingOpList = new _operator_list.OperatorList();
 
-       const resourcesArray = [patternDict.get("Resources"), resources];
 
-       const patternResources = _primitives.Dict.merge(this.xref, resourcesArray);
 
-       return this.getOperatorList({
 
-         stream: pattern,
 
-         task,
 
-         resources: patternResources,
 
-         operatorList: tilingOpList
 
-       }).then(function () {
 
-         return (0, _pattern.getTilingPatternIR)({
 
-           fnArray: tilingOpList.fnArray,
 
-           argsArray: tilingOpList.argsArray
 
-         }, patternDict, args);
 
-       }).then(function (tilingPatternIR) {
 
-         operatorList.addDependencies(tilingOpList.dependencies);
 
-         operatorList.addOp(fn, tilingPatternIR);
 
-       }, reason => {
 
-         if (reason instanceof _util.AbortException) {
 
-           return;
 
-         }
 
-         if (this.options.ignoreErrors) {
 
-           this.handler.send("UnsupportedFeature", {
 
-             featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-           });
 
-           (0, _util.warn)(`handleTilingType - ignoring pattern: "${reason}".`);
 
-           return;
 
-         }
 
-         throw reason;
 
-       });
 
-     },
 
-     handleSetFont: function PartialEvaluator_handleSetFont(resources, fontArgs, fontRef, operatorList, task, state) {
 
-       var fontName;
 
-       if (fontArgs) {
 
-         fontArgs = fontArgs.slice();
 
-         fontName = fontArgs[0].name;
 
-       }
 
-       return this.loadFont(fontName, fontRef, resources).then(translated => {
 
-         if (!translated.font.isType3Font) {
 
-           return translated;
 
-         }
 
-         return translated.loadType3Data(this, resources, operatorList, task).then(function () {
 
-           return translated;
 
-         }).catch(reason => {
 
-           this.handler.send("UnsupportedFeature", {
 
-             featureId: _util.UNSUPPORTED_FEATURES.font
 
-           });
 
-           return new TranslatedFont("g_font_error", new _fonts.ErrorFont("Type3 font load error: " + reason), translated.font);
 
-         });
 
-       }).then(translated => {
 
-         state.font = translated.font;
 
-         translated.send(this.handler);
 
-         return translated.loadedName;
 
-       });
 
-     },
 
-     handleText(chars, state) {
 
-       const font = state.font;
 
-       const glyphs = font.charsToGlyphs(chars);
 
-       if (font.data) {
 
-         const isAddToPathSet = !!(state.textRenderingMode & _util.TextRenderingMode.ADD_TO_PATH_FLAG);
 
-         if (isAddToPathSet || state.fillColorSpace.name === "Pattern" || font.disableFontFace || this.options.disableFontFace) {
 
-           PartialEvaluator.buildFontPaths(font, glyphs, this.handler);
 
-         }
 
-       }
 
-       return glyphs;
 
-     },
 
-     ensureStateFont(state) {
 
-       if (state.font) {
 
-         return;
 
-       }
 
-       const reason = new _util.FormatError("Missing setFont (Tf) operator before text rendering operator.");
 
-       if (this.options.ignoreErrors) {
 
-         this.handler.send("UnsupportedFeature", {
 
-           featureId: _util.UNSUPPORTED_FEATURES.font
 
-         });
 
-         (0, _util.warn)(`ensureStateFont: "${reason}".`);
 
-         return;
 
-       }
 
-       throw reason;
 
-     },
 
-     setGState: function PartialEvaluator_setGState(resources, gState, operatorList, task, stateManager) {
 
-       var gStateObj = [];
 
-       var gStateKeys = gState.getKeys();
 
-       var promise = Promise.resolve();
 
-       for (var i = 0, ii = gStateKeys.length; i < ii; i++) {
 
-         const key = gStateKeys[i];
 
-         const value = gState.get(key);
 
-         switch (key) {
 
-           case "Type":
 
-             break;
 
-           case "LW":
 
-           case "LC":
 
-           case "LJ":
 
-           case "ML":
 
-           case "D":
 
-           case "RI":
 
-           case "FL":
 
-           case "CA":
 
-           case "ca":
 
-             gStateObj.push([key, value]);
 
-             break;
 
-           case "Font":
 
-             promise = promise.then(() => {
 
-               return this.handleSetFont(resources, null, value[0], operatorList, task, stateManager.state).then(function (loadedName) {
 
-                 operatorList.addDependency(loadedName);
 
-                 gStateObj.push([key, [loadedName, value[1]]]);
 
-               });
 
-             });
 
-             break;
 
-           case "BM":
 
-             gStateObj.push([key, normalizeBlendMode(value)]);
 
-             break;
 
-           case "SMask":
 
-             if ((0, _primitives.isName)(value, "None")) {
 
-               gStateObj.push([key, false]);
 
-               break;
 
-             }
 
-             if ((0, _primitives.isDict)(value)) {
 
-               promise = promise.then(() => {
 
-                 return this.handleSMask(value, resources, operatorList, task, stateManager);
 
-               });
 
-               gStateObj.push([key, true]);
 
-             } else {
 
-               (0, _util.warn)("Unsupported SMask type");
 
-             }
 
-             break;
 
-           case "OP":
 
-           case "op":
 
-           case "OPM":
 
-           case "BG":
 
-           case "BG2":
 
-           case "UCR":
 
-           case "UCR2":
 
-           case "TR":
 
-           case "TR2":
 
-           case "HT":
 
-           case "SM":
 
-           case "SA":
 
-           case "AIS":
 
-           case "TK":
 
-             (0, _util.info)("graphic state operator " + key);
 
-             break;
 
-           default:
 
-             (0, _util.info)("Unknown graphic state operator " + key);
 
-             break;
 
-         }
 
-       }
 
-       return promise.then(function () {
 
-         if (gStateObj.length > 0) {
 
-           operatorList.addOp(_util.OPS.setGState, [gStateObj]);
 
-         }
 
-       });
 
-     },
 
-     loadFont: function PartialEvaluator_loadFont(fontName, font, resources) {
 
-       function errorFont() {
 
-         return Promise.resolve(new TranslatedFont("g_font_error", new _fonts.ErrorFont("Font " + fontName + " is not available"), font));
 
-       }
 
-       var fontRef,
 
-           xref = this.xref;
 
-       if (font) {
 
-         if (!(0, _primitives.isRef)(font)) {
 
-           throw new _util.FormatError('The "font" object should be a reference.');
 
-         }
 
-         fontRef = font;
 
-       } else {
 
-         var fontRes = resources.get("Font");
 
-         if (fontRes) {
 
-           fontRef = fontRes.getRaw(fontName);
 
-         }
 
-       }
 
-       if (!fontRef) {
 
-         const partialMsg = `Font "${fontName || font && font.toString()}" is not available`;
 
-         if (!this.options.ignoreErrors && !this.parsingType3Font) {
 
-           (0, _util.warn)(`${partialMsg}.`);
 
-           return errorFont();
 
-         }
 
-         this.handler.send("UnsupportedFeature", {
 
-           featureId: _util.UNSUPPORTED_FEATURES.font
 
-         });
 
-         (0, _util.warn)(`${partialMsg} -- attempting to fallback to a default font.`);
 
-         fontRef = PartialEvaluator.getFallbackFontDict();
 
-       }
 
-       if (this.fontCache.has(fontRef)) {
 
-         return this.fontCache.get(fontRef);
 
-       }
 
-       font = xref.fetchIfRef(fontRef);
 
-       if (!(0, _primitives.isDict)(font)) {
 
-         return errorFont();
 
-       }
 
-       if (font.translated) {
 
-         return font.translated;
 
-       }
 
-       var fontCapability = (0, _util.createPromiseCapability)();
 
-       var preEvaluatedFont = this.preEvaluateFont(font);
 
-       const {
 
-         descriptor,
 
-         hash
 
-       } = preEvaluatedFont;
 
-       var fontRefIsRef = (0, _primitives.isRef)(fontRef),
 
-           fontID;
 
-       if (fontRefIsRef) {
 
-         fontID = fontRef.toString();
 
-       }
 
-       if (hash && (0, _primitives.isDict)(descriptor)) {
 
-         if (!descriptor.fontAliases) {
 
-           descriptor.fontAliases = Object.create(null);
 
-         }
 
-         var fontAliases = descriptor.fontAliases;
 
-         if (fontAliases[hash]) {
 
-           var aliasFontRef = fontAliases[hash].aliasRef;
 
-           if (fontRefIsRef && aliasFontRef && this.fontCache.has(aliasFontRef)) {
 
-             this.fontCache.putAlias(fontRef, aliasFontRef);
 
-             return this.fontCache.get(fontRef);
 
-           }
 
-         } else {
 
-           fontAliases[hash] = {
 
-             fontID: _fonts.Font.getFontID()
 
-           };
 
-         }
 
-         if (fontRefIsRef) {
 
-           fontAliases[hash].aliasRef = fontRef;
 
-         }
 
-         fontID = fontAliases[hash].fontID;
 
-       }
 
-       if (fontRefIsRef) {
 
-         this.fontCache.put(fontRef, fontCapability.promise);
 
-       } else {
 
-         if (!fontID) {
 
-           fontID = this.idFactory.createObjId();
 
-         }
 
-         this.fontCache.put(`id_${fontID}`, fontCapability.promise);
 
-       }
 
-       (0, _util.assert)(fontID, 'The "fontID" must be defined.');
 
-       font.loadedName = `${this.idFactory.getDocId()}_f${fontID}`;
 
-       font.translated = fontCapability.promise;
 
-       var translatedPromise;
 
-       try {
 
-         translatedPromise = this.translateFont(preEvaluatedFont);
 
-       } catch (e) {
 
-         translatedPromise = Promise.reject(e);
 
-       }
 
-       translatedPromise.then(function (translatedFont) {
 
-         if (translatedFont.fontType !== undefined) {
 
-           var xrefFontStats = xref.stats.fontTypes;
 
-           xrefFontStats[translatedFont.fontType] = true;
 
-         }
 
-         fontCapability.resolve(new TranslatedFont(font.loadedName, translatedFont, font));
 
-       }).catch(reason => {
 
-         this.handler.send("UnsupportedFeature", {
 
-           featureId: _util.UNSUPPORTED_FEATURES.font
 
-         });
 
-         try {
 
-           var fontFile3 = descriptor && descriptor.get("FontFile3");
 
-           var subtype = fontFile3 && fontFile3.get("Subtype");
 
-           var fontType = (0, _fonts.getFontType)(preEvaluatedFont.type, subtype && subtype.name);
 
-           var xrefFontStats = xref.stats.fontTypes;
 
-           xrefFontStats[fontType] = true;
 
-         } catch (ex) {}
 
-         fontCapability.resolve(new TranslatedFont(font.loadedName, new _fonts.ErrorFont(reason instanceof Error ? reason.message : reason), font));
 
-       });
 
-       return fontCapability.promise;
 
-     },
 
-     buildPath(operatorList, fn, args, parsingText = false) {
 
-       var lastIndex = operatorList.length - 1;
 
-       if (!args) {
 
-         args = [];
 
-       }
 
-       if (lastIndex < 0 || operatorList.fnArray[lastIndex] !== _util.OPS.constructPath) {
 
-         if (parsingText) {
 
-           (0, _util.warn)(`Encountered path operator "${fn}" inside of a text object.`);
 
-           operatorList.addOp(_util.OPS.save, null);
 
-         }
 
-         operatorList.addOp(_util.OPS.constructPath, [[fn], args]);
 
-         if (parsingText) {
 
-           operatorList.addOp(_util.OPS.restore, null);
 
-         }
 
-       } else {
 
-         var opArgs = operatorList.argsArray[lastIndex];
 
-         opArgs[0].push(fn);
 
-         Array.prototype.push.apply(opArgs[1], args);
 
-       }
 
-     },
 
-     parseColorSpace({
 
-       cs,
 
-       resources
 
-     }) {
 
-       return new Promise(resolve => {
 
-         resolve(_colorspace.ColorSpace.parse(cs, this.xref, resources, this.pdfFunctionFactory));
 
-       }).catch(reason => {
 
-         if (reason instanceof _util.AbortException) {
 
-           return null;
 
-         }
 
-         if (this.options.ignoreErrors) {
 
-           this.handler.send("UnsupportedFeature", {
 
-             featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-           });
 
-           (0, _util.warn)(`parseColorSpace - ignoring ColorSpace: "${reason}".`);
 
-           return null;
 
-         }
 
-         throw reason;
 
-       });
 
-     },
 
-     async handleColorN(operatorList, fn, args, cs, patterns, resources, task) {
 
-       var patternName = args[args.length - 1];
 
-       var pattern;
 
-       if ((0, _primitives.isName)(patternName) && (pattern = patterns.get(patternName.name))) {
 
-         var dict = (0, _primitives.isStream)(pattern) ? pattern.dict : pattern;
 
-         var typeNum = dict.get("PatternType");
 
-         if (typeNum === TILING_PATTERN) {
 
-           var color = cs.base ? cs.base.getRgb(args, 0) : null;
 
-           return this.handleTilingType(fn, color, resources, pattern, dict, operatorList, task);
 
-         } else if (typeNum === SHADING_PATTERN) {
 
-           var shading = dict.get("Shading");
 
-           var matrix = dict.getArray("Matrix");
 
-           pattern = _pattern.Pattern.parseShading(shading, matrix, this.xref, resources, this.handler, this.pdfFunctionFactory);
 
-           operatorList.addOp(fn, pattern.getIR());
 
-           return undefined;
 
-         }
 
-         throw new _util.FormatError(`Unknown PatternType: ${typeNum}`);
 
-       }
 
-       throw new _util.FormatError(`Unknown PatternName: ${patternName}`);
 
-     },
 
-     getOperatorList({
 
-       stream,
 
-       task,
 
-       resources,
 
-       operatorList,
 
-       initialState = null
 
-     }) {
 
-       resources = resources || _primitives.Dict.empty;
 
-       initialState = initialState || new EvalState();
 
-       if (!operatorList) {
 
-         throw new Error('getOperatorList: missing "operatorList" parameter');
 
-       }
 
-       var self = this;
 
-       var xref = this.xref;
 
-       let parsingText = false;
 
-       var imageCache = Object.create(null);
 
-       var xobjs = resources.get("XObject") || _primitives.Dict.empty;
 
-       var patterns = resources.get("Pattern") || _primitives.Dict.empty;
 
-       var stateManager = new StateManager(initialState);
 
-       var preprocessor = new EvaluatorPreprocessor(stream, xref, stateManager);
 
-       var timeSlotManager = new TimeSlotManager();
 
-       function closePendingRestoreOPS(argument) {
 
-         for (var i = 0, ii = preprocessor.savedStatesDepth; i < ii; i++) {
 
-           operatorList.addOp(_util.OPS.restore, []);
 
-         }
 
-       }
 
-       return new Promise(function promiseBody(resolve, reject) {
 
-         const next = function (promise) {
 
-           Promise.all([promise, operatorList.ready]).then(function () {
 
-             try {
 
-               promiseBody(resolve, reject);
 
-             } catch (ex) {
 
-               reject(ex);
 
-             }
 
-           }, reject);
 
-         };
 
-         task.ensureNotTerminated();
 
-         timeSlotManager.reset();
 
-         var stop,
 
-             operation = {},
 
-             i,
 
-             ii,
 
-             cs;
 
-         while (!(stop = timeSlotManager.check())) {
 
-           operation.args = null;
 
-           if (!preprocessor.read(operation)) {
 
-             break;
 
-           }
 
-           var args = operation.args;
 
-           var fn = operation.fn;
 
-           switch (fn | 0) {
 
-             case _util.OPS.paintXObject:
 
-               var name = args[0].name;
 
-               if (name && imageCache[name] !== undefined) {
 
-                 operatorList.addOp(imageCache[name].fn, imageCache[name].args);
 
-                 args = null;
 
-                 continue;
 
-               }
 
-               next(new Promise(function (resolveXObject, rejectXObject) {
 
-                 if (!name) {
 
-                   throw new _util.FormatError("XObject must be referred to by name.");
 
-                 }
 
-                 const xobj = xobjs.get(name);
 
-                 if (!xobj) {
 
-                   operatorList.addOp(fn, args);
 
-                   resolveXObject();
 
-                   return;
 
-                 }
 
-                 if (!(0, _primitives.isStream)(xobj)) {
 
-                   throw new _util.FormatError("XObject should be a stream");
 
-                 }
 
-                 const type = xobj.dict.get("Subtype");
 
-                 if (!(0, _primitives.isName)(type)) {
 
-                   throw new _util.FormatError("XObject should have a Name subtype");
 
-                 }
 
-                 if (type.name === "Form") {
 
-                   stateManager.save();
 
-                   self.buildFormXObject(resources, xobj, null, operatorList, task, stateManager.state.clone()).then(function () {
 
-                     stateManager.restore();
 
-                     resolveXObject();
 
-                   }, rejectXObject);
 
-                   return;
 
-                 } else if (type.name === "Image") {
 
-                   self.buildPaintImageXObject({
 
-                     resources,
 
-                     image: xobj,
 
-                     operatorList,
 
-                     cacheKey: name,
 
-                     imageCache
 
-                   }).then(resolveXObject, rejectXObject);
 
-                   return;
 
-                 } else if (type.name === "PS") {
 
-                   (0, _util.info)("Ignored XObject subtype PS");
 
-                 } else {
 
-                   throw new _util.FormatError(`Unhandled XObject subtype ${type.name}`);
 
-                 }
 
-                 resolveXObject();
 
-               }).catch(function (reason) {
 
-                 if (reason instanceof _util.AbortException) {
 
-                   return;
 
-                 }
 
-                 if (self.options.ignoreErrors) {
 
-                   self.handler.send("UnsupportedFeature", {
 
-                     featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-                   });
 
-                   (0, _util.warn)(`getOperatorList - ignoring XObject: "${reason}".`);
 
-                   return;
 
-                 }
 
-                 throw reason;
 
-               }));
 
-               return;
 
-             case _util.OPS.setFont:
 
-               var fontSize = args[1];
 
-               next(self.handleSetFont(resources, args, null, operatorList, task, stateManager.state).then(function (loadedName) {
 
-                 operatorList.addDependency(loadedName);
 
-                 operatorList.addOp(_util.OPS.setFont, [loadedName, fontSize]);
 
-               }));
 
-               return;
 
-             case _util.OPS.beginText:
 
-               parsingText = true;
 
-               break;
 
-             case _util.OPS.endText:
 
-               parsingText = false;
 
-               break;
 
-             case _util.OPS.endInlineImage:
 
-               var cacheKey = args[0].cacheKey;
 
-               if (cacheKey) {
 
-                 var cacheEntry = imageCache[cacheKey];
 
-                 if (cacheEntry !== undefined) {
 
-                   operatorList.addOp(cacheEntry.fn, cacheEntry.args);
 
-                   args = null;
 
-                   continue;
 
-                 }
 
-               }
 
-               next(self.buildPaintImageXObject({
 
-                 resources,
 
-                 image: args[0],
 
-                 isInline: true,
 
-                 operatorList,
 
-                 cacheKey,
 
-                 imageCache
 
-               }));
 
-               return;
 
-             case _util.OPS.showText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               args[0] = self.handleText(args[0], stateManager.state);
 
-               break;
 
-             case _util.OPS.showSpacedText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               var arr = args[0];
 
-               var combinedGlyphs = [];
 
-               var arrLength = arr.length;
 
-               var state = stateManager.state;
 
-               for (i = 0; i < arrLength; ++i) {
 
-                 var arrItem = arr[i];
 
-                 if ((0, _util.isString)(arrItem)) {
 
-                   Array.prototype.push.apply(combinedGlyphs, self.handleText(arrItem, state));
 
-                 } else if ((0, _util.isNum)(arrItem)) {
 
-                   combinedGlyphs.push(arrItem);
 
-                 }
 
-               }
 
-               args[0] = combinedGlyphs;
 
-               fn = _util.OPS.showText;
 
-               break;
 
-             case _util.OPS.nextLineShowText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               operatorList.addOp(_util.OPS.nextLine);
 
-               args[0] = self.handleText(args[0], stateManager.state);
 
-               fn = _util.OPS.showText;
 
-               break;
 
-             case _util.OPS.nextLineSetSpacingShowText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               operatorList.addOp(_util.OPS.nextLine);
 
-               operatorList.addOp(_util.OPS.setWordSpacing, [args.shift()]);
 
-               operatorList.addOp(_util.OPS.setCharSpacing, [args.shift()]);
 
-               args[0] = self.handleText(args[0], stateManager.state);
 
-               fn = _util.OPS.showText;
 
-               break;
 
-             case _util.OPS.setTextRenderingMode:
 
-               stateManager.state.textRenderingMode = args[0];
 
-               break;
 
-             case _util.OPS.setFillColorSpace:
 
-               next(self.parseColorSpace({
 
-                 cs: args[0],
 
-                 resources
 
-               }).then(function (colorSpace) {
 
-                 if (colorSpace) {
 
-                   stateManager.state.fillColorSpace = colorSpace;
 
-                 }
 
-               }));
 
-               return;
 
-             case _util.OPS.setStrokeColorSpace:
 
-               next(self.parseColorSpace({
 
-                 cs: args[0],
 
-                 resources
 
-               }).then(function (colorSpace) {
 
-                 if (colorSpace) {
 
-                   stateManager.state.strokeColorSpace = colorSpace;
 
-                 }
 
-               }));
 
-               return;
 
-             case _util.OPS.setFillColor:
 
-               cs = stateManager.state.fillColorSpace;
 
-               args = cs.getRgb(args, 0);
 
-               fn = _util.OPS.setFillRGBColor;
 
-               break;
 
-             case _util.OPS.setStrokeColor:
 
-               cs = stateManager.state.strokeColorSpace;
 
-               args = cs.getRgb(args, 0);
 
-               fn = _util.OPS.setStrokeRGBColor;
 
-               break;
 
-             case _util.OPS.setFillGray:
 
-               stateManager.state.fillColorSpace = _colorspace.ColorSpace.singletons.gray;
 
-               args = _colorspace.ColorSpace.singletons.gray.getRgb(args, 0);
 
-               fn = _util.OPS.setFillRGBColor;
 
-               break;
 
-             case _util.OPS.setStrokeGray:
 
-               stateManager.state.strokeColorSpace = _colorspace.ColorSpace.singletons.gray;
 
-               args = _colorspace.ColorSpace.singletons.gray.getRgb(args, 0);
 
-               fn = _util.OPS.setStrokeRGBColor;
 
-               break;
 
-             case _util.OPS.setFillCMYKColor:
 
-               stateManager.state.fillColorSpace = _colorspace.ColorSpace.singletons.cmyk;
 
-               args = _colorspace.ColorSpace.singletons.cmyk.getRgb(args, 0);
 
-               fn = _util.OPS.setFillRGBColor;
 
-               break;
 
-             case _util.OPS.setStrokeCMYKColor:
 
-               stateManager.state.strokeColorSpace = _colorspace.ColorSpace.singletons.cmyk;
 
-               args = _colorspace.ColorSpace.singletons.cmyk.getRgb(args, 0);
 
-               fn = _util.OPS.setStrokeRGBColor;
 
-               break;
 
-             case _util.OPS.setFillRGBColor:
 
-               stateManager.state.fillColorSpace = _colorspace.ColorSpace.singletons.rgb;
 
-               args = _colorspace.ColorSpace.singletons.rgb.getRgb(args, 0);
 
-               break;
 
-             case _util.OPS.setStrokeRGBColor:
 
-               stateManager.state.strokeColorSpace = _colorspace.ColorSpace.singletons.rgb;
 
-               args = _colorspace.ColorSpace.singletons.rgb.getRgb(args, 0);
 
-               break;
 
-             case _util.OPS.setFillColorN:
 
-               cs = stateManager.state.fillColorSpace;
 
-               if (cs.name === "Pattern") {
 
-                 next(self.handleColorN(operatorList, _util.OPS.setFillColorN, args, cs, patterns, resources, task));
 
-                 return;
 
-               }
 
-               args = cs.getRgb(args, 0);
 
-               fn = _util.OPS.setFillRGBColor;
 
-               break;
 
-             case _util.OPS.setStrokeColorN:
 
-               cs = stateManager.state.strokeColorSpace;
 
-               if (cs.name === "Pattern") {
 
-                 next(self.handleColorN(operatorList, _util.OPS.setStrokeColorN, args, cs, patterns, resources, task));
 
-                 return;
 
-               }
 
-               args = cs.getRgb(args, 0);
 
-               fn = _util.OPS.setStrokeRGBColor;
 
-               break;
 
-             case _util.OPS.shadingFill:
 
-               var shadingRes = resources.get("Shading");
 
-               if (!shadingRes) {
 
-                 throw new _util.FormatError("No shading resource found");
 
-               }
 
-               var shading = shadingRes.get(args[0].name);
 
-               if (!shading) {
 
-                 throw new _util.FormatError("No shading object found");
 
-               }
 
-               var shadingFill = _pattern.Pattern.parseShading(shading, null, xref, resources, self.handler, self.pdfFunctionFactory);
 
-               var patternIR = shadingFill.getIR();
 
-               args = [patternIR];
 
-               fn = _util.OPS.shadingFill;
 
-               break;
 
-             case _util.OPS.setGState:
 
-               var dictName = args[0];
 
-               var extGState = resources.get("ExtGState");
 
-               if (!(0, _primitives.isDict)(extGState) || !extGState.has(dictName.name)) {
 
-                 break;
 
-               }
 
-               var gState = extGState.get(dictName.name);
 
-               next(self.setGState(resources, gState, operatorList, task, stateManager));
 
-               return;
 
-             case _util.OPS.moveTo:
 
-             case _util.OPS.lineTo:
 
-             case _util.OPS.curveTo:
 
-             case _util.OPS.curveTo2:
 
-             case _util.OPS.curveTo3:
 
-             case _util.OPS.closePath:
 
-             case _util.OPS.rectangle:
 
-               self.buildPath(operatorList, fn, args, parsingText);
 
-               continue;
 
-             case _util.OPS.markPoint:
 
-             case _util.OPS.markPointProps:
 
-             case _util.OPS.beginMarkedContent:
 
-             case _util.OPS.beginMarkedContentProps:
 
-             case _util.OPS.endMarkedContent:
 
-             case _util.OPS.beginCompat:
 
-             case _util.OPS.endCompat:
 
-               continue;
 
-             default:
 
-               if (args !== null) {
 
-                 for (i = 0, ii = args.length; i < ii; i++) {
 
-                   if (args[i] instanceof _primitives.Dict) {
 
-                     break;
 
-                   }
 
-                 }
 
-                 if (i < ii) {
 
-                   (0, _util.warn)("getOperatorList - ignoring operator: " + fn);
 
-                   continue;
 
-                 }
 
-               }
 
-           }
 
-           operatorList.addOp(fn, args);
 
-         }
 
-         if (stop) {
 
-           next(deferred);
 
-           return;
 
-         }
 
-         closePendingRestoreOPS();
 
-         resolve();
 
-       }).catch(reason => {
 
-         if (reason instanceof _util.AbortException) {
 
-           return;
 
-         }
 
-         if (this.options.ignoreErrors) {
 
-           this.handler.send("UnsupportedFeature", {
 
-             featureId: _util.UNSUPPORTED_FEATURES.unknown
 
-           });
 
-           (0, _util.warn)(`getOperatorList - ignoring errors during "${task.name}" ` + `task: "${reason}".`);
 
-           closePendingRestoreOPS();
 
-           return;
 
-         }
 
-         throw reason;
 
-       });
 
-     },
 
-     getTextContent({
 
-       stream,
 
-       task,
 
-       resources,
 
-       stateManager = null,
 
-       normalizeWhitespace = false,
 
-       combineTextItems = false,
 
-       sink,
 
-       seenStyles = Object.create(null)
 
-     }) {
 
-       resources = resources || _primitives.Dict.empty;
 
-       stateManager = stateManager || new StateManager(new TextState());
 
-       var WhitespaceRegexp = /\s/g;
 
-       var textContent = {
 
-         items: [],
 
-         styles: Object.create(null)
 
-       };
 
-       var textContentItem = {
 
-         initialized: false,
 
-         str: [],
 
-         width: 0,
 
-         height: 0,
 
-         vertical: false,
 
-         lastAdvanceWidth: 0,
 
-         lastAdvanceHeight: 0,
 
-         textAdvanceScale: 0,
 
-         spaceWidth: 0,
 
-         fakeSpaceMin: Infinity,
 
-         fakeMultiSpaceMin: Infinity,
 
-         fakeMultiSpaceMax: -0,
 
-         textRunBreakAllowed: false,
 
-         transform: null,
 
-         fontName: null
 
-       };
 
-       var SPACE_FACTOR = 0.3;
 
-       var MULTI_SPACE_FACTOR = 1.5;
 
-       var MULTI_SPACE_FACTOR_MAX = 4;
 
-       var self = this;
 
-       var xref = this.xref;
 
-       var xobjs = null;
 
-       var skipEmptyXObjs = Object.create(null);
 
-       var preprocessor = new EvaluatorPreprocessor(stream, xref, stateManager);
 
-       var textState;
 
-       function ensureTextContentItem() {
 
-         if (textContentItem.initialized) {
 
-           return textContentItem;
 
-         }
 
-         var font = textState.font;
 
-         if (!(font.loadedName in seenStyles)) {
 
-           seenStyles[font.loadedName] = true;
 
-           textContent.styles[font.loadedName] = {
 
-             fontFamily: font.fallbackName,
 
-             ascent: font.ascent,
 
-             descent: font.descent,
 
-             vertical: !!font.vertical
 
-           };
 
-         }
 
-         textContentItem.fontName = font.loadedName;
 
-         var tsm = [textState.fontSize * textState.textHScale, 0, 0, textState.fontSize, 0, textState.textRise];
 
-         if (font.isType3Font && textState.fontSize <= 1 && !(0, _util.isArrayEqual)(textState.fontMatrix, _util.FONT_IDENTITY_MATRIX)) {
 
-           const glyphHeight = font.bbox[3] - font.bbox[1];
 
-           if (glyphHeight > 0) {
 
-             tsm[3] *= glyphHeight * textState.fontMatrix[3];
 
-           }
 
-         }
 
-         var trm = _util.Util.transform(textState.ctm, _util.Util.transform(textState.textMatrix, tsm));
 
-         textContentItem.transform = trm;
 
-         if (!font.vertical) {
 
-           textContentItem.width = 0;
 
-           textContentItem.height = Math.sqrt(trm[2] * trm[2] + trm[3] * trm[3]);
 
-           textContentItem.vertical = false;
 
-         } else {
 
-           textContentItem.width = Math.sqrt(trm[0] * trm[0] + trm[1] * trm[1]);
 
-           textContentItem.height = 0;
 
-           textContentItem.vertical = true;
 
-         }
 
-         var a = textState.textLineMatrix[0];
 
-         var b = textState.textLineMatrix[1];
 
-         var scaleLineX = Math.sqrt(a * a + b * b);
 
-         a = textState.ctm[0];
 
-         b = textState.ctm[1];
 
-         var scaleCtmX = Math.sqrt(a * a + b * b);
 
-         textContentItem.textAdvanceScale = scaleCtmX * scaleLineX;
 
-         textContentItem.lastAdvanceWidth = 0;
 
-         textContentItem.lastAdvanceHeight = 0;
 
-         var spaceWidth = font.spaceWidth / 1000 * textState.fontSize;
 
-         if (spaceWidth) {
 
-           textContentItem.spaceWidth = spaceWidth;
 
-           textContentItem.fakeSpaceMin = spaceWidth * SPACE_FACTOR;
 
-           textContentItem.fakeMultiSpaceMin = spaceWidth * MULTI_SPACE_FACTOR;
 
-           textContentItem.fakeMultiSpaceMax = spaceWidth * MULTI_SPACE_FACTOR_MAX;
 
-           textContentItem.textRunBreakAllowed = !font.isMonospace;
 
-         } else {
 
-           textContentItem.spaceWidth = 0;
 
-           textContentItem.fakeSpaceMin = Infinity;
 
-           textContentItem.fakeMultiSpaceMin = Infinity;
 
-           textContentItem.fakeMultiSpaceMax = 0;
 
-           textContentItem.textRunBreakAllowed = false;
 
-         }
 
-         textContentItem.initialized = true;
 
-         return textContentItem;
 
-       }
 
-       function replaceWhitespace(str) {
 
-         var i = 0,
 
-             ii = str.length,
 
-             code;
 
-         while (i < ii && (code = str.charCodeAt(i)) >= 0x20 && code <= 0x7f) {
 
-           i++;
 
-         }
 
-         return i < ii ? str.replace(WhitespaceRegexp, " ") : str;
 
-       }
 
-       function runBidiTransform(textChunk) {
 
-         var str = textChunk.str.join("");
 
-         var bidiResult = (0, _bidi.bidi)(str, -1, textChunk.vertical);
 
-         return {
 
-           str: normalizeWhitespace ? replaceWhitespace(bidiResult.str) : bidiResult.str,
 
-           dir: bidiResult.dir,
 
-           width: textChunk.width,
 
-           height: textChunk.height,
 
-           transform: textChunk.transform,
 
-           fontName: textChunk.fontName
 
-         };
 
-       }
 
-       function handleSetFont(fontName, fontRef) {
 
-         return self.loadFont(fontName, fontRef, resources).then(function (translated) {
 
-           textState.font = translated.font;
 
-           textState.fontMatrix = translated.font.fontMatrix || _util.FONT_IDENTITY_MATRIX;
 
-         });
 
-       }
 
-       function buildTextContentItem(chars) {
 
-         var font = textState.font;
 
-         var textChunk = ensureTextContentItem();
 
-         var width = 0;
 
-         var height = 0;
 
-         var glyphs = font.charsToGlyphs(chars);
 
-         for (var i = 0; i < glyphs.length; i++) {
 
-           var glyph = glyphs[i];
 
-           var glyphWidth = null;
 
-           if (font.vertical && glyph.vmetric) {
 
-             glyphWidth = glyph.vmetric[0];
 
-           } else {
 
-             glyphWidth = glyph.width;
 
-           }
 
-           var glyphUnicode = glyph.unicode;
 
-           var NormalizedUnicodes = (0, _unicode.getNormalizedUnicodes)();
 
-           if (NormalizedUnicodes[glyphUnicode] !== undefined) {
 
-             glyphUnicode = NormalizedUnicodes[glyphUnicode];
 
-           }
 
-           glyphUnicode = (0, _unicode.reverseIfRtl)(glyphUnicode);
 
-           var charSpacing = textState.charSpacing;
 
-           if (glyph.isSpace) {
 
-             var wordSpacing = textState.wordSpacing;
 
-             charSpacing += wordSpacing;
 
-             if (wordSpacing > 0) {
 
-               addFakeSpaces(wordSpacing, textChunk.str);
 
-             }
 
-           }
 
-           var tx = 0;
 
-           var ty = 0;
 
-           if (!font.vertical) {
 
-             var w0 = glyphWidth * textState.fontMatrix[0];
 
-             tx = (w0 * textState.fontSize + charSpacing) * textState.textHScale;
 
-             width += tx;
 
-           } else {
 
-             var w1 = glyphWidth * textState.fontMatrix[0];
 
-             ty = w1 * textState.fontSize + charSpacing;
 
-             height += ty;
 
-           }
 
-           textState.translateTextMatrix(tx, ty);
 
-           textChunk.str.push(glyphUnicode);
 
-         }
 
-         if (!font.vertical) {
 
-           textChunk.lastAdvanceWidth = width;
 
-           textChunk.width += width;
 
-         } else {
 
-           textChunk.lastAdvanceHeight = height;
 
-           textChunk.height += Math.abs(height);
 
-         }
 
-         return textChunk;
 
-       }
 
-       function addFakeSpaces(width, strBuf) {
 
-         if (width < textContentItem.fakeSpaceMin) {
 
-           return;
 
-         }
 
-         if (width < textContentItem.fakeMultiSpaceMin) {
 
-           strBuf.push(" ");
 
-           return;
 
-         }
 
-         var fakeSpaces = Math.round(width / textContentItem.spaceWidth);
 
-         while (fakeSpaces-- > 0) {
 
-           strBuf.push(" ");
 
-         }
 
-       }
 
-       function flushTextContentItem() {
 
-         if (!textContentItem.initialized) {
 
-           return;
 
-         }
 
-         if (!textContentItem.vertical) {
 
-           textContentItem.width *= textContentItem.textAdvanceScale;
 
-         } else {
 
-           textContentItem.height *= textContentItem.textAdvanceScale;
 
-         }
 
-         textContent.items.push(runBidiTransform(textContentItem));
 
-         textContentItem.initialized = false;
 
-         textContentItem.str.length = 0;
 
-       }
 
-       function enqueueChunk() {
 
-         const length = textContent.items.length;
 
-         if (length > 0) {
 
-           sink.enqueue(textContent, length);
 
-           textContent.items = [];
 
-           textContent.styles = Object.create(null);
 
-         }
 
-       }
 
-       var timeSlotManager = new TimeSlotManager();
 
-       return new Promise(function promiseBody(resolve, reject) {
 
-         const next = function (promise) {
 
-           enqueueChunk();
 
-           Promise.all([promise, sink.ready]).then(function () {
 
-             try {
 
-               promiseBody(resolve, reject);
 
-             } catch (ex) {
 
-               reject(ex);
 
-             }
 
-           }, reject);
 
-         };
 
-         task.ensureNotTerminated();
 
-         timeSlotManager.reset();
 
-         var stop,
 
-             operation = {},
 
-             args = [];
 
-         while (!(stop = timeSlotManager.check())) {
 
-           args.length = 0;
 
-           operation.args = args;
 
-           if (!preprocessor.read(operation)) {
 
-             break;
 
-           }
 
-           textState = stateManager.state;
 
-           var fn = operation.fn;
 
-           args = operation.args;
 
-           var advance, diff;
 
-           switch (fn | 0) {
 
-             case _util.OPS.setFont:
 
-               var fontNameArg = args[0].name,
 
-                   fontSizeArg = args[1];
 
-               if (textState.font && fontNameArg === textState.fontName && fontSizeArg === textState.fontSize) {
 
-                 break;
 
-               }
 
-               flushTextContentItem();
 
-               textState.fontName = fontNameArg;
 
-               textState.fontSize = fontSizeArg;
 
-               next(handleSetFont(fontNameArg, null));
 
-               return;
 
-             case _util.OPS.setTextRise:
 
-               flushTextContentItem();
 
-               textState.textRise = args[0];
 
-               break;
 
-             case _util.OPS.setHScale:
 
-               flushTextContentItem();
 
-               textState.textHScale = args[0] / 100;
 
-               break;
 
-             case _util.OPS.setLeading:
 
-               flushTextContentItem();
 
-               textState.leading = args[0];
 
-               break;
 
-             case _util.OPS.moveText:
 
-               var isSameTextLine = !textState.font ? false : (textState.font.vertical ? args[0] : args[1]) === 0;
 
-               advance = args[0] - args[1];
 
-               if (combineTextItems && isSameTextLine && textContentItem.initialized && advance > 0 && advance <= textContentItem.fakeMultiSpaceMax) {
 
-                 textState.translateTextLineMatrix(args[0], args[1]);
 
-                 textContentItem.width += args[0] - textContentItem.lastAdvanceWidth;
 
-                 textContentItem.height += args[1] - textContentItem.lastAdvanceHeight;
 
-                 diff = args[0] - textContentItem.lastAdvanceWidth - (args[1] - textContentItem.lastAdvanceHeight);
 
-                 addFakeSpaces(diff, textContentItem.str);
 
-                 break;
 
-               }
 
-               flushTextContentItem();
 
-               textState.translateTextLineMatrix(args[0], args[1]);
 
-               textState.textMatrix = textState.textLineMatrix.slice();
 
-               break;
 
-             case _util.OPS.setLeadingMoveText:
 
-               flushTextContentItem();
 
-               textState.leading = -args[1];
 
-               textState.translateTextLineMatrix(args[0], args[1]);
 
-               textState.textMatrix = textState.textLineMatrix.slice();
 
-               break;
 
-             case _util.OPS.nextLine:
 
-               flushTextContentItem();
 
-               textState.carriageReturn();
 
-               break;
 
-             case _util.OPS.setTextMatrix:
 
-               advance = textState.calcTextLineMatrixAdvance(args[0], args[1], args[2], args[3], args[4], args[5]);
 
-               if (combineTextItems && advance !== null && textContentItem.initialized && advance.value > 0 && advance.value <= textContentItem.fakeMultiSpaceMax) {
 
-                 textState.translateTextLineMatrix(advance.width, advance.height);
 
-                 textContentItem.width += advance.width - textContentItem.lastAdvanceWidth;
 
-                 textContentItem.height += advance.height - textContentItem.lastAdvanceHeight;
 
-                 diff = advance.width - textContentItem.lastAdvanceWidth - (advance.height - textContentItem.lastAdvanceHeight);
 
-                 addFakeSpaces(diff, textContentItem.str);
 
-                 break;
 
-               }
 
-               flushTextContentItem();
 
-               textState.setTextMatrix(args[0], args[1], args[2], args[3], args[4], args[5]);
 
-               textState.setTextLineMatrix(args[0], args[1], args[2], args[3], args[4], args[5]);
 
-               break;
 
-             case _util.OPS.setCharSpacing:
 
-               textState.charSpacing = args[0];
 
-               break;
 
-             case _util.OPS.setWordSpacing:
 
-               textState.wordSpacing = args[0];
 
-               break;
 
-             case _util.OPS.beginText:
 
-               flushTextContentItem();
 
-               textState.textMatrix = _util.IDENTITY_MATRIX.slice();
 
-               textState.textLineMatrix = _util.IDENTITY_MATRIX.slice();
 
-               break;
 
-             case _util.OPS.showSpacedText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               var items = args[0];
 
-               var offset;
 
-               for (var j = 0, jj = items.length; j < jj; j++) {
 
-                 if (typeof items[j] === "string") {
 
-                   buildTextContentItem(items[j]);
 
-                 } else if ((0, _util.isNum)(items[j])) {
 
-                   ensureTextContentItem();
 
-                   advance = items[j] * textState.fontSize / 1000;
 
-                   var breakTextRun = false;
 
-                   if (textState.font.vertical) {
 
-                     offset = advance;
 
-                     textState.translateTextMatrix(0, offset);
 
-                     breakTextRun = textContentItem.textRunBreakAllowed && advance > textContentItem.fakeMultiSpaceMax;
 
-                     if (!breakTextRun) {
 
-                       textContentItem.height += offset;
 
-                     }
 
-                   } else {
 
-                     advance = -advance;
 
-                     offset = advance * textState.textHScale;
 
-                     textState.translateTextMatrix(offset, 0);
 
-                     breakTextRun = textContentItem.textRunBreakAllowed && advance > textContentItem.fakeMultiSpaceMax;
 
-                     if (!breakTextRun) {
 
-                       textContentItem.width += offset;
 
-                     }
 
-                   }
 
-                   if (breakTextRun) {
 
-                     flushTextContentItem();
 
-                   } else if (advance > 0) {
 
-                     addFakeSpaces(advance, textContentItem.str);
 
-                   }
 
-                 }
 
-               }
 
-               break;
 
-             case _util.OPS.showText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               buildTextContentItem(args[0]);
 
-               break;
 
-             case _util.OPS.nextLineShowText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               flushTextContentItem();
 
-               textState.carriageReturn();
 
-               buildTextContentItem(args[0]);
 
-               break;
 
-             case _util.OPS.nextLineSetSpacingShowText:
 
-               if (!stateManager.state.font) {
 
-                 self.ensureStateFont(stateManager.state);
 
-                 continue;
 
-               }
 
-               flushTextContentItem();
 
-               textState.wordSpacing = args[0];
 
-               textState.charSpacing = args[1];
 
-               textState.carriageReturn();
 
-               buildTextContentItem(args[2]);
 
-               break;
 
-             case _util.OPS.paintXObject:
 
-               flushTextContentItem();
 
-               if (!xobjs) {
 
-                 xobjs = resources.get("XObject") || _primitives.Dict.empty;
 
-               }
 
-               var name = args[0].name;
 
-               if (name && skipEmptyXObjs[name] !== undefined) {
 
-                 break;
 
-               }
 
-               next(new Promise(function (resolveXObject, rejectXObject) {
 
-                 if (!name) {
 
-                   throw new _util.FormatError("XObject must be referred to by name.");
 
-                 }
 
-                 const xobj = xobjs.get(name);
 
-                 if (!xobj) {
 
-                   resolveXObject();
 
-                   return;
 
-                 }
 
-                 if (!(0, _primitives.isStream)(xobj)) {
 
-                   throw new _util.FormatError("XObject should be a stream");
 
-                 }
 
-                 const type = xobj.dict.get("Subtype");
 
-                 if (!(0, _primitives.isName)(type)) {
 
-                   throw new _util.FormatError("XObject should have a Name subtype");
 
-                 }
 
-                 if (type.name !== "Form") {
 
-                   skipEmptyXObjs[name] = true;
 
-                   resolveXObject();
 
-                   return;
 
-                 }
 
-                 const currentState = stateManager.state.clone();
 
-                 const xObjStateManager = new StateManager(currentState);
 
-                 const matrix = xobj.dict.getArray("Matrix");
 
-                 if (Array.isArray(matrix) && matrix.length === 6) {
 
-                   xObjStateManager.transform(matrix);
 
-                 }
 
-                 enqueueChunk();
 
-                 const sinkWrapper = {
 
-                   enqueueInvoked: false,
 
-                   enqueue(chunk, size) {
 
-                     this.enqueueInvoked = true;
 
-                     sink.enqueue(chunk, size);
 
-                   },
 
-                   get desiredSize() {
 
-                     return sink.desiredSize;
 
-                   },
 
-                   get ready() {
 
-                     return sink.ready;
 
-                   }
 
-                 };
 
-                 self.getTextContent({
 
-                   stream: xobj,
 
-                   task,
 
-                   resources: xobj.dict.get("Resources") || resources,
 
-                   stateManager: xObjStateManager,
 
-                   normalizeWhitespace,
 
-                   combineTextItems,
 
-                   sink: sinkWrapper,
 
-                   seenStyles
 
-                 }).then(function () {
 
-                   if (!sinkWrapper.enqueueInvoked) {
 
-                     skipEmptyXObjs[name] = true;
 
-                   }
 
-                   resolveXObject();
 
-                 }, rejectXObject);
 
-               }).catch(function (reason) {
 
-                 if (reason instanceof _util.AbortException) {
 
-                   return;
 
-                 }
 
-                 if (self.options.ignoreErrors) {
 
-                   (0, _util.warn)(`getTextContent - ignoring XObject: "${reason}".`);
 
-                   return;
 
-                 }
 
-                 throw reason;
 
-               }));
 
-               return;
 
-             case _util.OPS.setGState:
 
-               flushTextContentItem();
 
-               var dictName = args[0];
 
-               var extGState = resources.get("ExtGState");
 
-               if (!(0, _primitives.isDict)(extGState) || !(0, _primitives.isName)(dictName)) {
 
-                 break;
 
-               }
 
-               var gState = extGState.get(dictName.name);
 
-               if (!(0, _primitives.isDict)(gState)) {
 
-                 break;
 
-               }
 
-               var gStateFont = gState.get("Font");
 
-               if (gStateFont) {
 
-                 textState.fontName = null;
 
-                 textState.fontSize = gStateFont[1];
 
-                 next(handleSetFont(null, gStateFont[0]));
 
-                 return;
 
-               }
 
-               break;
 
-           }
 
-           if (textContent.items.length >= sink.desiredSize) {
 
-             stop = true;
 
-             break;
 
-           }
 
-         }
 
-         if (stop) {
 
-           next(deferred);
 
-           return;
 
-         }
 
-         flushTextContentItem();
 
-         enqueueChunk();
 
-         resolve();
 
-       }).catch(reason => {
 
-         if (reason instanceof _util.AbortException) {
 
-           return;
 
-         }
 
-         if (this.options.ignoreErrors) {
 
-           (0, _util.warn)(`getTextContent - ignoring errors during "${task.name}" ` + `task: "${reason}".`);
 
-           flushTextContentItem();
 
-           enqueueChunk();
 
-           return;
 
-         }
 
-         throw reason;
 
-       });
 
-     },
 
-     extractDataStructures: function PartialEvaluator_extractDataStructures(dict, baseDict, properties) {
 
-       const xref = this.xref;
 
-       let cidToGidBytes;
 
-       var toUnicode = dict.get("ToUnicode") || baseDict.get("ToUnicode");
 
-       var toUnicodePromise = toUnicode ? this.readToUnicode(toUnicode) : Promise.resolve(undefined);
 
-       if (properties.composite) {
 
-         var cidSystemInfo = dict.get("CIDSystemInfo");
 
-         if ((0, _primitives.isDict)(cidSystemInfo)) {
 
-           properties.cidSystemInfo = {
 
-             registry: (0, _util.stringToPDFString)(cidSystemInfo.get("Registry")),
 
-             ordering: (0, _util.stringToPDFString)(cidSystemInfo.get("Ordering")),
 
-             supplement: cidSystemInfo.get("Supplement")
 
-           };
 
-         }
 
-         var cidToGidMap = dict.get("CIDToGIDMap");
 
-         if ((0, _primitives.isStream)(cidToGidMap)) {
 
-           cidToGidBytes = cidToGidMap.getBytes();
 
-         }
 
-       }
 
-       var differences = [];
 
-       var baseEncodingName = null;
 
-       var encoding;
 
-       if (dict.has("Encoding")) {
 
-         encoding = dict.get("Encoding");
 
-         if ((0, _primitives.isDict)(encoding)) {
 
-           baseEncodingName = encoding.get("BaseEncoding");
 
-           baseEncodingName = (0, _primitives.isName)(baseEncodingName) ? baseEncodingName.name : null;
 
-           if (encoding.has("Differences")) {
 
-             var diffEncoding = encoding.get("Differences");
 
-             var index = 0;
 
-             for (var j = 0, jj = diffEncoding.length; j < jj; j++) {
 
-               var data = xref.fetchIfRef(diffEncoding[j]);
 
-               if ((0, _util.isNum)(data)) {
 
-                 index = data;
 
-               } else if ((0, _primitives.isName)(data)) {
 
-                 differences[index++] = data.name;
 
-               } else {
 
-                 throw new _util.FormatError(`Invalid entry in 'Differences' array: ${data}`);
 
-               }
 
-             }
 
-           }
 
-         } else if ((0, _primitives.isName)(encoding)) {
 
-           baseEncodingName = encoding.name;
 
-         } else {
 
-           throw new _util.FormatError("Encoding is not a Name nor a Dict");
 
-         }
 
-         if (baseEncodingName !== "MacRomanEncoding" && baseEncodingName !== "MacExpertEncoding" && baseEncodingName !== "WinAnsiEncoding") {
 
-           baseEncodingName = null;
 
-         }
 
-       }
 
-       if (baseEncodingName) {
 
-         properties.defaultEncoding = (0, _encodings.getEncoding)(baseEncodingName).slice();
 
-       } else {
 
-         var isSymbolicFont = !!(properties.flags & _fonts.FontFlags.Symbolic);
 
-         var isNonsymbolicFont = !!(properties.flags & _fonts.FontFlags.Nonsymbolic);
 
-         encoding = _encodings.StandardEncoding;
 
-         if (properties.type === "TrueType" && !isNonsymbolicFont) {
 
-           encoding = _encodings.WinAnsiEncoding;
 
-         }
 
-         if (isSymbolicFont) {
 
-           encoding = _encodings.MacRomanEncoding;
 
-           if (!properties.file) {
 
-             if (/Symbol/i.test(properties.name)) {
 
-               encoding = _encodings.SymbolSetEncoding;
 
-             } else if (/Dingbats|Wingdings/i.test(properties.name)) {
 
-               encoding = _encodings.ZapfDingbatsEncoding;
 
-             }
 
-           }
 
-         }
 
-         properties.defaultEncoding = encoding;
 
-       }
 
-       properties.differences = differences;
 
-       properties.baseEncodingName = baseEncodingName;
 
-       properties.hasEncoding = !!baseEncodingName || differences.length > 0;
 
-       properties.dict = dict;
 
-       return toUnicodePromise.then(toUnicode => {
 
-         properties.toUnicode = toUnicode;
 
-         return this.buildToUnicode(properties);
 
-       }).then(toUnicode => {
 
-         properties.toUnicode = toUnicode;
 
-         if (cidToGidBytes) {
 
-           properties.cidToGidMap = this.readCidToGidMap(cidToGidBytes, toUnicode);
 
-         }
 
-         return properties;
 
-       });
 
-     },
 
-     _buildSimpleFontToUnicode(properties, forceGlyphs = false) {
 
-       (0, _util.assert)(!properties.composite, "Must be a simple font.");
 
-       const toUnicode = [];
 
-       const encoding = properties.defaultEncoding.slice();
 
-       const baseEncodingName = properties.baseEncodingName;
 
-       const differences = properties.differences;
 
-       for (const charcode in differences) {
 
-         const glyphName = differences[charcode];
 
-         if (glyphName === ".notdef") {
 
-           continue;
 
-         }
 
-         encoding[charcode] = glyphName;
 
-       }
 
-       const glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-       for (const charcode in encoding) {
 
-         let glyphName = encoding[charcode];
 
-         if (glyphName === "") {
 
-           continue;
 
-         } else if (glyphsUnicodeMap[glyphName] === undefined) {
 
-           let code = 0;
 
-           switch (glyphName[0]) {
 
-             case "G":
 
-               if (glyphName.length === 3) {
 
-                 code = parseInt(glyphName.substring(1), 16);
 
-               }
 
-               break;
 
-             case "g":
 
-               if (glyphName.length === 5) {
 
-                 code = parseInt(glyphName.substring(1), 16);
 
-               }
 
-               break;
 
-             case "C":
 
-             case "c":
 
-               if (glyphName.length >= 3 && glyphName.length <= 4) {
 
-                 const codeStr = glyphName.substring(1);
 
-                 if (forceGlyphs) {
 
-                   code = parseInt(codeStr, 16);
 
-                   break;
 
-                 }
 
-                 code = +codeStr;
 
-                 if (Number.isNaN(code) && Number.isInteger(parseInt(codeStr, 16))) {
 
-                   return this._buildSimpleFontToUnicode(properties, true);
 
-                 }
 
-               }
 
-               break;
 
-             default:
 
-               const unicode = (0, _unicode.getUnicodeForGlyph)(glyphName, glyphsUnicodeMap);
 
-               if (unicode !== -1) {
 
-                 code = unicode;
 
-               }
 
-           }
 
-           if (code > 0 && Number.isInteger(code)) {
 
-             if (baseEncodingName && code === +charcode) {
 
-               const baseEncoding = (0, _encodings.getEncoding)(baseEncodingName);
 
-               if (baseEncoding && (glyphName = baseEncoding[charcode])) {
 
-                 toUnicode[charcode] = String.fromCharCode(glyphsUnicodeMap[glyphName]);
 
-                 continue;
 
-               }
 
-             }
 
-             toUnicode[charcode] = String.fromCodePoint(code);
 
-           }
 
-           continue;
 
-         }
 
-         toUnicode[charcode] = String.fromCharCode(glyphsUnicodeMap[glyphName]);
 
-       }
 
-       return new _fonts.ToUnicodeMap(toUnicode);
 
-     },
 
-     buildToUnicode(properties) {
 
-       properties.hasIncludedToUnicodeMap = !!properties.toUnicode && properties.toUnicode.length > 0;
 
-       if (properties.hasIncludedToUnicodeMap) {
 
-         if (!properties.composite && properties.hasEncoding) {
 
-           properties.fallbackToUnicode = this._buildSimpleFontToUnicode(properties);
 
-         }
 
-         return Promise.resolve(properties.toUnicode);
 
-       }
 
-       if (!properties.composite) {
 
-         return Promise.resolve(this._buildSimpleFontToUnicode(properties));
 
-       }
 
-       if (properties.composite && (properties.cMap.builtInCMap && !(properties.cMap instanceof _cmap.IdentityCMap) || properties.cidSystemInfo.registry === "Adobe" && (properties.cidSystemInfo.ordering === "GB1" || properties.cidSystemInfo.ordering === "CNS1" || properties.cidSystemInfo.ordering === "Japan1" || properties.cidSystemInfo.ordering === "Korea1"))) {
 
-         const registry = properties.cidSystemInfo.registry;
 
-         const ordering = properties.cidSystemInfo.ordering;
 
-         const ucs2CMapName = _primitives.Name.get(registry + "-" + ordering + "-UCS2");
 
-         return _cmap.CMapFactory.create({
 
-           encoding: ucs2CMapName,
 
-           fetchBuiltInCMap: this.fetchBuiltInCMap,
 
-           useCMap: null
 
-         }).then(function (ucs2CMap) {
 
-           const cMap = properties.cMap;
 
-           const toUnicode = [];
 
-           cMap.forEach(function (charcode, cid) {
 
-             if (cid > 0xffff) {
 
-               throw new _util.FormatError("Max size of CID is 65,535");
 
-             }
 
-             const ucs2 = ucs2CMap.lookup(cid);
 
-             if (ucs2) {
 
-               toUnicode[charcode] = String.fromCharCode((ucs2.charCodeAt(0) << 8) + ucs2.charCodeAt(1));
 
-             }
 
-           });
 
-           return new _fonts.ToUnicodeMap(toUnicode);
 
-         });
 
-       }
 
-       return Promise.resolve(new _fonts.IdentityToUnicodeMap(properties.firstChar, properties.lastChar));
 
-     },
 
-     readToUnicode: function PartialEvaluator_readToUnicode(toUnicode) {
 
-       var cmapObj = toUnicode;
 
-       if ((0, _primitives.isName)(cmapObj)) {
 
-         return _cmap.CMapFactory.create({
 
-           encoding: cmapObj,
 
-           fetchBuiltInCMap: this.fetchBuiltInCMap,
 
-           useCMap: null
 
-         }).then(function (cmap) {
 
-           if (cmap instanceof _cmap.IdentityCMap) {
 
-             return new _fonts.IdentityToUnicodeMap(0, 0xffff);
 
-           }
 
-           return new _fonts.ToUnicodeMap(cmap.getMap());
 
-         });
 
-       } else if ((0, _primitives.isStream)(cmapObj)) {
 
-         return _cmap.CMapFactory.create({
 
-           encoding: cmapObj,
 
-           fetchBuiltInCMap: this.fetchBuiltInCMap,
 
-           useCMap: null
 
-         }).then(function (cmap) {
 
-           if (cmap instanceof _cmap.IdentityCMap) {
 
-             return new _fonts.IdentityToUnicodeMap(0, 0xffff);
 
-           }
 
-           var map = new Array(cmap.length);
 
-           cmap.forEach(function (charCode, token) {
 
-             var str = [];
 
-             for (var k = 0; k < token.length; k += 2) {
 
-               var w1 = token.charCodeAt(k) << 8 | token.charCodeAt(k + 1);
 
-               if ((w1 & 0xf800) !== 0xd800) {
 
-                 str.push(w1);
 
-                 continue;
 
-               }
 
-               k += 2;
 
-               var w2 = token.charCodeAt(k) << 8 | token.charCodeAt(k + 1);
 
-               str.push(((w1 & 0x3ff) << 10) + (w2 & 0x3ff) + 0x10000);
 
-             }
 
-             map[charCode] = String.fromCodePoint.apply(String, str);
 
-           });
 
-           return new _fonts.ToUnicodeMap(map);
 
-         }, reason => {
 
-           if (reason instanceof _util.AbortException) {
 
-             return null;
 
-           }
 
-           if (this.options.ignoreErrors) {
 
-             this.handler.send("UnsupportedFeature", {
 
-               featureId: _util.UNSUPPORTED_FEATURES.font
 
-             });
 
-             (0, _util.warn)(`readToUnicode - ignoring ToUnicode data: "${reason}".`);
 
-             return null;
 
-           }
 
-           throw reason;
 
-         });
 
-       }
 
-       return Promise.resolve(null);
 
-     },
 
-     readCidToGidMap(glyphsData, toUnicode) {
 
-       var result = [];
 
-       for (var j = 0, jj = glyphsData.length; j < jj; j++) {
 
-         var glyphID = glyphsData[j++] << 8 | glyphsData[j];
 
-         const code = j >> 1;
 
-         if (glyphID === 0 && !toUnicode.has(code)) {
 
-           continue;
 
-         }
 
-         result[code] = glyphID;
 
-       }
 
-       return result;
 
-     },
 
-     extractWidths: function PartialEvaluator_extractWidths(dict, descriptor, properties) {
 
-       var xref = this.xref;
 
-       var glyphsWidths = [];
 
-       var defaultWidth = 0;
 
-       var glyphsVMetrics = [];
 
-       var defaultVMetrics;
 
-       var i, ii, j, jj, start, code, widths;
 
-       if (properties.composite) {
 
-         defaultWidth = dict.has("DW") ? dict.get("DW") : 1000;
 
-         widths = dict.get("W");
 
-         if (widths) {
 
-           for (i = 0, ii = widths.length; i < ii; i++) {
 
-             start = xref.fetchIfRef(widths[i++]);
 
-             code = xref.fetchIfRef(widths[i]);
 
-             if (Array.isArray(code)) {
 
-               for (j = 0, jj = code.length; j < jj; j++) {
 
-                 glyphsWidths[start++] = xref.fetchIfRef(code[j]);
 
-               }
 
-             } else {
 
-               var width = xref.fetchIfRef(widths[++i]);
 
-               for (j = start; j <= code; j++) {
 
-                 glyphsWidths[j] = width;
 
-               }
 
-             }
 
-           }
 
-         }
 
-         if (properties.vertical) {
 
-           var vmetrics = dict.getArray("DW2") || [880, -1000];
 
-           defaultVMetrics = [vmetrics[1], defaultWidth * 0.5, vmetrics[0]];
 
-           vmetrics = dict.get("W2");
 
-           if (vmetrics) {
 
-             for (i = 0, ii = vmetrics.length; i < ii; i++) {
 
-               start = xref.fetchIfRef(vmetrics[i++]);
 
-               code = xref.fetchIfRef(vmetrics[i]);
 
-               if (Array.isArray(code)) {
 
-                 for (j = 0, jj = code.length; j < jj; j++) {
 
-                   glyphsVMetrics[start++] = [xref.fetchIfRef(code[j++]), xref.fetchIfRef(code[j++]), xref.fetchIfRef(code[j])];
 
-                 }
 
-               } else {
 
-                 var vmetric = [xref.fetchIfRef(vmetrics[++i]), xref.fetchIfRef(vmetrics[++i]), xref.fetchIfRef(vmetrics[++i])];
 
-                 for (j = start; j <= code; j++) {
 
-                   glyphsVMetrics[j] = vmetric;
 
-                 }
 
-               }
 
-             }
 
-           }
 
-         }
 
-       } else {
 
-         var firstChar = properties.firstChar;
 
-         widths = dict.get("Widths");
 
-         if (widths) {
 
-           j = firstChar;
 
-           for (i = 0, ii = widths.length; i < ii; i++) {
 
-             glyphsWidths[j++] = xref.fetchIfRef(widths[i]);
 
-           }
 
-           defaultWidth = parseFloat(descriptor.get("MissingWidth")) || 0;
 
-         } else {
 
-           var baseFontName = dict.get("BaseFont");
 
-           if ((0, _primitives.isName)(baseFontName)) {
 
-             var metrics = this.getBaseFontMetrics(baseFontName.name);
 
-             glyphsWidths = this.buildCharCodeToWidth(metrics.widths, properties);
 
-             defaultWidth = metrics.defaultWidth;
 
-           }
 
-         }
 
-       }
 
-       var isMonospace = true;
 
-       var firstWidth = defaultWidth;
 
-       for (var glyph in glyphsWidths) {
 
-         var glyphWidth = glyphsWidths[glyph];
 
-         if (!glyphWidth) {
 
-           continue;
 
-         }
 
-         if (!firstWidth) {
 
-           firstWidth = glyphWidth;
 
-           continue;
 
-         }
 
-         if (firstWidth !== glyphWidth) {
 
-           isMonospace = false;
 
-           break;
 
-         }
 
-       }
 
-       if (isMonospace) {
 
-         properties.flags |= _fonts.FontFlags.FixedPitch;
 
-       }
 
-       properties.defaultWidth = defaultWidth;
 
-       properties.widths = glyphsWidths;
 
-       properties.defaultVMetrics = defaultVMetrics;
 
-       properties.vmetrics = glyphsVMetrics;
 
-     },
 
-     isSerifFont: function PartialEvaluator_isSerifFont(baseFontName) {
 
-       var fontNameWoStyle = baseFontName.split("-")[0];
 
-       return fontNameWoStyle in (0, _standard_fonts.getSerifFonts)() || fontNameWoStyle.search(/serif/gi) !== -1;
 
-     },
 
-     getBaseFontMetrics: function PartialEvaluator_getBaseFontMetrics(name) {
 
-       var defaultWidth = 0;
 
-       var widths = [];
 
-       var monospace = false;
 
-       var stdFontMap = (0, _standard_fonts.getStdFontMap)();
 
-       var lookupName = stdFontMap[name] || name;
 
-       var Metrics = (0, _metrics.getMetrics)();
 
-       if (!(lookupName in Metrics)) {
 
-         if (this.isSerifFont(name)) {
 
-           lookupName = "Times-Roman";
 
-         } else {
 
-           lookupName = "Helvetica";
 
-         }
 
-       }
 
-       var glyphWidths = Metrics[lookupName];
 
-       if ((0, _util.isNum)(glyphWidths)) {
 
-         defaultWidth = glyphWidths;
 
-         monospace = true;
 
-       } else {
 
-         widths = glyphWidths();
 
-       }
 
-       return {
 
-         defaultWidth,
 
-         monospace,
 
-         widths
 
-       };
 
-     },
 
-     buildCharCodeToWidth: function PartialEvaluator_bulildCharCodeToWidth(widthsByGlyphName, properties) {
 
-       var widths = Object.create(null);
 
-       var differences = properties.differences;
 
-       var encoding = properties.defaultEncoding;
 
-       for (var charCode = 0; charCode < 256; charCode++) {
 
-         if (charCode in differences && widthsByGlyphName[differences[charCode]]) {
 
-           widths[charCode] = widthsByGlyphName[differences[charCode]];
 
-           continue;
 
-         }
 
-         if (charCode in encoding && widthsByGlyphName[encoding[charCode]]) {
 
-           widths[charCode] = widthsByGlyphName[encoding[charCode]];
 
-           continue;
 
-         }
 
-       }
 
-       return widths;
 
-     },
 
-     preEvaluateFont: function PartialEvaluator_preEvaluateFont(dict) {
 
-       var baseDict = dict;
 
-       var type = dict.get("Subtype");
 
-       if (!(0, _primitives.isName)(type)) {
 
-         throw new _util.FormatError("invalid font Subtype");
 
-       }
 
-       var composite = false;
 
-       var uint8array;
 
-       if (type.name === "Type0") {
 
-         var df = dict.get("DescendantFonts");
 
-         if (!df) {
 
-           throw new _util.FormatError("Descendant fonts are not specified");
 
-         }
 
-         dict = Array.isArray(df) ? this.xref.fetchIfRef(df[0]) : df;
 
-         type = dict.get("Subtype");
 
-         if (!(0, _primitives.isName)(type)) {
 
-           throw new _util.FormatError("invalid font Subtype");
 
-         }
 
-         composite = true;
 
-       }
 
-       var descriptor = dict.get("FontDescriptor");
 
-       if (descriptor) {
 
-         var hash = new _murmurhash.MurmurHash3_64();
 
-         var encoding = baseDict.getRaw("Encoding");
 
-         if ((0, _primitives.isName)(encoding)) {
 
-           hash.update(encoding.name);
 
-         } else if ((0, _primitives.isRef)(encoding)) {
 
-           hash.update(encoding.toString());
 
-         } else if ((0, _primitives.isDict)(encoding)) {
 
-           var keys = encoding.getKeys();
 
-           for (var i = 0, ii = keys.length; i < ii; i++) {
 
-             var entry = encoding.getRaw(keys[i]);
 
-             if ((0, _primitives.isName)(entry)) {
 
-               hash.update(entry.name);
 
-             } else if ((0, _primitives.isRef)(entry)) {
 
-               hash.update(entry.toString());
 
-             } else if (Array.isArray(entry)) {
 
-               var diffLength = entry.length,
 
-                   diffBuf = new Array(diffLength);
 
-               for (var j = 0; j < diffLength; j++) {
 
-                 var diffEntry = entry[j];
 
-                 if ((0, _primitives.isName)(diffEntry)) {
 
-                   diffBuf[j] = diffEntry.name;
 
-                 } else if ((0, _util.isNum)(diffEntry) || (0, _primitives.isRef)(diffEntry)) {
 
-                   diffBuf[j] = diffEntry.toString();
 
-                 }
 
-               }
 
-               hash.update(diffBuf.join());
 
-             }
 
-           }
 
-         }
 
-         const firstChar = dict.get("FirstChar") || 0;
 
-         const lastChar = dict.get("LastChar") || (composite ? 0xffff : 0xff);
 
-         hash.update(`${firstChar}-${lastChar}`);
 
-         var toUnicode = dict.get("ToUnicode") || baseDict.get("ToUnicode");
 
-         if ((0, _primitives.isStream)(toUnicode)) {
 
-           var stream = toUnicode.str || toUnicode;
 
-           uint8array = stream.buffer ? new Uint8Array(stream.buffer.buffer, 0, stream.bufferLength) : new Uint8Array(stream.bytes.buffer, stream.start, stream.end - stream.start);
 
-           hash.update(uint8array);
 
-         } else if ((0, _primitives.isName)(toUnicode)) {
 
-           hash.update(toUnicode.name);
 
-         }
 
-         var widths = dict.get("Widths") || baseDict.get("Widths");
 
-         if (widths) {
 
-           uint8array = new Uint8Array(new Uint32Array(widths).buffer);
 
-           hash.update(uint8array);
 
-         }
 
-       }
 
-       return {
 
-         descriptor,
 
-         dict,
 
-         baseDict,
 
-         composite,
 
-         type: type.name,
 
-         hash: hash ? hash.hexdigest() : ""
 
-       };
 
-     },
 
-     translateFont: function PartialEvaluator_translateFont(preEvaluatedFont) {
 
-       var baseDict = preEvaluatedFont.baseDict;
 
-       var dict = preEvaluatedFont.dict;
 
-       var composite = preEvaluatedFont.composite;
 
-       var descriptor = preEvaluatedFont.descriptor;
 
-       var type = preEvaluatedFont.type;
 
-       var maxCharIndex = composite ? 0xffff : 0xff;
 
-       var properties;
 
-       const firstChar = dict.get("FirstChar") || 0;
 
-       const lastChar = dict.get("LastChar") || maxCharIndex;
 
-       if (!descriptor) {
 
-         if (type === "Type3") {
 
-           descriptor = new _primitives.Dict(null);
 
-           descriptor.set("FontName", _primitives.Name.get(type));
 
-           descriptor.set("FontBBox", dict.getArray("FontBBox") || [0, 0, 0, 0]);
 
-         } else {
 
-           var baseFontName = dict.get("BaseFont");
 
-           if (!(0, _primitives.isName)(baseFontName)) {
 
-             throw new _util.FormatError("Base font is not specified");
 
-           }
 
-           baseFontName = baseFontName.name.replace(/[,_]/g, "-");
 
-           var metrics = this.getBaseFontMetrics(baseFontName);
 
-           var fontNameWoStyle = baseFontName.split("-")[0];
 
-           var flags = (this.isSerifFont(fontNameWoStyle) ? _fonts.FontFlags.Serif : 0) | (metrics.monospace ? _fonts.FontFlags.FixedPitch : 0) | ((0, _standard_fonts.getSymbolsFonts)()[fontNameWoStyle] ? _fonts.FontFlags.Symbolic : _fonts.FontFlags.Nonsymbolic);
 
-           properties = {
 
-             type,
 
-             name: baseFontName,
 
-             widths: metrics.widths,
 
-             defaultWidth: metrics.defaultWidth,
 
-             flags,
 
-             firstChar,
 
-             lastChar
 
-           };
 
-           const widths = dict.get("Widths");
 
-           return this.extractDataStructures(dict, dict, properties).then(properties => {
 
-             if (widths) {
 
-               const glyphWidths = [];
 
-               let j = firstChar;
 
-               for (let i = 0, ii = widths.length; i < ii; i++) {
 
-                 glyphWidths[j++] = this.xref.fetchIfRef(widths[i]);
 
-               }
 
-               properties.widths = glyphWidths;
 
-             } else {
 
-               properties.widths = this.buildCharCodeToWidth(metrics.widths, properties);
 
-             }
 
-             return new _fonts.Font(baseFontName, null, properties);
 
-           });
 
-         }
 
-       }
 
-       var fontName = descriptor.get("FontName");
 
-       var baseFont = dict.get("BaseFont");
 
-       if ((0, _util.isString)(fontName)) {
 
-         fontName = _primitives.Name.get(fontName);
 
-       }
 
-       if ((0, _util.isString)(baseFont)) {
 
-         baseFont = _primitives.Name.get(baseFont);
 
-       }
 
-       if (type !== "Type3") {
 
-         var fontNameStr = fontName && fontName.name;
 
-         var baseFontStr = baseFont && baseFont.name;
 
-         if (fontNameStr !== baseFontStr) {
 
-           (0, _util.info)(`The FontDescriptor\'s FontName is "${fontNameStr}" but ` + `should be the same as the Font\'s BaseFont "${baseFontStr}".`);
 
-           if (fontNameStr && baseFontStr && baseFontStr.startsWith(fontNameStr)) {
 
-             fontName = baseFont;
 
-           }
 
-         }
 
-       }
 
-       fontName = fontName || baseFont;
 
-       if (!(0, _primitives.isName)(fontName)) {
 
-         throw new _util.FormatError("invalid font name");
 
-       }
 
-       var fontFile = descriptor.get("FontFile", "FontFile2", "FontFile3");
 
-       if (fontFile) {
 
-         if (fontFile.dict) {
 
-           var subtype = fontFile.dict.get("Subtype");
 
-           if (subtype) {
 
-             subtype = subtype.name;
 
-           }
 
-           var length1 = fontFile.dict.get("Length1");
 
-           var length2 = fontFile.dict.get("Length2");
 
-           var length3 = fontFile.dict.get("Length3");
 
-         }
 
-       }
 
-       properties = {
 
-         type,
 
-         name: fontName.name,
 
-         subtype,
 
-         file: fontFile,
 
-         length1,
 
-         length2,
 
-         length3,
 
-         loadedName: baseDict.loadedName,
 
-         composite,
 
-         wideChars: composite,
 
-         fixedPitch: false,
 
-         fontMatrix: dict.getArray("FontMatrix") || _util.FONT_IDENTITY_MATRIX,
 
-         firstChar: firstChar || 0,
 
-         lastChar: lastChar || maxCharIndex,
 
-         bbox: descriptor.getArray("FontBBox"),
 
-         ascent: descriptor.get("Ascent"),
 
-         descent: descriptor.get("Descent"),
 
-         xHeight: descriptor.get("XHeight"),
 
-         capHeight: descriptor.get("CapHeight"),
 
-         flags: descriptor.get("Flags"),
 
-         italicAngle: descriptor.get("ItalicAngle"),
 
-         isType3Font: false
 
-       };
 
-       var cMapPromise;
 
-       if (composite) {
 
-         var cidEncoding = baseDict.get("Encoding");
 
-         if ((0, _primitives.isName)(cidEncoding)) {
 
-           properties.cidEncoding = cidEncoding.name;
 
-         }
 
-         cMapPromise = _cmap.CMapFactory.create({
 
-           encoding: cidEncoding,
 
-           fetchBuiltInCMap: this.fetchBuiltInCMap,
 
-           useCMap: null
 
-         }).then(function (cMap) {
 
-           properties.cMap = cMap;
 
-           properties.vertical = properties.cMap.vertical;
 
-         });
 
-       } else {
 
-         cMapPromise = Promise.resolve(undefined);
 
-       }
 
-       return cMapPromise.then(() => {
 
-         return this.extractDataStructures(dict, baseDict, properties);
 
-       }).then(properties => {
 
-         this.extractWidths(dict, descriptor, properties);
 
-         if (type === "Type3") {
 
-           properties.isType3Font = true;
 
-         }
 
-         return new _fonts.Font(fontName.name, fontFile, properties);
 
-       });
 
-     }
 
-   };
 
-   PartialEvaluator.buildFontPaths = function (font, glyphs, handler) {
 
-     function buildPath(fontChar) {
 
-       if (font.renderer.hasBuiltPath(fontChar)) {
 
-         return;
 
-       }
 
-       handler.send("commonobj", [`${font.loadedName}_path_${fontChar}`, "FontPath", font.renderer.getPathJs(fontChar)]);
 
-     }
 
-     for (const glyph of glyphs) {
 
-       buildPath(glyph.fontChar);
 
-       const accent = glyph.accent;
 
-       if (accent && accent.fontChar) {
 
-         buildPath(accent.fontChar);
 
-       }
 
-     }
 
-   };
 
-   PartialEvaluator.getFallbackFontDict = function () {
 
-     if (this._fallbackFontDict) {
 
-       return this._fallbackFontDict;
 
-     }
 
-     const dict = new _primitives.Dict();
 
-     dict.set("BaseFont", _primitives.Name.get("PDFJS-FallbackFont"));
 
-     dict.set("Type", _primitives.Name.get("FallbackType"));
 
-     dict.set("Subtype", _primitives.Name.get("FallbackType"));
 
-     dict.set("Encoding", _primitives.Name.get("WinAnsiEncoding"));
 
-     return this._fallbackFontDict = dict;
 
-   };
 
-   return PartialEvaluator;
 
- }();
 
- exports.PartialEvaluator = PartialEvaluator;
 
- var TranslatedFont = function TranslatedFontClosure() {
 
-   function TranslatedFont(loadedName, font, dict) {
 
-     this.loadedName = loadedName;
 
-     this.font = font;
 
-     this.dict = dict;
 
-     this.type3Loaded = null;
 
-     this.sent = false;
 
-   }
 
-   TranslatedFont.prototype = {
 
-     send(handler) {
 
-       if (this.sent) {
 
-         return;
 
-       }
 
-       this.sent = true;
 
-       handler.send("commonobj", [this.loadedName, "Font", this.font.exportData()]);
 
-     },
 
-     fallback(handler) {
 
-       if (!this.font.data) {
 
-         return;
 
-       }
 
-       this.font.disableFontFace = true;
 
-       const glyphs = this.font.glyphCacheValues;
 
-       PartialEvaluator.buildFontPaths(this.font, glyphs, handler);
 
-     },
 
-     loadType3Data(evaluator, resources, parentOperatorList, task) {
 
-       if (!this.font.isType3Font) {
 
-         throw new Error("Must be a Type3 font.");
 
-       }
 
-       if (this.type3Loaded) {
 
-         return this.type3Loaded;
 
-       }
 
-       var type3Options = Object.create(evaluator.options);
 
-       type3Options.ignoreErrors = false;
 
-       type3Options.nativeImageDecoderSupport = _util.NativeImageDecoding.NONE;
 
-       var type3Evaluator = evaluator.clone(type3Options);
 
-       type3Evaluator.parsingType3Font = true;
 
-       var translatedFont = this.font;
 
-       var loadCharProcsPromise = Promise.resolve();
 
-       var charProcs = this.dict.get("CharProcs");
 
-       var fontResources = this.dict.get("Resources") || resources;
 
-       var charProcKeys = charProcs.getKeys();
 
-       var charProcOperatorList = Object.create(null);
 
-       for (var i = 0, n = charProcKeys.length; i < n; ++i) {
 
-         const key = charProcKeys[i];
 
-         loadCharProcsPromise = loadCharProcsPromise.then(function () {
 
-           var glyphStream = charProcs.get(key);
 
-           var operatorList = new _operator_list.OperatorList();
 
-           return type3Evaluator.getOperatorList({
 
-             stream: glyphStream,
 
-             task,
 
-             resources: fontResources,
 
-             operatorList
 
-           }).then(function () {
 
-             charProcOperatorList[key] = operatorList.getIR();
 
-             parentOperatorList.addDependencies(operatorList.dependencies);
 
-           }).catch(function (reason) {
 
-             (0, _util.warn)(`Type3 font resource "${key}" is not available.`);
 
-             var operatorList = new _operator_list.OperatorList();
 
-             charProcOperatorList[key] = operatorList.getIR();
 
-           });
 
-         });
 
-       }
 
-       this.type3Loaded = loadCharProcsPromise.then(function () {
 
-         translatedFont.charProcOperatorList = charProcOperatorList;
 
-       });
 
-       return this.type3Loaded;
 
-     }
 
-   };
 
-   return TranslatedFont;
 
- }();
 
- var StateManager = function StateManagerClosure() {
 
-   function StateManager(initialState) {
 
-     this.state = initialState;
 
-     this.stateStack = [];
 
-   }
 
-   StateManager.prototype = {
 
-     save() {
 
-       var old = this.state;
 
-       this.stateStack.push(this.state);
 
-       this.state = old.clone();
 
-     },
 
-     restore() {
 
-       var prev = this.stateStack.pop();
 
-       if (prev) {
 
-         this.state = prev;
 
-       }
 
-     },
 
-     transform(args) {
 
-       this.state.ctm = _util.Util.transform(this.state.ctm, args);
 
-     }
 
-   };
 
-   return StateManager;
 
- }();
 
- var TextState = function TextStateClosure() {
 
-   function TextState() {
 
-     this.ctm = new Float32Array(_util.IDENTITY_MATRIX);
 
-     this.fontName = null;
 
-     this.fontSize = 0;
 
-     this.font = null;
 
-     this.fontMatrix = _util.FONT_IDENTITY_MATRIX;
 
-     this.textMatrix = _util.IDENTITY_MATRIX.slice();
 
-     this.textLineMatrix = _util.IDENTITY_MATRIX.slice();
 
-     this.charSpacing = 0;
 
-     this.wordSpacing = 0;
 
-     this.leading = 0;
 
-     this.textHScale = 1;
 
-     this.textRise = 0;
 
-   }
 
-   TextState.prototype = {
 
-     setTextMatrix: function TextState_setTextMatrix(a, b, c, d, e, f) {
 
-       var m = this.textMatrix;
 
-       m[0] = a;
 
-       m[1] = b;
 
-       m[2] = c;
 
-       m[3] = d;
 
-       m[4] = e;
 
-       m[5] = f;
 
-     },
 
-     setTextLineMatrix: function TextState_setTextMatrix(a, b, c, d, e, f) {
 
-       var m = this.textLineMatrix;
 
-       m[0] = a;
 
-       m[1] = b;
 
-       m[2] = c;
 
-       m[3] = d;
 
-       m[4] = e;
 
-       m[5] = f;
 
-     },
 
-     translateTextMatrix: function TextState_translateTextMatrix(x, y) {
 
-       var m = this.textMatrix;
 
-       m[4] = m[0] * x + m[2] * y + m[4];
 
-       m[5] = m[1] * x + m[3] * y + m[5];
 
-     },
 
-     translateTextLineMatrix: function TextState_translateTextMatrix(x, y) {
 
-       var m = this.textLineMatrix;
 
-       m[4] = m[0] * x + m[2] * y + m[4];
 
-       m[5] = m[1] * x + m[3] * y + m[5];
 
-     },
 
-     calcTextLineMatrixAdvance: function TextState_calcTextLineMatrixAdvance(a, b, c, d, e, f) {
 
-       var font = this.font;
 
-       if (!font) {
 
-         return null;
 
-       }
 
-       var m = this.textLineMatrix;
 
-       if (!(a === m[0] && b === m[1] && c === m[2] && d === m[3])) {
 
-         return null;
 
-       }
 
-       var txDiff = e - m[4],
 
-           tyDiff = f - m[5];
 
-       if (font.vertical && txDiff !== 0 || !font.vertical && tyDiff !== 0) {
 
-         return null;
 
-       }
 
-       var tx,
 
-           ty,
 
-           denominator = a * d - b * c;
 
-       if (font.vertical) {
 
-         tx = -tyDiff * c / denominator;
 
-         ty = tyDiff * a / denominator;
 
-       } else {
 
-         tx = txDiff * d / denominator;
 
-         ty = -txDiff * b / denominator;
 
-       }
 
-       return {
 
-         width: tx,
 
-         height: ty,
 
-         value: font.vertical ? ty : tx
 
-       };
 
-     },
 
-     calcRenderMatrix: function TextState_calcRendeMatrix(ctm) {
 
-       var tsm = [this.fontSize * this.textHScale, 0, 0, this.fontSize, 0, this.textRise];
 
-       return _util.Util.transform(ctm, _util.Util.transform(this.textMatrix, tsm));
 
-     },
 
-     carriageReturn: function TextState_carriageReturn() {
 
-       this.translateTextLineMatrix(0, -this.leading);
 
-       this.textMatrix = this.textLineMatrix.slice();
 
-     },
 
-     clone: function TextState_clone() {
 
-       var clone = Object.create(this);
 
-       clone.textMatrix = this.textMatrix.slice();
 
-       clone.textLineMatrix = this.textLineMatrix.slice();
 
-       clone.fontMatrix = this.fontMatrix.slice();
 
-       return clone;
 
-     }
 
-   };
 
-   return TextState;
 
- }();
 
- var EvalState = function EvalStateClosure() {
 
-   function EvalState() {
 
-     this.ctm = new Float32Array(_util.IDENTITY_MATRIX);
 
-     this.font = null;
 
-     this.textRenderingMode = _util.TextRenderingMode.FILL;
 
-     this.fillColorSpace = _colorspace.ColorSpace.singletons.gray;
 
-     this.strokeColorSpace = _colorspace.ColorSpace.singletons.gray;
 
-   }
 
-   EvalState.prototype = {
 
-     clone: function CanvasExtraState_clone() {
 
-       return Object.create(this);
 
-     }
 
-   };
 
-   return EvalState;
 
- }();
 
- var EvaluatorPreprocessor = function EvaluatorPreprocessorClosure() {
 
-   var getOPMap = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["w"] = {
 
-       id: _util.OPS.setLineWidth,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["J"] = {
 
-       id: _util.OPS.setLineCap,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["j"] = {
 
-       id: _util.OPS.setLineJoin,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["M"] = {
 
-       id: _util.OPS.setMiterLimit,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["d"] = {
 
-       id: _util.OPS.setDash,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["ri"] = {
 
-       id: _util.OPS.setRenderingIntent,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["i"] = {
 
-       id: _util.OPS.setFlatness,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["gs"] = {
 
-       id: _util.OPS.setGState,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["q"] = {
 
-       id: _util.OPS.save,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["Q"] = {
 
-       id: _util.OPS.restore,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["cm"] = {
 
-       id: _util.OPS.transform,
 
-       numArgs: 6,
 
-       variableArgs: false
 
-     };
 
-     t["m"] = {
 
-       id: _util.OPS.moveTo,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["l"] = {
 
-       id: _util.OPS.lineTo,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["c"] = {
 
-       id: _util.OPS.curveTo,
 
-       numArgs: 6,
 
-       variableArgs: false
 
-     };
 
-     t["v"] = {
 
-       id: _util.OPS.curveTo2,
 
-       numArgs: 4,
 
-       variableArgs: false
 
-     };
 
-     t["y"] = {
 
-       id: _util.OPS.curveTo3,
 
-       numArgs: 4,
 
-       variableArgs: false
 
-     };
 
-     t["h"] = {
 
-       id: _util.OPS.closePath,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["re"] = {
 
-       id: _util.OPS.rectangle,
 
-       numArgs: 4,
 
-       variableArgs: false
 
-     };
 
-     t["S"] = {
 
-       id: _util.OPS.stroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["s"] = {
 
-       id: _util.OPS.closeStroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["f"] = {
 
-       id: _util.OPS.fill,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["F"] = {
 
-       id: _util.OPS.fill,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["f*"] = {
 
-       id: _util.OPS.eoFill,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["B"] = {
 
-       id: _util.OPS.fillStroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["B*"] = {
 
-       id: _util.OPS.eoFillStroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["b"] = {
 
-       id: _util.OPS.closeFillStroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["b*"] = {
 
-       id: _util.OPS.closeEOFillStroke,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["n"] = {
 
-       id: _util.OPS.endPath,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["W"] = {
 
-       id: _util.OPS.clip,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["W*"] = {
 
-       id: _util.OPS.eoClip,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["BT"] = {
 
-       id: _util.OPS.beginText,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["ET"] = {
 
-       id: _util.OPS.endText,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["Tc"] = {
 
-       id: _util.OPS.setCharSpacing,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Tw"] = {
 
-       id: _util.OPS.setWordSpacing,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Tz"] = {
 
-       id: _util.OPS.setHScale,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["TL"] = {
 
-       id: _util.OPS.setLeading,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Tf"] = {
 
-       id: _util.OPS.setFont,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["Tr"] = {
 
-       id: _util.OPS.setTextRenderingMode,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Ts"] = {
 
-       id: _util.OPS.setTextRise,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Td"] = {
 
-       id: _util.OPS.moveText,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["TD"] = {
 
-       id: _util.OPS.setLeadingMoveText,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["Tm"] = {
 
-       id: _util.OPS.setTextMatrix,
 
-       numArgs: 6,
 
-       variableArgs: false
 
-     };
 
-     t["T*"] = {
 
-       id: _util.OPS.nextLine,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["Tj"] = {
 
-       id: _util.OPS.showText,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["TJ"] = {
 
-       id: _util.OPS.showSpacedText,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["'"] = {
 
-       id: _util.OPS.nextLineShowText,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t['"'] = {
 
-       id: _util.OPS.nextLineSetSpacingShowText,
 
-       numArgs: 3,
 
-       variableArgs: false
 
-     };
 
-     t["d0"] = {
 
-       id: _util.OPS.setCharWidth,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["d1"] = {
 
-       id: _util.OPS.setCharWidthAndBounds,
 
-       numArgs: 6,
 
-       variableArgs: false
 
-     };
 
-     t["CS"] = {
 
-       id: _util.OPS.setStrokeColorSpace,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["cs"] = {
 
-       id: _util.OPS.setFillColorSpace,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["SC"] = {
 
-       id: _util.OPS.setStrokeColor,
 
-       numArgs: 4,
 
-       variableArgs: true
 
-     };
 
-     t["SCN"] = {
 
-       id: _util.OPS.setStrokeColorN,
 
-       numArgs: 33,
 
-       variableArgs: true
 
-     };
 
-     t["sc"] = {
 
-       id: _util.OPS.setFillColor,
 
-       numArgs: 4,
 
-       variableArgs: true
 
-     };
 
-     t["scn"] = {
 
-       id: _util.OPS.setFillColorN,
 
-       numArgs: 33,
 
-       variableArgs: true
 
-     };
 
-     t["G"] = {
 
-       id: _util.OPS.setStrokeGray,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["g"] = {
 
-       id: _util.OPS.setFillGray,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["RG"] = {
 
-       id: _util.OPS.setStrokeRGBColor,
 
-       numArgs: 3,
 
-       variableArgs: false
 
-     };
 
-     t["rg"] = {
 
-       id: _util.OPS.setFillRGBColor,
 
-       numArgs: 3,
 
-       variableArgs: false
 
-     };
 
-     t["K"] = {
 
-       id: _util.OPS.setStrokeCMYKColor,
 
-       numArgs: 4,
 
-       variableArgs: false
 
-     };
 
-     t["k"] = {
 
-       id: _util.OPS.setFillCMYKColor,
 
-       numArgs: 4,
 
-       variableArgs: false
 
-     };
 
-     t["sh"] = {
 
-       id: _util.OPS.shadingFill,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["BI"] = {
 
-       id: _util.OPS.beginInlineImage,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["ID"] = {
 
-       id: _util.OPS.beginImageData,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["EI"] = {
 
-       id: _util.OPS.endInlineImage,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["Do"] = {
 
-       id: _util.OPS.paintXObject,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["MP"] = {
 
-       id: _util.OPS.markPoint,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["DP"] = {
 
-       id: _util.OPS.markPointProps,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["BMC"] = {
 
-       id: _util.OPS.beginMarkedContent,
 
-       numArgs: 1,
 
-       variableArgs: false
 
-     };
 
-     t["BDC"] = {
 
-       id: _util.OPS.beginMarkedContentProps,
 
-       numArgs: 2,
 
-       variableArgs: false
 
-     };
 
-     t["EMC"] = {
 
-       id: _util.OPS.endMarkedContent,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["BX"] = {
 
-       id: _util.OPS.beginCompat,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["EX"] = {
 
-       id: _util.OPS.endCompat,
 
-       numArgs: 0,
 
-       variableArgs: false
 
-     };
 
-     t["BM"] = null;
 
-     t["BD"] = null;
 
-     t["true"] = null;
 
-     t["fa"] = null;
 
-     t["fal"] = null;
 
-     t["fals"] = null;
 
-     t["false"] = null;
 
-     t["nu"] = null;
 
-     t["nul"] = null;
 
-     t["null"] = null;
 
-   });
 
-   const MAX_INVALID_PATH_OPS = 20;
 
-   function EvaluatorPreprocessor(stream, xref, stateManager) {
 
-     this.opMap = getOPMap();
 
-     this.parser = new _parser.Parser({
 
-       lexer: new _parser.Lexer(stream, this.opMap),
 
-       xref
 
-     });
 
-     this.stateManager = stateManager;
 
-     this.nonProcessedArgs = [];
 
-     this._numInvalidPathOPS = 0;
 
-   }
 
-   EvaluatorPreprocessor.prototype = {
 
-     get savedStatesDepth() {
 
-       return this.stateManager.stateStack.length;
 
-     },
 
-     read: function EvaluatorPreprocessor_read(operation) {
 
-       var args = operation.args;
 
-       while (true) {
 
-         var obj = this.parser.getObj();
 
-         if (obj instanceof _primitives.Cmd) {
 
-           var cmd = obj.cmd;
 
-           var opSpec = this.opMap[cmd];
 
-           if (!opSpec) {
 
-             (0, _util.warn)(`Unknown command "${cmd}".`);
 
-             continue;
 
-           }
 
-           var fn = opSpec.id;
 
-           var numArgs = opSpec.numArgs;
 
-           var argsLength = args !== null ? args.length : 0;
 
-           if (!opSpec.variableArgs) {
 
-             if (argsLength !== numArgs) {
 
-               var nonProcessedArgs = this.nonProcessedArgs;
 
-               while (argsLength > numArgs) {
 
-                 nonProcessedArgs.push(args.shift());
 
-                 argsLength--;
 
-               }
 
-               while (argsLength < numArgs && nonProcessedArgs.length !== 0) {
 
-                 if (args === null) {
 
-                   args = [];
 
-                 }
 
-                 args.unshift(nonProcessedArgs.pop());
 
-                 argsLength++;
 
-               }
 
-             }
 
-             if (argsLength < numArgs) {
 
-               const partialMsg = `command ${cmd}: expected ${numArgs} args, ` + `but received ${argsLength} args.`;
 
-               if (fn >= _util.OPS.moveTo && fn <= _util.OPS.endPath && ++this._numInvalidPathOPS > MAX_INVALID_PATH_OPS) {
 
-                 throw new _util.FormatError(`Invalid ${partialMsg}`);
 
-               }
 
-               (0, _util.warn)(`Skipping ${partialMsg}`);
 
-               if (args !== null) {
 
-                 args.length = 0;
 
-               }
 
-               continue;
 
-             }
 
-           } else if (argsLength > numArgs) {
 
-             (0, _util.info)(`Command ${cmd}: expected [0, ${numArgs}] args, ` + `but received ${argsLength} args.`);
 
-           }
 
-           this.preprocessCommand(fn, args);
 
-           operation.fn = fn;
 
-           operation.args = args;
 
-           return true;
 
-         }
 
-         if (obj === _primitives.EOF) {
 
-           return false;
 
-         }
 
-         if (obj !== null) {
 
-           if (args === null) {
 
-             args = [];
 
-           }
 
-           args.push(obj);
 
-           if (args.length > 33) {
 
-             throw new _util.FormatError("Too many arguments");
 
-           }
 
-         }
 
-       }
 
-     },
 
-     preprocessCommand: function EvaluatorPreprocessor_preprocessCommand(fn, args) {
 
-       switch (fn | 0) {
 
-         case _util.OPS.save:
 
-           this.stateManager.save();
 
-           break;
 
-         case _util.OPS.restore:
 
-           this.stateManager.restore();
 
-           break;
 
-         case _util.OPS.transform:
 
-           this.stateManager.transform(args);
 
-           break;
 
-       }
 
-     }
 
-   };
 
-   return EvaluatorPreprocessor;
 
- }();
 
- /***/ }),
 
- /* 26 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.CMapFactory = exports.IdentityCMap = exports.CMap = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _parser = __w_pdfjs_require__(10);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _stream = __w_pdfjs_require__(11);
 
- var BUILT_IN_CMAPS = ["Adobe-GB1-UCS2", "Adobe-CNS1-UCS2", "Adobe-Japan1-UCS2", "Adobe-Korea1-UCS2", "78-EUC-H", "78-EUC-V", "78-H", "78-RKSJ-H", "78-RKSJ-V", "78-V", "78ms-RKSJ-H", "78ms-RKSJ-V", "83pv-RKSJ-H", "90ms-RKSJ-H", "90ms-RKSJ-V", "90msp-RKSJ-H", "90msp-RKSJ-V", "90pv-RKSJ-H", "90pv-RKSJ-V", "Add-H", "Add-RKSJ-H", "Add-RKSJ-V", "Add-V", "Adobe-CNS1-0", "Adobe-CNS1-1", "Adobe-CNS1-2", "Adobe-CNS1-3", "Adobe-CNS1-4", "Adobe-CNS1-5", "Adobe-CNS1-6", "Adobe-GB1-0", "Adobe-GB1-1", "Adobe-GB1-2", "Adobe-GB1-3", "Adobe-GB1-4", "Adobe-GB1-5", "Adobe-Japan1-0", "Adobe-Japan1-1", "Adobe-Japan1-2", "Adobe-Japan1-3", "Adobe-Japan1-4", "Adobe-Japan1-5", "Adobe-Japan1-6", "Adobe-Korea1-0", "Adobe-Korea1-1", "Adobe-Korea1-2", "B5-H", "B5-V", "B5pc-H", "B5pc-V", "CNS-EUC-H", "CNS-EUC-V", "CNS1-H", "CNS1-V", "CNS2-H", "CNS2-V", "ETHK-B5-H", "ETHK-B5-V", "ETen-B5-H", "ETen-B5-V", "ETenms-B5-H", "ETenms-B5-V", "EUC-H", "EUC-V", "Ext-H", "Ext-RKSJ-H", "Ext-RKSJ-V", "Ext-V", "GB-EUC-H", "GB-EUC-V", "GB-H", "GB-V", "GBK-EUC-H", "GBK-EUC-V", "GBK2K-H", "GBK2K-V", "GBKp-EUC-H", "GBKp-EUC-V", "GBT-EUC-H", "GBT-EUC-V", "GBT-H", "GBT-V", "GBTpc-EUC-H", "GBTpc-EUC-V", "GBpc-EUC-H", "GBpc-EUC-V", "H", "HKdla-B5-H", "HKdla-B5-V", "HKdlb-B5-H", "HKdlb-B5-V", "HKgccs-B5-H", "HKgccs-B5-V", "HKm314-B5-H", "HKm314-B5-V", "HKm471-B5-H", "HKm471-B5-V", "HKscs-B5-H", "HKscs-B5-V", "Hankaku", "Hiragana", "KSC-EUC-H", "KSC-EUC-V", "KSC-H", "KSC-Johab-H", "KSC-Johab-V", "KSC-V", "KSCms-UHC-H", "KSCms-UHC-HW-H", "KSCms-UHC-HW-V", "KSCms-UHC-V", "KSCpc-EUC-H", "KSCpc-EUC-V", "Katakana", "NWP-H", "NWP-V", "RKSJ-H", "RKSJ-V", "Roman", "UniCNS-UCS2-H", "UniCNS-UCS2-V", "UniCNS-UTF16-H", "UniCNS-UTF16-V", "UniCNS-UTF32-H", "UniCNS-UTF32-V", "UniCNS-UTF8-H", "UniCNS-UTF8-V", "UniGB-UCS2-H", "UniGB-UCS2-V", "UniGB-UTF16-H", "UniGB-UTF16-V", "UniGB-UTF32-H", "UniGB-UTF32-V", "UniGB-UTF8-H", "UniGB-UTF8-V", "UniJIS-UCS2-H", "UniJIS-UCS2-HW-H", "UniJIS-UCS2-HW-V", "UniJIS-UCS2-V", "UniJIS-UTF16-H", "UniJIS-UTF16-V", "UniJIS-UTF32-H", "UniJIS-UTF32-V", "UniJIS-UTF8-H", "UniJIS-UTF8-V", "UniJIS2004-UTF16-H", "UniJIS2004-UTF16-V", "UniJIS2004-UTF32-H", "UniJIS2004-UTF32-V", "UniJIS2004-UTF8-H", "UniJIS2004-UTF8-V", "UniJISPro-UCS2-HW-V", "UniJISPro-UCS2-V", "UniJISPro-UTF8-V", "UniJISX0213-UTF32-H", "UniJISX0213-UTF32-V", "UniJISX02132004-UTF32-H", "UniJISX02132004-UTF32-V", "UniKS-UCS2-H", "UniKS-UCS2-V", "UniKS-UTF16-H", "UniKS-UTF16-V", "UniKS-UTF32-H", "UniKS-UTF32-V", "UniKS-UTF8-H", "UniKS-UTF8-V", "V", "WP-Symbol"];
 
- class CMap {
 
-   constructor(builtInCMap = false) {
 
-     this.codespaceRanges = [[], [], [], []];
 
-     this.numCodespaceRanges = 0;
 
-     this._map = [];
 
-     this.name = "";
 
-     this.vertical = false;
 
-     this.useCMap = null;
 
-     this.builtInCMap = builtInCMap;
 
-   }
 
-   addCodespaceRange(n, low, high) {
 
-     this.codespaceRanges[n - 1].push(low, high);
 
-     this.numCodespaceRanges++;
 
-   }
 
-   mapCidRange(low, high, dstLow) {
 
-     while (low <= high) {
 
-       this._map[low++] = dstLow++;
 
-     }
 
-   }
 
-   mapBfRange(low, high, dstLow) {
 
-     var lastByte = dstLow.length - 1;
 
-     while (low <= high) {
 
-       this._map[low++] = dstLow;
 
-       dstLow = dstLow.substring(0, lastByte) + String.fromCharCode(dstLow.charCodeAt(lastByte) + 1);
 
-     }
 
-   }
 
-   mapBfRangeToArray(low, high, array) {
 
-     const ii = array.length;
 
-     let i = 0;
 
-     while (low <= high && i < ii) {
 
-       this._map[low] = array[i++];
 
-       ++low;
 
-     }
 
-   }
 
-   mapOne(src, dst) {
 
-     this._map[src] = dst;
 
-   }
 
-   lookup(code) {
 
-     return this._map[code];
 
-   }
 
-   contains(code) {
 
-     return this._map[code] !== undefined;
 
-   }
 
-   forEach(callback) {
 
-     const map = this._map;
 
-     const length = map.length;
 
-     if (length <= 0x10000) {
 
-       for (let i = 0; i < length; i++) {
 
-         if (map[i] !== undefined) {
 
-           callback(i, map[i]);
 
-         }
 
-       }
 
-     } else {
 
-       for (const i in map) {
 
-         callback(i, map[i]);
 
-       }
 
-     }
 
-   }
 
-   charCodeOf(value) {
 
-     const map = this._map;
 
-     if (map.length <= 0x10000) {
 
-       return map.indexOf(value);
 
-     }
 
-     for (const charCode in map) {
 
-       if (map[charCode] === value) {
 
-         return charCode | 0;
 
-       }
 
-     }
 
-     return -1;
 
-   }
 
-   getMap() {
 
-     return this._map;
 
-   }
 
-   readCharCode(str, offset, out) {
 
-     let c = 0;
 
-     const codespaceRanges = this.codespaceRanges;
 
-     for (let n = 0, nn = codespaceRanges.length; n < nn; n++) {
 
-       c = (c << 8 | str.charCodeAt(offset + n)) >>> 0;
 
-       const codespaceRange = codespaceRanges[n];
 
-       for (let k = 0, kk = codespaceRange.length; k < kk;) {
 
-         const low = codespaceRange[k++];
 
-         const high = codespaceRange[k++];
 
-         if (c >= low && c <= high) {
 
-           out.charcode = c;
 
-           out.length = n + 1;
 
-           return;
 
-         }
 
-       }
 
-     }
 
-     out.charcode = 0;
 
-     out.length = 1;
 
-   }
 
-   get length() {
 
-     return this._map.length;
 
-   }
 
-   get isIdentityCMap() {
 
-     if (!(this.name === "Identity-H" || this.name === "Identity-V")) {
 
-       return false;
 
-     }
 
-     if (this._map.length !== 0x10000) {
 
-       return false;
 
-     }
 
-     for (let i = 0; i < 0x10000; i++) {
 
-       if (this._map[i] !== i) {
 
-         return false;
 
-       }
 
-     }
 
-     return true;
 
-   }
 
- }
 
- exports.CMap = CMap;
 
- class IdentityCMap extends CMap {
 
-   constructor(vertical, n) {
 
-     super();
 
-     this.vertical = vertical;
 
-     this.addCodespaceRange(n, 0, 0xffff);
 
-   }
 
-   mapCidRange(low, high, dstLow) {
 
-     (0, _util.unreachable)("should not call mapCidRange");
 
-   }
 
-   mapBfRange(low, high, dstLow) {
 
-     (0, _util.unreachable)("should not call mapBfRange");
 
-   }
 
-   mapBfRangeToArray(low, high, array) {
 
-     (0, _util.unreachable)("should not call mapBfRangeToArray");
 
-   }
 
-   mapOne(src, dst) {
 
-     (0, _util.unreachable)("should not call mapCidOne");
 
-   }
 
-   lookup(code) {
 
-     return Number.isInteger(code) && code <= 0xffff ? code : undefined;
 
-   }
 
-   contains(code) {
 
-     return Number.isInteger(code) && code <= 0xffff;
 
-   }
 
-   forEach(callback) {
 
-     for (let i = 0; i <= 0xffff; i++) {
 
-       callback(i, i);
 
-     }
 
-   }
 
-   charCodeOf(value) {
 
-     return Number.isInteger(value) && value <= 0xffff ? value : -1;
 
-   }
 
-   getMap() {
 
-     const map = new Array(0x10000);
 
-     for (let i = 0; i <= 0xffff; i++) {
 
-       map[i] = i;
 
-     }
 
-     return map;
 
-   }
 
-   get length() {
 
-     return 0x10000;
 
-   }
 
-   get isIdentityCMap() {
 
-     (0, _util.unreachable)("should not access .isIdentityCMap");
 
-   }
 
- }
 
- exports.IdentityCMap = IdentityCMap;
 
- var BinaryCMapReader = function BinaryCMapReaderClosure() {
 
-   function hexToInt(a, size) {
 
-     var n = 0;
 
-     for (var i = 0; i <= size; i++) {
 
-       n = n << 8 | a[i];
 
-     }
 
-     return n >>> 0;
 
-   }
 
-   function hexToStr(a, size) {
 
-     if (size === 1) {
 
-       return String.fromCharCode(a[0], a[1]);
 
-     }
 
-     if (size === 3) {
 
-       return String.fromCharCode(a[0], a[1], a[2], a[3]);
 
-     }
 
-     return String.fromCharCode.apply(null, a.subarray(0, size + 1));
 
-   }
 
-   function addHex(a, b, size) {
 
-     var c = 0;
 
-     for (var i = size; i >= 0; i--) {
 
-       c += a[i] + b[i];
 
-       a[i] = c & 255;
 
-       c >>= 8;
 
-     }
 
-   }
 
-   function incHex(a, size) {
 
-     var c = 1;
 
-     for (var i = size; i >= 0 && c > 0; i--) {
 
-       c += a[i];
 
-       a[i] = c & 255;
 
-       c >>= 8;
 
-     }
 
-   }
 
-   var MAX_NUM_SIZE = 16;
 
-   var MAX_ENCODED_NUM_SIZE = 19;
 
-   function BinaryCMapStream(data) {
 
-     this.buffer = data;
 
-     this.pos = 0;
 
-     this.end = data.length;
 
-     this.tmpBuf = new Uint8Array(MAX_ENCODED_NUM_SIZE);
 
-   }
 
-   BinaryCMapStream.prototype = {
 
-     readByte() {
 
-       if (this.pos >= this.end) {
 
-         return -1;
 
-       }
 
-       return this.buffer[this.pos++];
 
-     },
 
-     readNumber() {
 
-       var n = 0;
 
-       var last;
 
-       do {
 
-         var b = this.readByte();
 
-         if (b < 0) {
 
-           throw new _util.FormatError("unexpected EOF in bcmap");
 
-         }
 
-         last = !(b & 0x80);
 
-         n = n << 7 | b & 0x7f;
 
-       } while (!last);
 
-       return n;
 
-     },
 
-     readSigned() {
 
-       var n = this.readNumber();
 
-       return n & 1 ? ~(n >>> 1) : n >>> 1;
 
-     },
 
-     readHex(num, size) {
 
-       num.set(this.buffer.subarray(this.pos, this.pos + size + 1));
 
-       this.pos += size + 1;
 
-     },
 
-     readHexNumber(num, size) {
 
-       var last;
 
-       var stack = this.tmpBuf,
 
-           sp = 0;
 
-       do {
 
-         var b = this.readByte();
 
-         if (b < 0) {
 
-           throw new _util.FormatError("unexpected EOF in bcmap");
 
-         }
 
-         last = !(b & 0x80);
 
-         stack[sp++] = b & 0x7f;
 
-       } while (!last);
 
-       var i = size,
 
-           buffer = 0,
 
-           bufferSize = 0;
 
-       while (i >= 0) {
 
-         while (bufferSize < 8 && stack.length > 0) {
 
-           buffer = stack[--sp] << bufferSize | buffer;
 
-           bufferSize += 7;
 
-         }
 
-         num[i] = buffer & 255;
 
-         i--;
 
-         buffer >>= 8;
 
-         bufferSize -= 8;
 
-       }
 
-     },
 
-     readHexSigned(num, size) {
 
-       this.readHexNumber(num, size);
 
-       var sign = num[size] & 1 ? 255 : 0;
 
-       var c = 0;
 
-       for (var i = 0; i <= size; i++) {
 
-         c = (c & 1) << 8 | num[i];
 
-         num[i] = c >> 1 ^ sign;
 
-       }
 
-     },
 
-     readString() {
 
-       var len = this.readNumber();
 
-       var s = "";
 
-       for (var i = 0; i < len; i++) {
 
-         s += String.fromCharCode(this.readNumber());
 
-       }
 
-       return s;
 
-     }
 
-   };
 
-   function processBinaryCMap(data, cMap, extend) {
 
-     return new Promise(function (resolve, reject) {
 
-       var stream = new BinaryCMapStream(data);
 
-       var header = stream.readByte();
 
-       cMap.vertical = !!(header & 1);
 
-       var useCMap = null;
 
-       var start = new Uint8Array(MAX_NUM_SIZE);
 
-       var end = new Uint8Array(MAX_NUM_SIZE);
 
-       var char = new Uint8Array(MAX_NUM_SIZE);
 
-       var charCode = new Uint8Array(MAX_NUM_SIZE);
 
-       var tmp = new Uint8Array(MAX_NUM_SIZE);
 
-       var code;
 
-       var b;
 
-       while ((b = stream.readByte()) >= 0) {
 
-         var type = b >> 5;
 
-         if (type === 7) {
 
-           switch (b & 0x1f) {
 
-             case 0:
 
-               stream.readString();
 
-               break;
 
-             case 1:
 
-               useCMap = stream.readString();
 
-               break;
 
-           }
 
-           continue;
 
-         }
 
-         var sequence = !!(b & 0x10);
 
-         var dataSize = b & 15;
 
-         if (dataSize + 1 > MAX_NUM_SIZE) {
 
-           throw new Error("processBinaryCMap: Invalid dataSize.");
 
-         }
 
-         var ucs2DataSize = 1;
 
-         var subitemsCount = stream.readNumber();
 
-         var i;
 
-         switch (type) {
 
-           case 0:
 
-             stream.readHex(start, dataSize);
 
-             stream.readHexNumber(end, dataSize);
 
-             addHex(end, start, dataSize);
 
-             cMap.addCodespaceRange(dataSize + 1, hexToInt(start, dataSize), hexToInt(end, dataSize));
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(end, dataSize);
 
-               stream.readHexNumber(start, dataSize);
 
-               addHex(start, end, dataSize);
 
-               stream.readHexNumber(end, dataSize);
 
-               addHex(end, start, dataSize);
 
-               cMap.addCodespaceRange(dataSize + 1, hexToInt(start, dataSize), hexToInt(end, dataSize));
 
-             }
 
-             break;
 
-           case 1:
 
-             stream.readHex(start, dataSize);
 
-             stream.readHexNumber(end, dataSize);
 
-             addHex(end, start, dataSize);
 
-             stream.readNumber();
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(end, dataSize);
 
-               stream.readHexNumber(start, dataSize);
 
-               addHex(start, end, dataSize);
 
-               stream.readHexNumber(end, dataSize);
 
-               addHex(end, start, dataSize);
 
-               stream.readNumber();
 
-             }
 
-             break;
 
-           case 2:
 
-             stream.readHex(char, dataSize);
 
-             code = stream.readNumber();
 
-             cMap.mapOne(hexToInt(char, dataSize), code);
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(char, dataSize);
 
-               if (!sequence) {
 
-                 stream.readHexNumber(tmp, dataSize);
 
-                 addHex(char, tmp, dataSize);
 
-               }
 
-               code = stream.readSigned() + (code + 1);
 
-               cMap.mapOne(hexToInt(char, dataSize), code);
 
-             }
 
-             break;
 
-           case 3:
 
-             stream.readHex(start, dataSize);
 
-             stream.readHexNumber(end, dataSize);
 
-             addHex(end, start, dataSize);
 
-             code = stream.readNumber();
 
-             cMap.mapCidRange(hexToInt(start, dataSize), hexToInt(end, dataSize), code);
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(end, dataSize);
 
-               if (!sequence) {
 
-                 stream.readHexNumber(start, dataSize);
 
-                 addHex(start, end, dataSize);
 
-               } else {
 
-                 start.set(end);
 
-               }
 
-               stream.readHexNumber(end, dataSize);
 
-               addHex(end, start, dataSize);
 
-               code = stream.readNumber();
 
-               cMap.mapCidRange(hexToInt(start, dataSize), hexToInt(end, dataSize), code);
 
-             }
 
-             break;
 
-           case 4:
 
-             stream.readHex(char, ucs2DataSize);
 
-             stream.readHex(charCode, dataSize);
 
-             cMap.mapOne(hexToInt(char, ucs2DataSize), hexToStr(charCode, dataSize));
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(char, ucs2DataSize);
 
-               if (!sequence) {
 
-                 stream.readHexNumber(tmp, ucs2DataSize);
 
-                 addHex(char, tmp, ucs2DataSize);
 
-               }
 
-               incHex(charCode, dataSize);
 
-               stream.readHexSigned(tmp, dataSize);
 
-               addHex(charCode, tmp, dataSize);
 
-               cMap.mapOne(hexToInt(char, ucs2DataSize), hexToStr(charCode, dataSize));
 
-             }
 
-             break;
 
-           case 5:
 
-             stream.readHex(start, ucs2DataSize);
 
-             stream.readHexNumber(end, ucs2DataSize);
 
-             addHex(end, start, ucs2DataSize);
 
-             stream.readHex(charCode, dataSize);
 
-             cMap.mapBfRange(hexToInt(start, ucs2DataSize), hexToInt(end, ucs2DataSize), hexToStr(charCode, dataSize));
 
-             for (i = 1; i < subitemsCount; i++) {
 
-               incHex(end, ucs2DataSize);
 
-               if (!sequence) {
 
-                 stream.readHexNumber(start, ucs2DataSize);
 
-                 addHex(start, end, ucs2DataSize);
 
-               } else {
 
-                 start.set(end);
 
-               }
 
-               stream.readHexNumber(end, ucs2DataSize);
 
-               addHex(end, start, ucs2DataSize);
 
-               stream.readHex(charCode, dataSize);
 
-               cMap.mapBfRange(hexToInt(start, ucs2DataSize), hexToInt(end, ucs2DataSize), hexToStr(charCode, dataSize));
 
-             }
 
-             break;
 
-           default:
 
-             reject(new Error("processBinaryCMap: Unknown type: " + type));
 
-             return;
 
-         }
 
-       }
 
-       if (useCMap) {
 
-         resolve(extend(useCMap));
 
-         return;
 
-       }
 
-       resolve(cMap);
 
-     });
 
-   }
 
-   function BinaryCMapReader() {}
 
-   BinaryCMapReader.prototype = {
 
-     process: processBinaryCMap
 
-   };
 
-   return BinaryCMapReader;
 
- }();
 
- var CMapFactory = function CMapFactoryClosure() {
 
-   function strToInt(str) {
 
-     var a = 0;
 
-     for (var i = 0; i < str.length; i++) {
 
-       a = a << 8 | str.charCodeAt(i);
 
-     }
 
-     return a >>> 0;
 
-   }
 
-   function expectString(obj) {
 
-     if (!(0, _util.isString)(obj)) {
 
-       throw new _util.FormatError("Malformed CMap: expected string.");
 
-     }
 
-   }
 
-   function expectInt(obj) {
 
-     if (!Number.isInteger(obj)) {
 
-       throw new _util.FormatError("Malformed CMap: expected int.");
 
-     }
 
-   }
 
-   function parseBfChar(cMap, lexer) {
 
-     while (true) {
 
-       var obj = lexer.getObj();
 
-       if ((0, _primitives.isEOF)(obj)) {
 
-         break;
 
-       }
 
-       if ((0, _primitives.isCmd)(obj, "endbfchar")) {
 
-         return;
 
-       }
 
-       expectString(obj);
 
-       var src = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       expectString(obj);
 
-       var dst = obj;
 
-       cMap.mapOne(src, dst);
 
-     }
 
-   }
 
-   function parseBfRange(cMap, lexer) {
 
-     while (true) {
 
-       var obj = lexer.getObj();
 
-       if ((0, _primitives.isEOF)(obj)) {
 
-         break;
 
-       }
 
-       if ((0, _primitives.isCmd)(obj, "endbfrange")) {
 
-         return;
 
-       }
 
-       expectString(obj);
 
-       var low = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       expectString(obj);
 
-       var high = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       if (Number.isInteger(obj) || (0, _util.isString)(obj)) {
 
-         var dstLow = Number.isInteger(obj) ? String.fromCharCode(obj) : obj;
 
-         cMap.mapBfRange(low, high, dstLow);
 
-       } else if ((0, _primitives.isCmd)(obj, "[")) {
 
-         obj = lexer.getObj();
 
-         var array = [];
 
-         while (!(0, _primitives.isCmd)(obj, "]") && !(0, _primitives.isEOF)(obj)) {
 
-           array.push(obj);
 
-           obj = lexer.getObj();
 
-         }
 
-         cMap.mapBfRangeToArray(low, high, array);
 
-       } else {
 
-         break;
 
-       }
 
-     }
 
-     throw new _util.FormatError("Invalid bf range.");
 
-   }
 
-   function parseCidChar(cMap, lexer) {
 
-     while (true) {
 
-       var obj = lexer.getObj();
 
-       if ((0, _primitives.isEOF)(obj)) {
 
-         break;
 
-       }
 
-       if ((0, _primitives.isCmd)(obj, "endcidchar")) {
 
-         return;
 
-       }
 
-       expectString(obj);
 
-       var src = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       expectInt(obj);
 
-       var dst = obj;
 
-       cMap.mapOne(src, dst);
 
-     }
 
-   }
 
-   function parseCidRange(cMap, lexer) {
 
-     while (true) {
 
-       var obj = lexer.getObj();
 
-       if ((0, _primitives.isEOF)(obj)) {
 
-         break;
 
-       }
 
-       if ((0, _primitives.isCmd)(obj, "endcidrange")) {
 
-         return;
 
-       }
 
-       expectString(obj);
 
-       var low = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       expectString(obj);
 
-       var high = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       expectInt(obj);
 
-       var dstLow = obj;
 
-       cMap.mapCidRange(low, high, dstLow);
 
-     }
 
-   }
 
-   function parseCodespaceRange(cMap, lexer) {
 
-     while (true) {
 
-       var obj = lexer.getObj();
 
-       if ((0, _primitives.isEOF)(obj)) {
 
-         break;
 
-       }
 
-       if ((0, _primitives.isCmd)(obj, "endcodespacerange")) {
 
-         return;
 
-       }
 
-       if (!(0, _util.isString)(obj)) {
 
-         break;
 
-       }
 
-       var low = strToInt(obj);
 
-       obj = lexer.getObj();
 
-       if (!(0, _util.isString)(obj)) {
 
-         break;
 
-       }
 
-       var high = strToInt(obj);
 
-       cMap.addCodespaceRange(obj.length, low, high);
 
-     }
 
-     throw new _util.FormatError("Invalid codespace range.");
 
-   }
 
-   function parseWMode(cMap, lexer) {
 
-     var obj = lexer.getObj();
 
-     if (Number.isInteger(obj)) {
 
-       cMap.vertical = !!obj;
 
-     }
 
-   }
 
-   function parseCMapName(cMap, lexer) {
 
-     var obj = lexer.getObj();
 
-     if ((0, _primitives.isName)(obj) && (0, _util.isString)(obj.name)) {
 
-       cMap.name = obj.name;
 
-     }
 
-   }
 
-   function parseCMap(cMap, lexer, fetchBuiltInCMap, useCMap) {
 
-     var previous;
 
-     var embeddedUseCMap;
 
-     objLoop: while (true) {
 
-       try {
 
-         var obj = lexer.getObj();
 
-         if ((0, _primitives.isEOF)(obj)) {
 
-           break;
 
-         } else if ((0, _primitives.isName)(obj)) {
 
-           if (obj.name === "WMode") {
 
-             parseWMode(cMap, lexer);
 
-           } else if (obj.name === "CMapName") {
 
-             parseCMapName(cMap, lexer);
 
-           }
 
-           previous = obj;
 
-         } else if ((0, _primitives.isCmd)(obj)) {
 
-           switch (obj.cmd) {
 
-             case "endcmap":
 
-               break objLoop;
 
-             case "usecmap":
 
-               if ((0, _primitives.isName)(previous)) {
 
-                 embeddedUseCMap = previous.name;
 
-               }
 
-               break;
 
-             case "begincodespacerange":
 
-               parseCodespaceRange(cMap, lexer);
 
-               break;
 
-             case "beginbfchar":
 
-               parseBfChar(cMap, lexer);
 
-               break;
 
-             case "begincidchar":
 
-               parseCidChar(cMap, lexer);
 
-               break;
 
-             case "beginbfrange":
 
-               parseBfRange(cMap, lexer);
 
-               break;
 
-             case "begincidrange":
 
-               parseCidRange(cMap, lexer);
 
-               break;
 
-           }
 
-         }
 
-       } catch (ex) {
 
-         if (ex instanceof _core_utils.MissingDataException) {
 
-           throw ex;
 
-         }
 
-         (0, _util.warn)("Invalid cMap data: " + ex);
 
-         continue;
 
-       }
 
-     }
 
-     if (!useCMap && embeddedUseCMap) {
 
-       useCMap = embeddedUseCMap;
 
-     }
 
-     if (useCMap) {
 
-       return extendCMap(cMap, fetchBuiltInCMap, useCMap);
 
-     }
 
-     return Promise.resolve(cMap);
 
-   }
 
-   function extendCMap(cMap, fetchBuiltInCMap, useCMap) {
 
-     return createBuiltInCMap(useCMap, fetchBuiltInCMap).then(function (newCMap) {
 
-       cMap.useCMap = newCMap;
 
-       if (cMap.numCodespaceRanges === 0) {
 
-         var useCodespaceRanges = cMap.useCMap.codespaceRanges;
 
-         for (var i = 0; i < useCodespaceRanges.length; i++) {
 
-           cMap.codespaceRanges[i] = useCodespaceRanges[i].slice();
 
-         }
 
-         cMap.numCodespaceRanges = cMap.useCMap.numCodespaceRanges;
 
-       }
 
-       cMap.useCMap.forEach(function (key, value) {
 
-         if (!cMap.contains(key)) {
 
-           cMap.mapOne(key, cMap.useCMap.lookup(key));
 
-         }
 
-       });
 
-       return cMap;
 
-     });
 
-   }
 
-   function createBuiltInCMap(name, fetchBuiltInCMap) {
 
-     if (name === "Identity-H") {
 
-       return Promise.resolve(new IdentityCMap(false, 2));
 
-     } else if (name === "Identity-V") {
 
-       return Promise.resolve(new IdentityCMap(true, 2));
 
-     }
 
-     if (!BUILT_IN_CMAPS.includes(name)) {
 
-       return Promise.reject(new Error("Unknown CMap name: " + name));
 
-     }
 
-     if (!fetchBuiltInCMap) {
 
-       return Promise.reject(new Error("Built-in CMap parameters are not provided."));
 
-     }
 
-     return fetchBuiltInCMap(name).then(function (data) {
 
-       var cMapData = data.cMapData,
 
-           compressionType = data.compressionType;
 
-       var cMap = new CMap(true);
 
-       if (compressionType === _util.CMapCompressionType.BINARY) {
 
-         return new BinaryCMapReader().process(cMapData, cMap, function (useCMap) {
 
-           return extendCMap(cMap, fetchBuiltInCMap, useCMap);
 
-         });
 
-       }
 
-       if (compressionType === _util.CMapCompressionType.NONE) {
 
-         var lexer = new _parser.Lexer(new _stream.Stream(cMapData));
 
-         return parseCMap(cMap, lexer, fetchBuiltInCMap, null);
 
-       }
 
-       return Promise.reject(new Error("TODO: Only BINARY/NONE CMap compression is currently supported."));
 
-     });
 
-   }
 
-   return {
 
-     async create(params) {
 
-       var encoding = params.encoding;
 
-       var fetchBuiltInCMap = params.fetchBuiltInCMap;
 
-       var useCMap = params.useCMap;
 
-       if ((0, _primitives.isName)(encoding)) {
 
-         return createBuiltInCMap(encoding.name, fetchBuiltInCMap);
 
-       } else if ((0, _primitives.isStream)(encoding)) {
 
-         var cMap = new CMap();
 
-         var lexer = new _parser.Lexer(encoding);
 
-         return parseCMap(cMap, lexer, fetchBuiltInCMap, useCMap).then(function (parsedCMap) {
 
-           if (parsedCMap.isIdentityCMap) {
 
-             return createBuiltInCMap(parsedCMap.name, fetchBuiltInCMap);
 
-           }
 
-           return parsedCMap;
 
-         });
 
-       }
 
-       throw new Error("Encoding required.");
 
-     }
 
-   };
 
- }();
 
- exports.CMapFactory = CMapFactory;
 
- /***/ }),
 
- /* 27 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getFontType = getFontType;
 
- exports.IdentityToUnicodeMap = exports.ToUnicodeMap = exports.FontFlags = exports.Font = exports.ErrorFont = exports.SEAC_ANALYSIS_ENABLED = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _cff_parser = __w_pdfjs_require__(28);
 
- var _glyphlist = __w_pdfjs_require__(31);
 
- var _encodings = __w_pdfjs_require__(30);
 
- var _standard_fonts = __w_pdfjs_require__(32);
 
- var _unicode = __w_pdfjs_require__(33);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _font_renderer = __w_pdfjs_require__(34);
 
- var _cmap = __w_pdfjs_require__(26);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _type1_parser = __w_pdfjs_require__(35);
 
- const PRIVATE_USE_AREAS = [[0xe000, 0xf8ff], [0x100000, 0x10fffd]];
 
- var PDF_GLYPH_SPACE_UNITS = 1000;
 
- var SEAC_ANALYSIS_ENABLED = true;
 
- exports.SEAC_ANALYSIS_ENABLED = SEAC_ANALYSIS_ENABLED;
 
- var FontFlags = {
 
-   FixedPitch: 1,
 
-   Serif: 2,
 
-   Symbolic: 4,
 
-   Script: 8,
 
-   Nonsymbolic: 32,
 
-   Italic: 64,
 
-   AllCap: 65536,
 
-   SmallCap: 131072,
 
-   ForceBold: 262144
 
- };
 
- exports.FontFlags = FontFlags;
 
- var MacStandardGlyphOrdering = [".notdef", ".null", "nonmarkingreturn", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quotesingle", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "grave", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "Adieresis", "Aring", "Ccedilla", "Eacute", "Ntilde", "Odieresis", "Udieresis", "aacute", "agrave", "acircumflex", "adieresis", "atilde", "aring", "ccedilla", "eacute", "egrave", "ecircumflex", "edieresis", "iacute", "igrave", "icircumflex", "idieresis", "ntilde", "oacute", "ograve", "ocircumflex", "odieresis", "otilde", "uacute", "ugrave", "ucircumflex", "udieresis", "dagger", "degree", "cent", "sterling", "section", "bullet", "paragraph", "germandbls", "registered", "copyright", "trademark", "acute", "dieresis", "notequal", "AE", "Oslash", "infinity", "plusminus", "lessequal", "greaterequal", "yen", "mu", "partialdiff", "summation", "product", "pi", "integral", "ordfeminine", "ordmasculine", "Omega", "ae", "oslash", "questiondown", "exclamdown", "logicalnot", "radical", "florin", "approxequal", "Delta", "guillemotleft", "guillemotright", "ellipsis", "nonbreakingspace", "Agrave", "Atilde", "Otilde", "OE", "oe", "endash", "emdash", "quotedblleft", "quotedblright", "quoteleft", "quoteright", "divide", "lozenge", "ydieresis", "Ydieresis", "fraction", "currency", "guilsinglleft", "guilsinglright", "fi", "fl", "daggerdbl", "periodcentered", "quotesinglbase", "quotedblbase", "perthousand", "Acircumflex", "Ecircumflex", "Aacute", "Edieresis", "Egrave", "Iacute", "Icircumflex", "Idieresis", "Igrave", "Oacute", "Ocircumflex", "apple", "Ograve", "Uacute", "Ucircumflex", "Ugrave", "dotlessi", "circumflex", "tilde", "macron", "breve", "dotaccent", "ring", "cedilla", "hungarumlaut", "ogonek", "caron", "Lslash", "lslash", "Scaron", "scaron", "Zcaron", "zcaron", "brokenbar", "Eth", "eth", "Yacute", "yacute", "Thorn", "thorn", "minus", "multiply", "onesuperior", "twosuperior", "threesuperior", "onehalf", "onequarter", "threequarters", "franc", "Gbreve", "gbreve", "Idotaccent", "Scedilla", "scedilla", "Cacute", "cacute", "Ccaron", "ccaron", "dcroat"];
 
- function adjustWidths(properties) {
 
-   if (!properties.fontMatrix) {
 
-     return;
 
-   }
 
-   if (properties.fontMatrix[0] === _util.FONT_IDENTITY_MATRIX[0]) {
 
-     return;
 
-   }
 
-   var scale = 0.001 / properties.fontMatrix[0];
 
-   var glyphsWidths = properties.widths;
 
-   for (var glyph in glyphsWidths) {
 
-     glyphsWidths[glyph] *= scale;
 
-   }
 
-   properties.defaultWidth *= scale;
 
- }
 
- function adjustToUnicode(properties, builtInEncoding) {
 
-   if (properties.hasIncludedToUnicodeMap) {
 
-     return;
 
-   }
 
-   if (properties.hasEncoding) {
 
-     return;
 
-   }
 
-   if (builtInEncoding === properties.defaultEncoding) {
 
-     return;
 
-   }
 
-   if (properties.toUnicode instanceof IdentityToUnicodeMap) {
 
-     return;
 
-   }
 
-   var toUnicode = [],
 
-       glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-   for (var charCode in builtInEncoding) {
 
-     var glyphName = builtInEncoding[charCode];
 
-     var unicode = (0, _unicode.getUnicodeForGlyph)(glyphName, glyphsUnicodeMap);
 
-     if (unicode !== -1) {
 
-       toUnicode[charCode] = String.fromCharCode(unicode);
 
-     }
 
-   }
 
-   properties.toUnicode.amend(toUnicode);
 
- }
 
- function getFontType(type, subtype) {
 
-   switch (type) {
 
-     case "Type1":
 
-       return subtype === "Type1C" ? _util.FontType.TYPE1C : _util.FontType.TYPE1;
 
-     case "CIDFontType0":
 
-       return subtype === "CIDFontType0C" ? _util.FontType.CIDFONTTYPE0C : _util.FontType.CIDFONTTYPE0;
 
-     case "OpenType":
 
-       return _util.FontType.OPENTYPE;
 
-     case "TrueType":
 
-       return _util.FontType.TRUETYPE;
 
-     case "CIDFontType2":
 
-       return _util.FontType.CIDFONTTYPE2;
 
-     case "MMType1":
 
-       return _util.FontType.MMTYPE1;
 
-     case "Type0":
 
-       return _util.FontType.TYPE0;
 
-     default:
 
-       return _util.FontType.UNKNOWN;
 
-   }
 
- }
 
- function recoverGlyphName(name, glyphsUnicodeMap) {
 
-   if (glyphsUnicodeMap[name] !== undefined) {
 
-     return name;
 
-   }
 
-   var unicode = (0, _unicode.getUnicodeForGlyph)(name, glyphsUnicodeMap);
 
-   if (unicode !== -1) {
 
-     for (var key in glyphsUnicodeMap) {
 
-       if (glyphsUnicodeMap[key] === unicode) {
 
-         return key;
 
-       }
 
-     }
 
-   }
 
-   (0, _util.info)("Unable to recover a standard glyph name for: " + name);
 
-   return name;
 
- }
 
- var Glyph = function GlyphClosure() {
 
-   function Glyph(fontChar, unicode, accent, width, vmetric, operatorListId, isSpace, isInFont) {
 
-     this.fontChar = fontChar;
 
-     this.unicode = unicode;
 
-     this.accent = accent;
 
-     this.width = width;
 
-     this.vmetric = vmetric;
 
-     this.operatorListId = operatorListId;
 
-     this.isSpace = isSpace;
 
-     this.isInFont = isInFont;
 
-   }
 
-   Glyph.prototype.matchesForCache = function (fontChar, unicode, accent, width, vmetric, operatorListId, isSpace, isInFont) {
 
-     return this.fontChar === fontChar && this.unicode === unicode && this.accent === accent && this.width === width && this.vmetric === vmetric && this.operatorListId === operatorListId && this.isSpace === isSpace && this.isInFont === isInFont;
 
-   };
 
-   return Glyph;
 
- }();
 
- var ToUnicodeMap = function ToUnicodeMapClosure() {
 
-   function ToUnicodeMap(cmap = []) {
 
-     this._map = cmap;
 
-   }
 
-   ToUnicodeMap.prototype = {
 
-     get length() {
 
-       return this._map.length;
 
-     },
 
-     forEach(callback) {
 
-       for (var charCode in this._map) {
 
-         callback(charCode, this._map[charCode].charCodeAt(0));
 
-       }
 
-     },
 
-     has(i) {
 
-       return this._map[i] !== undefined;
 
-     },
 
-     get(i) {
 
-       return this._map[i];
 
-     },
 
-     charCodeOf(value) {
 
-       const map = this._map;
 
-       if (map.length <= 0x10000) {
 
-         return map.indexOf(value);
 
-       }
 
-       for (const charCode in map) {
 
-         if (map[charCode] === value) {
 
-           return charCode | 0;
 
-         }
 
-       }
 
-       return -1;
 
-     },
 
-     amend(map) {
 
-       for (var charCode in map) {
 
-         this._map[charCode] = map[charCode];
 
-       }
 
-     }
 
-   };
 
-   return ToUnicodeMap;
 
- }();
 
- exports.ToUnicodeMap = ToUnicodeMap;
 
- var IdentityToUnicodeMap = function IdentityToUnicodeMapClosure() {
 
-   function IdentityToUnicodeMap(firstChar, lastChar) {
 
-     this.firstChar = firstChar;
 
-     this.lastChar = lastChar;
 
-   }
 
-   IdentityToUnicodeMap.prototype = {
 
-     get length() {
 
-       return this.lastChar + 1 - this.firstChar;
 
-     },
 
-     forEach(callback) {
 
-       for (var i = this.firstChar, ii = this.lastChar; i <= ii; i++) {
 
-         callback(i, i);
 
-       }
 
-     },
 
-     has(i) {
 
-       return this.firstChar <= i && i <= this.lastChar;
 
-     },
 
-     get(i) {
 
-       if (this.firstChar <= i && i <= this.lastChar) {
 
-         return String.fromCharCode(i);
 
-       }
 
-       return undefined;
 
-     },
 
-     charCodeOf(v) {
 
-       return Number.isInteger(v) && v >= this.firstChar && v <= this.lastChar ? v : -1;
 
-     },
 
-     amend(map) {
 
-       (0, _util.unreachable)("Should not call amend()");
 
-     }
 
-   };
 
-   return IdentityToUnicodeMap;
 
- }();
 
- exports.IdentityToUnicodeMap = IdentityToUnicodeMap;
 
- var OpenTypeFileBuilder = function OpenTypeFileBuilderClosure() {
 
-   function writeInt16(dest, offset, num) {
 
-     dest[offset] = num >> 8 & 0xff;
 
-     dest[offset + 1] = num & 0xff;
 
-   }
 
-   function writeInt32(dest, offset, num) {
 
-     dest[offset] = num >> 24 & 0xff;
 
-     dest[offset + 1] = num >> 16 & 0xff;
 
-     dest[offset + 2] = num >> 8 & 0xff;
 
-     dest[offset + 3] = num & 0xff;
 
-   }
 
-   function writeData(dest, offset, data) {
 
-     var i, ii;
 
-     if (data instanceof Uint8Array) {
 
-       dest.set(data, offset);
 
-     } else if (typeof data === "string") {
 
-       for (i = 0, ii = data.length; i < ii; i++) {
 
-         dest[offset++] = data.charCodeAt(i) & 0xff;
 
-       }
 
-     } else {
 
-       for (i = 0, ii = data.length; i < ii; i++) {
 
-         dest[offset++] = data[i] & 0xff;
 
-       }
 
-     }
 
-   }
 
-   function OpenTypeFileBuilder(sfnt) {
 
-     this.sfnt = sfnt;
 
-     this.tables = Object.create(null);
 
-   }
 
-   OpenTypeFileBuilder.getSearchParams = function OpenTypeFileBuilder_getSearchParams(entriesCount, entrySize) {
 
-     var maxPower2 = 1,
 
-         log2 = 0;
 
-     while ((maxPower2 ^ entriesCount) > maxPower2) {
 
-       maxPower2 <<= 1;
 
-       log2++;
 
-     }
 
-     var searchRange = maxPower2 * entrySize;
 
-     return {
 
-       range: searchRange,
 
-       entry: log2,
 
-       rangeShift: entrySize * entriesCount - searchRange
 
-     };
 
-   };
 
-   var OTF_HEADER_SIZE = 12;
 
-   var OTF_TABLE_ENTRY_SIZE = 16;
 
-   OpenTypeFileBuilder.prototype = {
 
-     toArray: function OpenTypeFileBuilder_toArray() {
 
-       var sfnt = this.sfnt;
 
-       var tables = this.tables;
 
-       var tablesNames = Object.keys(tables);
 
-       tablesNames.sort();
 
-       var numTables = tablesNames.length;
 
-       var i, j, jj, table, tableName;
 
-       var offset = OTF_HEADER_SIZE + numTables * OTF_TABLE_ENTRY_SIZE;
 
-       var tableOffsets = [offset];
 
-       for (i = 0; i < numTables; i++) {
 
-         table = tables[tablesNames[i]];
 
-         var paddedLength = (table.length + 3 & ~3) >>> 0;
 
-         offset += paddedLength;
 
-         tableOffsets.push(offset);
 
-       }
 
-       var file = new Uint8Array(offset);
 
-       for (i = 0; i < numTables; i++) {
 
-         table = tables[tablesNames[i]];
 
-         writeData(file, tableOffsets[i], table);
 
-       }
 
-       if (sfnt === "true") {
 
-         sfnt = (0, _util.string32)(0x00010000);
 
-       }
 
-       file[0] = sfnt.charCodeAt(0) & 0xff;
 
-       file[1] = sfnt.charCodeAt(1) & 0xff;
 
-       file[2] = sfnt.charCodeAt(2) & 0xff;
 
-       file[3] = sfnt.charCodeAt(3) & 0xff;
 
-       writeInt16(file, 4, numTables);
 
-       var searchParams = OpenTypeFileBuilder.getSearchParams(numTables, 16);
 
-       writeInt16(file, 6, searchParams.range);
 
-       writeInt16(file, 8, searchParams.entry);
 
-       writeInt16(file, 10, searchParams.rangeShift);
 
-       offset = OTF_HEADER_SIZE;
 
-       for (i = 0; i < numTables; i++) {
 
-         tableName = tablesNames[i];
 
-         file[offset] = tableName.charCodeAt(0) & 0xff;
 
-         file[offset + 1] = tableName.charCodeAt(1) & 0xff;
 
-         file[offset + 2] = tableName.charCodeAt(2) & 0xff;
 
-         file[offset + 3] = tableName.charCodeAt(3) & 0xff;
 
-         var checksum = 0;
 
-         for (j = tableOffsets[i], jj = tableOffsets[i + 1]; j < jj; j += 4) {
 
-           var quad = (0, _core_utils.readUint32)(file, j);
 
-           checksum = checksum + quad >>> 0;
 
-         }
 
-         writeInt32(file, offset + 4, checksum);
 
-         writeInt32(file, offset + 8, tableOffsets[i]);
 
-         writeInt32(file, offset + 12, tables[tableName].length);
 
-         offset += OTF_TABLE_ENTRY_SIZE;
 
-       }
 
-       return file;
 
-     },
 
-     addTable: function OpenTypeFileBuilder_addTable(tag, data) {
 
-       if (tag in this.tables) {
 
-         throw new Error("Table " + tag + " already exists");
 
-       }
 
-       this.tables[tag] = data;
 
-     }
 
-   };
 
-   return OpenTypeFileBuilder;
 
- }();
 
- var Font = function FontClosure() {
 
-   function Font(name, file, properties) {
 
-     var charCode;
 
-     this.name = name;
 
-     this.loadedName = properties.loadedName;
 
-     this.isType3Font = properties.isType3Font;
 
-     this.sizes = [];
 
-     this.missingFile = false;
 
-     this.glyphCache = Object.create(null);
 
-     this.isSerifFont = !!(properties.flags & FontFlags.Serif);
 
-     this.isSymbolicFont = !!(properties.flags & FontFlags.Symbolic);
 
-     this.isMonospace = !!(properties.flags & FontFlags.FixedPitch);
 
-     var type = properties.type;
 
-     var subtype = properties.subtype;
 
-     this.type = type;
 
-     this.subtype = subtype;
 
-     let fallbackName = "sans-serif";
 
-     if (this.isMonospace) {
 
-       fallbackName = "monospace";
 
-     } else if (this.isSerifFont) {
 
-       fallbackName = "serif";
 
-     }
 
-     this.fallbackName = fallbackName;
 
-     this.differences = properties.differences;
 
-     this.widths = properties.widths;
 
-     this.defaultWidth = properties.defaultWidth;
 
-     this.composite = properties.composite;
 
-     this.wideChars = properties.wideChars;
 
-     this.cMap = properties.cMap;
 
-     this.ascent = properties.ascent / PDF_GLYPH_SPACE_UNITS;
 
-     this.descent = properties.descent / PDF_GLYPH_SPACE_UNITS;
 
-     this.fontMatrix = properties.fontMatrix;
 
-     this.bbox = properties.bbox;
 
-     this.defaultEncoding = properties.defaultEncoding;
 
-     this.toUnicode = properties.toUnicode;
 
-     this.fallbackToUnicode = properties.fallbackToUnicode || new ToUnicodeMap();
 
-     this.toFontChar = [];
 
-     if (properties.type === "Type3") {
 
-       for (charCode = 0; charCode < 256; charCode++) {
 
-         this.toFontChar[charCode] = this.differences[charCode] || properties.defaultEncoding[charCode];
 
-       }
 
-       this.fontType = _util.FontType.TYPE3;
 
-       return;
 
-     }
 
-     this.cidEncoding = properties.cidEncoding;
 
-     this.vertical = properties.vertical;
 
-     if (this.vertical) {
 
-       this.vmetrics = properties.vmetrics;
 
-       this.defaultVMetrics = properties.defaultVMetrics;
 
-     }
 
-     if (!file || file.isEmpty) {
 
-       if (file) {
 
-         (0, _util.warn)('Font file is empty in "' + name + '" (' + this.loadedName + ")");
 
-       }
 
-       this.fallbackToSystemFont();
 
-       return;
 
-     }
 
-     [type, subtype] = getFontFileType(file, properties);
 
-     if (type !== this.type || subtype !== this.subtype) {
 
-       (0, _util.info)("Inconsistent font file Type/SubType, expected: " + `${this.type}/${this.subtype} but found: ${type}/${subtype}.`);
 
-     }
 
-     try {
 
-       var data;
 
-       switch (type) {
 
-         case "MMType1":
 
-           (0, _util.info)("MMType1 font (" + name + "), falling back to Type1.");
 
-         case "Type1":
 
-         case "CIDFontType0":
 
-           this.mimetype = "font/opentype";
 
-           var cff = subtype === "Type1C" || subtype === "CIDFontType0C" ? new CFFFont(file, properties) : new Type1Font(name, file, properties);
 
-           adjustWidths(properties);
 
-           data = this.convert(name, cff, properties);
 
-           break;
 
-         case "OpenType":
 
-         case "TrueType":
 
-         case "CIDFontType2":
 
-           this.mimetype = "font/opentype";
 
-           data = this.checkAndRepair(name, file, properties);
 
-           if (this.isOpenType) {
 
-             adjustWidths(properties);
 
-             type = "OpenType";
 
-           }
 
-           break;
 
-         default:
 
-           throw new _util.FormatError(`Font ${type} is not supported`);
 
-       }
 
-     } catch (e) {
 
-       (0, _util.warn)(e);
 
-       this.fallbackToSystemFont();
 
-       return;
 
-     }
 
-     this.data = data;
 
-     this.fontType = getFontType(type, subtype);
 
-     this.fontMatrix = properties.fontMatrix;
 
-     this.widths = properties.widths;
 
-     this.defaultWidth = properties.defaultWidth;
 
-     this.toUnicode = properties.toUnicode;
 
-     this.encoding = properties.baseEncoding;
 
-     this.seacMap = properties.seacMap;
 
-   }
 
-   Font.getFontID = function () {
 
-     var ID = 1;
 
-     return function Font_getFontID() {
 
-       return String(ID++);
 
-     };
 
-   }();
 
-   function int16(b0, b1) {
 
-     return (b0 << 8) + b1;
 
-   }
 
-   function writeSignedInt16(bytes, index, value) {
 
-     bytes[index + 1] = value;
 
-     bytes[index] = value >>> 8;
 
-   }
 
-   function signedInt16(b0, b1) {
 
-     var value = (b0 << 8) + b1;
 
-     return value & 1 << 15 ? value - 0x10000 : value;
 
-   }
 
-   function int32(b0, b1, b2, b3) {
 
-     return (b0 << 24) + (b1 << 16) + (b2 << 8) + b3;
 
-   }
 
-   function string16(value) {
 
-     return String.fromCharCode(value >> 8 & 0xff, value & 0xff);
 
-   }
 
-   function safeString16(value) {
 
-     if (value > 0x7fff) {
 
-       value = 0x7fff;
 
-     } else if (value < -0x8000) {
 
-       value = -0x8000;
 
-     }
 
-     return String.fromCharCode(value >> 8 & 0xff, value & 0xff);
 
-   }
 
-   function isTrueTypeFile(file) {
 
-     var header = file.peekBytes(4);
 
-     return (0, _core_utils.readUint32)(header, 0) === 0x00010000 || (0, _util.bytesToString)(header) === "true";
 
-   }
 
-   function isTrueTypeCollectionFile(file) {
 
-     const header = file.peekBytes(4);
 
-     return (0, _util.bytesToString)(header) === "ttcf";
 
-   }
 
-   function isOpenTypeFile(file) {
 
-     var header = file.peekBytes(4);
 
-     return (0, _util.bytesToString)(header) === "OTTO";
 
-   }
 
-   function isType1File(file) {
 
-     var header = file.peekBytes(2);
 
-     if (header[0] === 0x25 && header[1] === 0x21) {
 
-       return true;
 
-     }
 
-     if (header[0] === 0x80 && header[1] === 0x01) {
 
-       return true;
 
-     }
 
-     return false;
 
-   }
 
-   function isCFFFile(file) {
 
-     const header = file.peekBytes(4);
 
-     if (header[0] >= 1 && header[3] >= 1 && header[3] <= 4) {
 
-       return true;
 
-     }
 
-     return false;
 
-   }
 
-   function getFontFileType(file, {
 
-     type,
 
-     subtype,
 
-     composite
 
-   }) {
 
-     let fileType, fileSubtype;
 
-     if (isTrueTypeFile(file) || isTrueTypeCollectionFile(file)) {
 
-       if (composite) {
 
-         fileType = "CIDFontType2";
 
-       } else {
 
-         fileType = "TrueType";
 
-       }
 
-     } else if (isOpenTypeFile(file)) {
 
-       if (composite) {
 
-         fileType = "CIDFontType2";
 
-       } else {
 
-         fileType = "OpenType";
 
-       }
 
-     } else if (isType1File(file)) {
 
-       if (composite) {
 
-         fileType = "CIDFontType0";
 
-       } else {
 
-         fileType = type === "MMType1" ? "MMType1" : "Type1";
 
-       }
 
-     } else if (isCFFFile(file)) {
 
-       if (composite) {
 
-         fileType = "CIDFontType0";
 
-         fileSubtype = "CIDFontType0C";
 
-       } else {
 
-         fileType = type === "MMType1" ? "MMType1" : "Type1";
 
-         fileSubtype = "Type1C";
 
-       }
 
-     } else {
 
-       (0, _util.warn)("getFontFileType: Unable to detect correct font file Type/Subtype.");
 
-       fileType = type;
 
-       fileSubtype = subtype;
 
-     }
 
-     return [fileType, fileSubtype];
 
-   }
 
-   function buildToFontChar(encoding, glyphsUnicodeMap, differences) {
 
-     var toFontChar = [],
 
-         unicode;
 
-     for (var i = 0, ii = encoding.length; i < ii; i++) {
 
-       unicode = (0, _unicode.getUnicodeForGlyph)(encoding[i], glyphsUnicodeMap);
 
-       if (unicode !== -1) {
 
-         toFontChar[i] = unicode;
 
-       }
 
-     }
 
-     for (var charCode in differences) {
 
-       unicode = (0, _unicode.getUnicodeForGlyph)(differences[charCode], glyphsUnicodeMap);
 
-       if (unicode !== -1) {
 
-         toFontChar[+charCode] = unicode;
 
-       }
 
-     }
 
-     return toFontChar;
 
-   }
 
-   function adjustMapping(charCodeToGlyphId, hasGlyph, newGlyphZeroId) {
 
-     var newMap = Object.create(null);
 
-     var toFontChar = [];
 
-     var privateUseAreaIndex = 0;
 
-     var nextAvailableFontCharCode = PRIVATE_USE_AREAS[privateUseAreaIndex][0];
 
-     var privateUseOffetEnd = PRIVATE_USE_AREAS[privateUseAreaIndex][1];
 
-     for (var originalCharCode in charCodeToGlyphId) {
 
-       originalCharCode |= 0;
 
-       var glyphId = charCodeToGlyphId[originalCharCode];
 
-       if (!hasGlyph(glyphId)) {
 
-         continue;
 
-       }
 
-       if (nextAvailableFontCharCode > privateUseOffetEnd) {
 
-         privateUseAreaIndex++;
 
-         if (privateUseAreaIndex >= PRIVATE_USE_AREAS.length) {
 
-           (0, _util.warn)("Ran out of space in font private use area.");
 
-           break;
 
-         }
 
-         nextAvailableFontCharCode = PRIVATE_USE_AREAS[privateUseAreaIndex][0];
 
-         privateUseOffetEnd = PRIVATE_USE_AREAS[privateUseAreaIndex][1];
 
-       }
 
-       var fontCharCode = nextAvailableFontCharCode++;
 
-       if (glyphId === 0) {
 
-         glyphId = newGlyphZeroId;
 
-       }
 
-       newMap[fontCharCode] = glyphId;
 
-       toFontChar[originalCharCode] = fontCharCode;
 
-     }
 
-     return {
 
-       toFontChar,
 
-       charCodeToGlyphId: newMap,
 
-       nextAvailableFontCharCode
 
-     };
 
-   }
 
-   function getRanges(glyphs, numGlyphs) {
 
-     var codes = [];
 
-     for (var charCode in glyphs) {
 
-       if (glyphs[charCode] >= numGlyphs) {
 
-         continue;
 
-       }
 
-       codes.push({
 
-         fontCharCode: charCode | 0,
 
-         glyphId: glyphs[charCode]
 
-       });
 
-     }
 
-     if (codes.length === 0) {
 
-       codes.push({
 
-         fontCharCode: 0,
 
-         glyphId: 0
 
-       });
 
-     }
 
-     codes.sort(function fontGetRangesSort(a, b) {
 
-       return a.fontCharCode - b.fontCharCode;
 
-     });
 
-     var ranges = [];
 
-     var length = codes.length;
 
-     for (var n = 0; n < length;) {
 
-       var start = codes[n].fontCharCode;
 
-       var codeIndices = [codes[n].glyphId];
 
-       ++n;
 
-       var end = start;
 
-       while (n < length && end + 1 === codes[n].fontCharCode) {
 
-         codeIndices.push(codes[n].glyphId);
 
-         ++end;
 
-         ++n;
 
-         if (end === 0xffff) {
 
-           break;
 
-         }
 
-       }
 
-       ranges.push([start, end, codeIndices]);
 
-     }
 
-     return ranges;
 
-   }
 
-   function createCmapTable(glyphs, numGlyphs) {
 
-     var ranges = getRanges(glyphs, numGlyphs);
 
-     var numTables = ranges[ranges.length - 1][1] > 0xffff ? 2 : 1;
 
-     var cmap = "\x00\x00" + string16(numTables) + "\x00\x03" + "\x00\x01" + (0, _util.string32)(4 + numTables * 8);
 
-     var i, ii, j, jj;
 
-     for (i = ranges.length - 1; i >= 0; --i) {
 
-       if (ranges[i][0] <= 0xffff) {
 
-         break;
 
-       }
 
-     }
 
-     var bmpLength = i + 1;
 
-     if (ranges[i][0] < 0xffff && ranges[i][1] === 0xffff) {
 
-       ranges[i][1] = 0xfffe;
 
-     }
 
-     var trailingRangesCount = ranges[i][1] < 0xffff ? 1 : 0;
 
-     var segCount = bmpLength + trailingRangesCount;
 
-     var searchParams = OpenTypeFileBuilder.getSearchParams(segCount, 2);
 
-     var startCount = "";
 
-     var endCount = "";
 
-     var idDeltas = "";
 
-     var idRangeOffsets = "";
 
-     var glyphsIds = "";
 
-     var bias = 0;
 
-     var range, start, end, codes;
 
-     for (i = 0, ii = bmpLength; i < ii; i++) {
 
-       range = ranges[i];
 
-       start = range[0];
 
-       end = range[1];
 
-       startCount += string16(start);
 
-       endCount += string16(end);
 
-       codes = range[2];
 
-       var contiguous = true;
 
-       for (j = 1, jj = codes.length; j < jj; ++j) {
 
-         if (codes[j] !== codes[j - 1] + 1) {
 
-           contiguous = false;
 
-           break;
 
-         }
 
-       }
 
-       if (!contiguous) {
 
-         var offset = (segCount - i) * 2 + bias * 2;
 
-         bias += end - start + 1;
 
-         idDeltas += string16(0);
 
-         idRangeOffsets += string16(offset);
 
-         for (j = 0, jj = codes.length; j < jj; ++j) {
 
-           glyphsIds += string16(codes[j]);
 
-         }
 
-       } else {
 
-         var startCode = codes[0];
 
-         idDeltas += string16(startCode - start & 0xffff);
 
-         idRangeOffsets += string16(0);
 
-       }
 
-     }
 
-     if (trailingRangesCount > 0) {
 
-       endCount += "\xFF\xFF";
 
-       startCount += "\xFF\xFF";
 
-       idDeltas += "\x00\x01";
 
-       idRangeOffsets += "\x00\x00";
 
-     }
 
-     var format314 = "\x00\x00" + string16(2 * segCount) + string16(searchParams.range) + string16(searchParams.entry) + string16(searchParams.rangeShift) + endCount + "\x00\x00" + startCount + idDeltas + idRangeOffsets + glyphsIds;
 
-     var format31012 = "";
 
-     var header31012 = "";
 
-     if (numTables > 1) {
 
-       cmap += "\x00\x03" + "\x00\x0A" + (0, _util.string32)(4 + numTables * 8 + 4 + format314.length);
 
-       format31012 = "";
 
-       for (i = 0, ii = ranges.length; i < ii; i++) {
 
-         range = ranges[i];
 
-         start = range[0];
 
-         codes = range[2];
 
-         var code = codes[0];
 
-         for (j = 1, jj = codes.length; j < jj; ++j) {
 
-           if (codes[j] !== codes[j - 1] + 1) {
 
-             end = range[0] + j - 1;
 
-             format31012 += (0, _util.string32)(start) + (0, _util.string32)(end) + (0, _util.string32)(code);
 
-             start = end + 1;
 
-             code = codes[j];
 
-           }
 
-         }
 
-         format31012 += (0, _util.string32)(start) + (0, _util.string32)(range[1]) + (0, _util.string32)(code);
 
-       }
 
-       header31012 = "\x00\x0C" + "\x00\x00" + (0, _util.string32)(format31012.length + 16) + "\x00\x00\x00\x00" + (0, _util.string32)(format31012.length / 12);
 
-     }
 
-     return cmap + "\x00\x04" + string16(format314.length + 4) + format314 + header31012 + format31012;
 
-   }
 
-   function validateOS2Table(os2) {
 
-     var stream = new _stream.Stream(os2.data);
 
-     var version = stream.getUint16();
 
-     stream.getBytes(60);
 
-     var selection = stream.getUint16();
 
-     if (version < 4 && selection & 0x0300) {
 
-       return false;
 
-     }
 
-     var firstChar = stream.getUint16();
 
-     var lastChar = stream.getUint16();
 
-     if (firstChar > lastChar) {
 
-       return false;
 
-     }
 
-     stream.getBytes(6);
 
-     var usWinAscent = stream.getUint16();
 
-     if (usWinAscent === 0) {
 
-       return false;
 
-     }
 
-     os2.data[8] = os2.data[9] = 0;
 
-     return true;
 
-   }
 
-   function createOS2Table(properties, charstrings, override) {
 
-     override = override || {
 
-       unitsPerEm: 0,
 
-       yMax: 0,
 
-       yMin: 0,
 
-       ascent: 0,
 
-       descent: 0
 
-     };
 
-     var ulUnicodeRange1 = 0;
 
-     var ulUnicodeRange2 = 0;
 
-     var ulUnicodeRange3 = 0;
 
-     var ulUnicodeRange4 = 0;
 
-     var firstCharIndex = null;
 
-     var lastCharIndex = 0;
 
-     if (charstrings) {
 
-       for (var code in charstrings) {
 
-         code |= 0;
 
-         if (firstCharIndex > code || !firstCharIndex) {
 
-           firstCharIndex = code;
 
-         }
 
-         if (lastCharIndex < code) {
 
-           lastCharIndex = code;
 
-         }
 
-         var position = (0, _unicode.getUnicodeRangeFor)(code);
 
-         if (position < 32) {
 
-           ulUnicodeRange1 |= 1 << position;
 
-         } else if (position < 64) {
 
-           ulUnicodeRange2 |= 1 << position - 32;
 
-         } else if (position < 96) {
 
-           ulUnicodeRange3 |= 1 << position - 64;
 
-         } else if (position < 123) {
 
-           ulUnicodeRange4 |= 1 << position - 96;
 
-         } else {
 
-           throw new _util.FormatError("Unicode ranges Bits > 123 are reserved for internal usage");
 
-         }
 
-       }
 
-       if (lastCharIndex > 0xffff) {
 
-         lastCharIndex = 0xffff;
 
-       }
 
-     } else {
 
-       firstCharIndex = 0;
 
-       lastCharIndex = 255;
 
-     }
 
-     var bbox = properties.bbox || [0, 0, 0, 0];
 
-     var unitsPerEm = override.unitsPerEm || 1 / (properties.fontMatrix || _util.FONT_IDENTITY_MATRIX)[0];
 
-     var scale = properties.ascentScaled ? 1.0 : unitsPerEm / PDF_GLYPH_SPACE_UNITS;
 
-     var typoAscent = override.ascent || Math.round(scale * (properties.ascent || bbox[3]));
 
-     var typoDescent = override.descent || Math.round(scale * (properties.descent || bbox[1]));
 
-     if (typoDescent > 0 && properties.descent > 0 && bbox[1] < 0) {
 
-       typoDescent = -typoDescent;
 
-     }
 
-     var winAscent = override.yMax || typoAscent;
 
-     var winDescent = -override.yMin || -typoDescent;
 
-     return "\x00\x03" + "\x02\x24" + "\x01\xF4" + "\x00\x05" + "\x00\x00" + "\x02\x8A" + "\x02\xBB" + "\x00\x00" + "\x00\x8C" + "\x02\x8A" + "\x02\xBB" + "\x00\x00" + "\x01\xDF" + "\x00\x31" + "\x01\x02" + "\x00\x00" + "\x00\x00\x06" + String.fromCharCode(properties.fixedPitch ? 0x09 : 0x00) + "\x00\x00\x00\x00\x00\x00" + (0, _util.string32)(ulUnicodeRange1) + (0, _util.string32)(ulUnicodeRange2) + (0, _util.string32)(ulUnicodeRange3) + (0, _util.string32)(ulUnicodeRange4) + "\x2A\x32\x31\x2A" + string16(properties.italicAngle ? 1 : 0) + string16(firstCharIndex || properties.firstChar) + string16(lastCharIndex || properties.lastChar) + string16(typoAscent) + string16(typoDescent) + "\x00\x64" + string16(winAscent) + string16(winDescent) + "\x00\x00\x00\x00" + "\x00\x00\x00\x00" + string16(properties.xHeight) + string16(properties.capHeight) + string16(0) + string16(firstCharIndex || properties.firstChar) + "\x00\x03";
 
-   }
 
-   function createPostTable(properties) {
 
-     var angle = Math.floor(properties.italicAngle * 2 ** 16);
 
-     return "\x00\x03\x00\x00" + (0, _util.string32)(angle) + "\x00\x00" + "\x00\x00" + (0, _util.string32)(properties.fixedPitch) + "\x00\x00\x00\x00" + "\x00\x00\x00\x00" + "\x00\x00\x00\x00" + "\x00\x00\x00\x00";
 
-   }
 
-   function createNameTable(name, proto) {
 
-     if (!proto) {
 
-       proto = [[], []];
 
-     }
 
-     var strings = [proto[0][0] || "Original licence", proto[0][1] || name, proto[0][2] || "Unknown", proto[0][3] || "uniqueID", proto[0][4] || name, proto[0][5] || "Version 0.11", proto[0][6] || "", proto[0][7] || "Unknown", proto[0][8] || "Unknown", proto[0][9] || "Unknown"];
 
-     var stringsUnicode = [];
 
-     var i, ii, j, jj, str;
 
-     for (i = 0, ii = strings.length; i < ii; i++) {
 
-       str = proto[1][i] || strings[i];
 
-       var strBufUnicode = [];
 
-       for (j = 0, jj = str.length; j < jj; j++) {
 
-         strBufUnicode.push(string16(str.charCodeAt(j)));
 
-       }
 
-       stringsUnicode.push(strBufUnicode.join(""));
 
-     }
 
-     var names = [strings, stringsUnicode];
 
-     var platforms = ["\x00\x01", "\x00\x03"];
 
-     var encodings = ["\x00\x00", "\x00\x01"];
 
-     var languages = ["\x00\x00", "\x04\x09"];
 
-     var namesRecordCount = strings.length * platforms.length;
 
-     var nameTable = "\x00\x00" + string16(namesRecordCount) + string16(namesRecordCount * 12 + 6);
 
-     var strOffset = 0;
 
-     for (i = 0, ii = platforms.length; i < ii; i++) {
 
-       var strs = names[i];
 
-       for (j = 0, jj = strs.length; j < jj; j++) {
 
-         str = strs[j];
 
-         var nameRecord = platforms[i] + encodings[i] + languages[i] + string16(j) + string16(str.length) + string16(strOffset);
 
-         nameTable += nameRecord;
 
-         strOffset += str.length;
 
-       }
 
-     }
 
-     nameTable += strings.join("") + stringsUnicode.join("");
 
-     return nameTable;
 
-   }
 
-   Font.prototype = {
 
-     name: null,
 
-     font: null,
 
-     mimetype: null,
 
-     encoding: null,
 
-     disableFontFace: false,
 
-     get renderer() {
 
-       var renderer = _font_renderer.FontRendererFactory.create(this, SEAC_ANALYSIS_ENABLED);
 
-       return (0, _util.shadow)(this, "renderer", renderer);
 
-     },
 
-     exportData: function Font_exportData() {
 
-       var data = {};
 
-       for (var i in this) {
 
-         if (this.hasOwnProperty(i)) {
 
-           data[i] = this[i];
 
-         }
 
-       }
 
-       return data;
 
-     },
 
-     fallbackToSystemFont: function Font_fallbackToSystemFont() {
 
-       this.missingFile = true;
 
-       var charCode, unicode;
 
-       var name = this.name;
 
-       var type = this.type;
 
-       var subtype = this.subtype;
 
-       let fontName = name.replace(/[,_]/g, "-").replace(/\s/g, "");
 
-       var stdFontMap = (0, _standard_fonts.getStdFontMap)(),
 
-           nonStdFontMap = (0, _standard_fonts.getNonStdFontMap)();
 
-       var isStandardFont = !!stdFontMap[fontName] || !!(nonStdFontMap[fontName] && stdFontMap[nonStdFontMap[fontName]]);
 
-       fontName = stdFontMap[fontName] || nonStdFontMap[fontName] || fontName;
 
-       this.bold = fontName.search(/bold/gi) !== -1;
 
-       this.italic = fontName.search(/oblique/gi) !== -1 || fontName.search(/italic/gi) !== -1;
 
-       this.black = name.search(/Black/g) !== -1;
 
-       this.remeasure = Object.keys(this.widths).length > 0;
 
-       if (isStandardFont && type === "CIDFontType2" && this.cidEncoding.startsWith("Identity-")) {
 
-         const GlyphMapForStandardFonts = (0, _standard_fonts.getGlyphMapForStandardFonts)();
 
-         const map = [];
 
-         for (charCode in GlyphMapForStandardFonts) {
 
-           map[+charCode] = GlyphMapForStandardFonts[charCode];
 
-         }
 
-         if (/Arial-?Black/i.test(name)) {
 
-           var SupplementalGlyphMapForArialBlack = (0, _standard_fonts.getSupplementalGlyphMapForArialBlack)();
 
-           for (charCode in SupplementalGlyphMapForArialBlack) {
 
-             map[+charCode] = SupplementalGlyphMapForArialBlack[charCode];
 
-           }
 
-         } else if (/Calibri/i.test(name)) {
 
-           const SupplementalGlyphMapForCalibri = (0, _standard_fonts.getSupplementalGlyphMapForCalibri)();
 
-           for (charCode in SupplementalGlyphMapForCalibri) {
 
-             map[+charCode] = SupplementalGlyphMapForCalibri[charCode];
 
-           }
 
-         }
 
-         var isIdentityUnicode = this.toUnicode instanceof IdentityToUnicodeMap;
 
-         if (!isIdentityUnicode) {
 
-           this.toUnicode.forEach(function (charCode, unicodeCharCode) {
 
-             map[+charCode] = unicodeCharCode;
 
-           });
 
-         }
 
-         this.toFontChar = map;
 
-         this.toUnicode = new ToUnicodeMap(map);
 
-       } else if (/Symbol/i.test(fontName)) {
 
-         this.toFontChar = buildToFontChar(_encodings.SymbolSetEncoding, (0, _glyphlist.getGlyphsUnicode)(), this.differences);
 
-       } else if (/Dingbats/i.test(fontName)) {
 
-         if (/Wingdings/i.test(name)) {
 
-           (0, _util.warn)("Non-embedded Wingdings font, falling back to ZapfDingbats.");
 
-         }
 
-         this.toFontChar = buildToFontChar(_encodings.ZapfDingbatsEncoding, (0, _glyphlist.getDingbatsGlyphsUnicode)(), this.differences);
 
-       } else if (isStandardFont) {
 
-         this.toFontChar = buildToFontChar(this.defaultEncoding, (0, _glyphlist.getGlyphsUnicode)(), this.differences);
 
-       } else {
 
-         const glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-         const map = [];
 
-         this.toUnicode.forEach((charCode, unicodeCharCode) => {
 
-           if (!this.composite) {
 
-             var glyphName = this.differences[charCode] || this.defaultEncoding[charCode];
 
-             unicode = (0, _unicode.getUnicodeForGlyph)(glyphName, glyphsUnicodeMap);
 
-             if (unicode !== -1) {
 
-               unicodeCharCode = unicode;
 
-             }
 
-           }
 
-           map[+charCode] = unicodeCharCode;
 
-         });
 
-         if (this.composite && this.toUnicode instanceof IdentityToUnicodeMap) {
 
-           if (/Verdana/i.test(name)) {
 
-             const GlyphMapForStandardFonts = (0, _standard_fonts.getGlyphMapForStandardFonts)();
 
-             for (charCode in GlyphMapForStandardFonts) {
 
-               map[+charCode] = GlyphMapForStandardFonts[charCode];
 
-             }
 
-           }
 
-         }
 
-         this.toFontChar = map;
 
-       }
 
-       this.loadedName = fontName.split("-")[0];
 
-       this.fontType = getFontType(type, subtype);
 
-     },
 
-     checkAndRepair: function Font_checkAndRepair(name, font, properties) {
 
-       const VALID_TABLES = ["OS/2", "cmap", "head", "hhea", "hmtx", "maxp", "name", "post", "loca", "glyf", "fpgm", "prep", "cvt ", "CFF "];
 
-       function readTables(file, numTables) {
 
-         const tables = Object.create(null);
 
-         tables["OS/2"] = null;
 
-         tables["cmap"] = null;
 
-         tables["head"] = null;
 
-         tables["hhea"] = null;
 
-         tables["hmtx"] = null;
 
-         tables["maxp"] = null;
 
-         tables["name"] = null;
 
-         tables["post"] = null;
 
-         for (let i = 0; i < numTables; i++) {
 
-           const table = readTableEntry(font);
 
-           if (!VALID_TABLES.includes(table.tag)) {
 
-             continue;
 
-           }
 
-           if (table.length === 0) {
 
-             continue;
 
-           }
 
-           tables[table.tag] = table;
 
-         }
 
-         return tables;
 
-       }
 
-       function readTableEntry(file) {
 
-         var tag = (0, _util.bytesToString)(file.getBytes(4));
 
-         var checksum = file.getInt32() >>> 0;
 
-         var offset = file.getInt32() >>> 0;
 
-         var length = file.getInt32() >>> 0;
 
-         var previousPosition = file.pos;
 
-         file.pos = file.start ? file.start : 0;
 
-         file.skip(offset);
 
-         var data = file.getBytes(length);
 
-         file.pos = previousPosition;
 
-         if (tag === "head") {
 
-           data[8] = data[9] = data[10] = data[11] = 0;
 
-           data[17] |= 0x20;
 
-         }
 
-         return {
 
-           tag,
 
-           checksum,
 
-           length,
 
-           offset,
 
-           data
 
-         };
 
-       }
 
-       function readOpenTypeHeader(ttf) {
 
-         return {
 
-           version: (0, _util.bytesToString)(ttf.getBytes(4)),
 
-           numTables: ttf.getUint16(),
 
-           searchRange: ttf.getUint16(),
 
-           entrySelector: ttf.getUint16(),
 
-           rangeShift: ttf.getUint16()
 
-         };
 
-       }
 
-       function readTrueTypeCollectionHeader(ttc) {
 
-         const ttcTag = (0, _util.bytesToString)(ttc.getBytes(4));
 
-         (0, _util.assert)(ttcTag === "ttcf", "Must be a TrueType Collection font.");
 
-         const majorVersion = ttc.getUint16();
 
-         const minorVersion = ttc.getUint16();
 
-         const numFonts = ttc.getInt32() >>> 0;
 
-         const offsetTable = [];
 
-         for (let i = 0; i < numFonts; i++) {
 
-           offsetTable.push(ttc.getInt32() >>> 0);
 
-         }
 
-         const header = {
 
-           ttcTag,
 
-           majorVersion,
 
-           minorVersion,
 
-           numFonts,
 
-           offsetTable
 
-         };
 
-         switch (majorVersion) {
 
-           case 1:
 
-             return header;
 
-           case 2:
 
-             header.dsigTag = ttc.getInt32() >>> 0;
 
-             header.dsigLength = ttc.getInt32() >>> 0;
 
-             header.dsigOffset = ttc.getInt32() >>> 0;
 
-             return header;
 
-         }
 
-         throw new _util.FormatError(`Invalid TrueType Collection majorVersion: ${majorVersion}.`);
 
-       }
 
-       function readTrueTypeCollectionData(ttc, fontName) {
 
-         const {
 
-           numFonts,
 
-           offsetTable
 
-         } = readTrueTypeCollectionHeader(ttc);
 
-         for (let i = 0; i < numFonts; i++) {
 
-           ttc.pos = (ttc.start || 0) + offsetTable[i];
 
-           const potentialHeader = readOpenTypeHeader(ttc);
 
-           const potentialTables = readTables(ttc, potentialHeader.numTables);
 
-           if (!potentialTables["name"]) {
 
-             throw new _util.FormatError('TrueType Collection font must contain a "name" table.');
 
-           }
 
-           const nameTable = readNameTable(potentialTables["name"]);
 
-           for (let j = 0, jj = nameTable.length; j < jj; j++) {
 
-             for (let k = 0, kk = nameTable[j].length; k < kk; k++) {
 
-               const nameEntry = nameTable[j][k];
 
-               if (nameEntry && nameEntry.replace(/\s/g, "") === fontName) {
 
-                 return {
 
-                   header: potentialHeader,
 
-                   tables: potentialTables
 
-                 };
 
-               }
 
-             }
 
-           }
 
-         }
 
-         throw new _util.FormatError(`TrueType Collection does not contain "${fontName}" font.`);
 
-       }
 
-       function readCmapTable(cmap, font, isSymbolicFont, hasEncoding) {
 
-         if (!cmap) {
 
-           (0, _util.warn)("No cmap table available.");
 
-           return {
 
-             platformId: -1,
 
-             encodingId: -1,
 
-             mappings: [],
 
-             hasShortCmap: false
 
-           };
 
-         }
 
-         var segment;
 
-         var start = (font.start ? font.start : 0) + cmap.offset;
 
-         font.pos = start;
 
-         font.getUint16();
 
-         var numTables = font.getUint16();
 
-         var potentialTable;
 
-         var canBreak = false;
 
-         for (var i = 0; i < numTables; i++) {
 
-           var platformId = font.getUint16();
 
-           var encodingId = font.getUint16();
 
-           var offset = font.getInt32() >>> 0;
 
-           var useTable = false;
 
-           if (potentialTable && potentialTable.platformId === platformId && potentialTable.encodingId === encodingId) {
 
-             continue;
 
-           }
 
-           if (platformId === 0 && encodingId === 0) {
 
-             useTable = true;
 
-           } else if (platformId === 1 && encodingId === 0) {
 
-             useTable = true;
 
-           } else if (platformId === 3 && encodingId === 1 && (hasEncoding || !potentialTable)) {
 
-             useTable = true;
 
-             if (!isSymbolicFont) {
 
-               canBreak = true;
 
-             }
 
-           } else if (isSymbolicFont && platformId === 3 && encodingId === 0) {
 
-             useTable = true;
 
-             canBreak = true;
 
-           }
 
-           if (useTable) {
 
-             potentialTable = {
 
-               platformId,
 
-               encodingId,
 
-               offset
 
-             };
 
-           }
 
-           if (canBreak) {
 
-             break;
 
-           }
 
-         }
 
-         if (potentialTable) {
 
-           font.pos = start + potentialTable.offset;
 
-         }
 
-         if (!potentialTable || font.peekByte() === -1) {
 
-           (0, _util.warn)("Could not find a preferred cmap table.");
 
-           return {
 
-             platformId: -1,
 
-             encodingId: -1,
 
-             mappings: [],
 
-             hasShortCmap: false
 
-           };
 
-         }
 
-         var format = font.getUint16();
 
-         font.getUint16();
 
-         font.getUint16();
 
-         var hasShortCmap = false;
 
-         var mappings = [];
 
-         var j, glyphId;
 
-         if (format === 0) {
 
-           for (j = 0; j < 256; j++) {
 
-             var index = font.getByte();
 
-             if (!index) {
 
-               continue;
 
-             }
 
-             mappings.push({
 
-               charCode: j,
 
-               glyphId: index
 
-             });
 
-           }
 
-           hasShortCmap = true;
 
-         } else if (format === 4) {
 
-           var segCount = font.getUint16() >> 1;
 
-           font.getBytes(6);
 
-           var segIndex,
 
-               segments = [];
 
-           for (segIndex = 0; segIndex < segCount; segIndex++) {
 
-             segments.push({
 
-               end: font.getUint16()
 
-             });
 
-           }
 
-           font.getUint16();
 
-           for (segIndex = 0; segIndex < segCount; segIndex++) {
 
-             segments[segIndex].start = font.getUint16();
 
-           }
 
-           for (segIndex = 0; segIndex < segCount; segIndex++) {
 
-             segments[segIndex].delta = font.getUint16();
 
-           }
 
-           var offsetsCount = 0;
 
-           for (segIndex = 0; segIndex < segCount; segIndex++) {
 
-             segment = segments[segIndex];
 
-             var rangeOffset = font.getUint16();
 
-             if (!rangeOffset) {
 
-               segment.offsetIndex = -1;
 
-               continue;
 
-             }
 
-             var offsetIndex = (rangeOffset >> 1) - (segCount - segIndex);
 
-             segment.offsetIndex = offsetIndex;
 
-             offsetsCount = Math.max(offsetsCount, offsetIndex + segment.end - segment.start + 1);
 
-           }
 
-           var offsets = [];
 
-           for (j = 0; j < offsetsCount; j++) {
 
-             offsets.push(font.getUint16());
 
-           }
 
-           for (segIndex = 0; segIndex < segCount; segIndex++) {
 
-             segment = segments[segIndex];
 
-             start = segment.start;
 
-             var end = segment.end;
 
-             var delta = segment.delta;
 
-             offsetIndex = segment.offsetIndex;
 
-             for (j = start; j <= end; j++) {
 
-               if (j === 0xffff) {
 
-                 continue;
 
-               }
 
-               glyphId = offsetIndex < 0 ? j : offsets[offsetIndex + j - start];
 
-               glyphId = glyphId + delta & 0xffff;
 
-               mappings.push({
 
-                 charCode: j,
 
-                 glyphId
 
-               });
 
-             }
 
-           }
 
-         } else if (format === 6) {
 
-           var firstCode = font.getUint16();
 
-           var entryCount = font.getUint16();
 
-           for (j = 0; j < entryCount; j++) {
 
-             glyphId = font.getUint16();
 
-             var charCode = firstCode + j;
 
-             mappings.push({
 
-               charCode,
 
-               glyphId
 
-             });
 
-           }
 
-         } else {
 
-           (0, _util.warn)("cmap table has unsupported format: " + format);
 
-           return {
 
-             platformId: -1,
 
-             encodingId: -1,
 
-             mappings: [],
 
-             hasShortCmap: false
 
-           };
 
-         }
 
-         mappings.sort(function (a, b) {
 
-           return a.charCode - b.charCode;
 
-         });
 
-         for (i = 1; i < mappings.length; i++) {
 
-           if (mappings[i - 1].charCode === mappings[i].charCode) {
 
-             mappings.splice(i, 1);
 
-             i--;
 
-           }
 
-         }
 
-         return {
 
-           platformId: potentialTable.platformId,
 
-           encodingId: potentialTable.encodingId,
 
-           mappings,
 
-           hasShortCmap
 
-         };
 
-       }
 
-       function sanitizeMetrics(font, header, metrics, numGlyphs, dupFirstEntry) {
 
-         if (!header) {
 
-           if (metrics) {
 
-             metrics.data = null;
 
-           }
 
-           return;
 
-         }
 
-         font.pos = (font.start ? font.start : 0) + header.offset;
 
-         font.pos += 4;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 2;
 
-         font.pos += 8;
 
-         font.pos += 2;
 
-         var numOfMetrics = font.getUint16();
 
-         if (numOfMetrics > numGlyphs) {
 
-           (0, _util.info)("The numOfMetrics (" + numOfMetrics + ") should not be " + "greater than the numGlyphs (" + numGlyphs + ")");
 
-           numOfMetrics = numGlyphs;
 
-           header.data[34] = (numOfMetrics & 0xff00) >> 8;
 
-           header.data[35] = numOfMetrics & 0x00ff;
 
-         }
 
-         var numOfSidebearings = numGlyphs - numOfMetrics;
 
-         var numMissing = numOfSidebearings - (metrics.length - numOfMetrics * 4 >> 1);
 
-         if (numMissing > 0) {
 
-           var entries = new Uint8Array(metrics.length + numMissing * 2);
 
-           entries.set(metrics.data);
 
-           if (dupFirstEntry) {
 
-             entries[metrics.length] = metrics.data[2];
 
-             entries[metrics.length + 1] = metrics.data[3];
 
-           }
 
-           metrics.data = entries;
 
-         }
 
-       }
 
-       function sanitizeGlyph(source, sourceStart, sourceEnd, dest, destStart, hintsValid) {
 
-         var glyphProfile = {
 
-           length: 0,
 
-           sizeOfInstructions: 0
 
-         };
 
-         if (sourceEnd - sourceStart <= 12) {
 
-           return glyphProfile;
 
-         }
 
-         var glyf = source.subarray(sourceStart, sourceEnd);
 
-         var contoursCount = signedInt16(glyf[0], glyf[1]);
 
-         if (contoursCount < 0) {
 
-           contoursCount = -1;
 
-           writeSignedInt16(glyf, 0, contoursCount);
 
-           dest.set(glyf, destStart);
 
-           glyphProfile.length = glyf.length;
 
-           return glyphProfile;
 
-         }
 
-         var i,
 
-             j = 10,
 
-             flagsCount = 0;
 
-         for (i = 0; i < contoursCount; i++) {
 
-           var endPoint = glyf[j] << 8 | glyf[j + 1];
 
-           flagsCount = endPoint + 1;
 
-           j += 2;
 
-         }
 
-         var instructionsStart = j;
 
-         var instructionsLength = glyf[j] << 8 | glyf[j + 1];
 
-         glyphProfile.sizeOfInstructions = instructionsLength;
 
-         j += 2 + instructionsLength;
 
-         var instructionsEnd = j;
 
-         var coordinatesLength = 0;
 
-         for (i = 0; i < flagsCount; i++) {
 
-           var flag = glyf[j++];
 
-           if (flag & 0xc0) {
 
-             glyf[j - 1] = flag & 0x3f;
 
-           }
 
-           let xLength = 2;
 
-           if (flag & 2) {
 
-             xLength = 1;
 
-           } else if (flag & 16) {
 
-             xLength = 0;
 
-           }
 
-           let yLength = 2;
 
-           if (flag & 4) {
 
-             yLength = 1;
 
-           } else if (flag & 32) {
 
-             yLength = 0;
 
-           }
 
-           const xyLength = xLength + yLength;
 
-           coordinatesLength += xyLength;
 
-           if (flag & 8) {
 
-             var repeat = glyf[j++];
 
-             i += repeat;
 
-             coordinatesLength += repeat * xyLength;
 
-           }
 
-         }
 
-         if (coordinatesLength === 0) {
 
-           return glyphProfile;
 
-         }
 
-         var glyphDataLength = j + coordinatesLength;
 
-         if (glyphDataLength > glyf.length) {
 
-           return glyphProfile;
 
-         }
 
-         if (!hintsValid && instructionsLength > 0) {
 
-           dest.set(glyf.subarray(0, instructionsStart), destStart);
 
-           dest.set([0, 0], destStart + instructionsStart);
 
-           dest.set(glyf.subarray(instructionsEnd, glyphDataLength), destStart + instructionsStart + 2);
 
-           glyphDataLength -= instructionsLength;
 
-           if (glyf.length - glyphDataLength > 3) {
 
-             glyphDataLength = glyphDataLength + 3 & ~3;
 
-           }
 
-           glyphProfile.length = glyphDataLength;
 
-           return glyphProfile;
 
-         }
 
-         if (glyf.length - glyphDataLength > 3) {
 
-           glyphDataLength = glyphDataLength + 3 & ~3;
 
-           dest.set(glyf.subarray(0, glyphDataLength), destStart);
 
-           glyphProfile.length = glyphDataLength;
 
-           return glyphProfile;
 
-         }
 
-         dest.set(glyf, destStart);
 
-         glyphProfile.length = glyf.length;
 
-         return glyphProfile;
 
-       }
 
-       function sanitizeHead(head, numGlyphs, locaLength) {
 
-         var data = head.data;
 
-         var version = int32(data[0], data[1], data[2], data[3]);
 
-         if (version >> 16 !== 1) {
 
-           (0, _util.info)("Attempting to fix invalid version in head table: " + version);
 
-           data[0] = 0;
 
-           data[1] = 1;
 
-           data[2] = 0;
 
-           data[3] = 0;
 
-         }
 
-         var indexToLocFormat = int16(data[50], data[51]);
 
-         if (indexToLocFormat < 0 || indexToLocFormat > 1) {
 
-           (0, _util.info)("Attempting to fix invalid indexToLocFormat in head table: " + indexToLocFormat);
 
-           var numGlyphsPlusOne = numGlyphs + 1;
 
-           if (locaLength === numGlyphsPlusOne << 1) {
 
-             data[50] = 0;
 
-             data[51] = 0;
 
-           } else if (locaLength === numGlyphsPlusOne << 2) {
 
-             data[50] = 0;
 
-             data[51] = 1;
 
-           } else {
 
-             throw new _util.FormatError("Could not fix indexToLocFormat: " + indexToLocFormat);
 
-           }
 
-         }
 
-       }
 
-       function sanitizeGlyphLocations(loca, glyf, numGlyphs, isGlyphLocationsLong, hintsValid, dupFirstEntry, maxSizeOfInstructions) {
 
-         var itemSize, itemDecode, itemEncode;
 
-         if (isGlyphLocationsLong) {
 
-           itemSize = 4;
 
-           itemDecode = function fontItemDecodeLong(data, offset) {
 
-             return data[offset] << 24 | data[offset + 1] << 16 | data[offset + 2] << 8 | data[offset + 3];
 
-           };
 
-           itemEncode = function fontItemEncodeLong(data, offset, value) {
 
-             data[offset] = value >>> 24 & 0xff;
 
-             data[offset + 1] = value >> 16 & 0xff;
 
-             data[offset + 2] = value >> 8 & 0xff;
 
-             data[offset + 3] = value & 0xff;
 
-           };
 
-         } else {
 
-           itemSize = 2;
 
-           itemDecode = function fontItemDecode(data, offset) {
 
-             return data[offset] << 9 | data[offset + 1] << 1;
 
-           };
 
-           itemEncode = function fontItemEncode(data, offset, value) {
 
-             data[offset] = value >> 9 & 0xff;
 
-             data[offset + 1] = value >> 1 & 0xff;
 
-           };
 
-         }
 
-         var numGlyphsOut = dupFirstEntry ? numGlyphs + 1 : numGlyphs;
 
-         var locaDataSize = itemSize * (1 + numGlyphsOut);
 
-         var locaData = new Uint8Array(locaDataSize);
 
-         locaData.set(loca.data.subarray(0, locaDataSize));
 
-         loca.data = locaData;
 
-         var oldGlyfData = glyf.data;
 
-         var oldGlyfDataLength = oldGlyfData.length;
 
-         var newGlyfData = new Uint8Array(oldGlyfDataLength);
 
-         var startOffset = itemDecode(locaData, 0);
 
-         var writeOffset = 0;
 
-         var missingGlyphs = Object.create(null);
 
-         itemEncode(locaData, 0, writeOffset);
 
-         var i, j;
 
-         for (i = 0, j = itemSize; i < numGlyphs; i++, j += itemSize) {
 
-           var endOffset = itemDecode(locaData, j);
 
-           if (endOffset === 0) {
 
-             endOffset = startOffset;
 
-           }
 
-           if (endOffset > oldGlyfDataLength && (oldGlyfDataLength + 3 & ~3) === endOffset) {
 
-             endOffset = oldGlyfDataLength;
 
-           }
 
-           if (endOffset > oldGlyfDataLength) {
 
-             startOffset = endOffset;
 
-           }
 
-           var glyphProfile = sanitizeGlyph(oldGlyfData, startOffset, endOffset, newGlyfData, writeOffset, hintsValid);
 
-           var newLength = glyphProfile.length;
 
-           if (newLength === 0) {
 
-             missingGlyphs[i] = true;
 
-           }
 
-           if (glyphProfile.sizeOfInstructions > maxSizeOfInstructions) {
 
-             maxSizeOfInstructions = glyphProfile.sizeOfInstructions;
 
-           }
 
-           writeOffset += newLength;
 
-           itemEncode(locaData, j, writeOffset);
 
-           startOffset = endOffset;
 
-         }
 
-         if (writeOffset === 0) {
 
-           var simpleGlyph = new Uint8Array([0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 49, 0]);
 
-           for (i = 0, j = itemSize; i < numGlyphsOut; i++, j += itemSize) {
 
-             itemEncode(locaData, j, simpleGlyph.length);
 
-           }
 
-           glyf.data = simpleGlyph;
 
-         } else if (dupFirstEntry) {
 
-           var firstEntryLength = itemDecode(locaData, itemSize);
 
-           if (newGlyfData.length > firstEntryLength + writeOffset) {
 
-             glyf.data = newGlyfData.subarray(0, firstEntryLength + writeOffset);
 
-           } else {
 
-             glyf.data = new Uint8Array(firstEntryLength + writeOffset);
 
-             glyf.data.set(newGlyfData.subarray(0, writeOffset));
 
-           }
 
-           glyf.data.set(newGlyfData.subarray(0, firstEntryLength), writeOffset);
 
-           itemEncode(loca.data, locaData.length - itemSize, writeOffset + firstEntryLength);
 
-         } else {
 
-           glyf.data = newGlyfData.subarray(0, writeOffset);
 
-         }
 
-         return {
 
-           missingGlyphs,
 
-           maxSizeOfInstructions
 
-         };
 
-       }
 
-       function readPostScriptTable(post, properties, maxpNumGlyphs) {
 
-         var start = (font.start ? font.start : 0) + post.offset;
 
-         font.pos = start;
 
-         var length = post.length,
 
-             end = start + length;
 
-         var version = font.getInt32();
 
-         font.getBytes(28);
 
-         var glyphNames;
 
-         var valid = true;
 
-         var i;
 
-         switch (version) {
 
-           case 0x00010000:
 
-             glyphNames = MacStandardGlyphOrdering;
 
-             break;
 
-           case 0x00020000:
 
-             var numGlyphs = font.getUint16();
 
-             if (numGlyphs !== maxpNumGlyphs) {
 
-               valid = false;
 
-               break;
 
-             }
 
-             var glyphNameIndexes = [];
 
-             for (i = 0; i < numGlyphs; ++i) {
 
-               var index = font.getUint16();
 
-               if (index >= 32768) {
 
-                 valid = false;
 
-                 break;
 
-               }
 
-               glyphNameIndexes.push(index);
 
-             }
 
-             if (!valid) {
 
-               break;
 
-             }
 
-             var customNames = [];
 
-             var strBuf = [];
 
-             while (font.pos < end) {
 
-               var stringLength = font.getByte();
 
-               strBuf.length = stringLength;
 
-               for (i = 0; i < stringLength; ++i) {
 
-                 strBuf[i] = String.fromCharCode(font.getByte());
 
-               }
 
-               customNames.push(strBuf.join(""));
 
-             }
 
-             glyphNames = [];
 
-             for (i = 0; i < numGlyphs; ++i) {
 
-               var j = glyphNameIndexes[i];
 
-               if (j < 258) {
 
-                 glyphNames.push(MacStandardGlyphOrdering[j]);
 
-                 continue;
 
-               }
 
-               glyphNames.push(customNames[j - 258]);
 
-             }
 
-             break;
 
-           case 0x00030000:
 
-             break;
 
-           default:
 
-             (0, _util.warn)("Unknown/unsupported post table version " + version);
 
-             valid = false;
 
-             if (properties.defaultEncoding) {
 
-               glyphNames = properties.defaultEncoding;
 
-             }
 
-             break;
 
-         }
 
-         properties.glyphNames = glyphNames;
 
-         return valid;
 
-       }
 
-       function readNameTable(nameTable) {
 
-         var start = (font.start ? font.start : 0) + nameTable.offset;
 
-         font.pos = start;
 
-         var names = [[], []];
 
-         var length = nameTable.length,
 
-             end = start + length;
 
-         var format = font.getUint16();
 
-         var FORMAT_0_HEADER_LENGTH = 6;
 
-         if (format !== 0 || length < FORMAT_0_HEADER_LENGTH) {
 
-           return names;
 
-         }
 
-         var numRecords = font.getUint16();
 
-         var stringsStart = font.getUint16();
 
-         var records = [];
 
-         var NAME_RECORD_LENGTH = 12;
 
-         var i, ii;
 
-         for (i = 0; i < numRecords && font.pos + NAME_RECORD_LENGTH <= end; i++) {
 
-           var r = {
 
-             platform: font.getUint16(),
 
-             encoding: font.getUint16(),
 
-             language: font.getUint16(),
 
-             name: font.getUint16(),
 
-             length: font.getUint16(),
 
-             offset: font.getUint16()
 
-           };
 
-           if (r.platform === 1 && r.encoding === 0 && r.language === 0 || r.platform === 3 && r.encoding === 1 && r.language === 0x409) {
 
-             records.push(r);
 
-           }
 
-         }
 
-         for (i = 0, ii = records.length; i < ii; i++) {
 
-           var record = records[i];
 
-           if (record.length <= 0) {
 
-             continue;
 
-           }
 
-           var pos = start + stringsStart + record.offset;
 
-           if (pos + record.length > end) {
 
-             continue;
 
-           }
 
-           font.pos = pos;
 
-           var nameIndex = record.name;
 
-           if (record.encoding) {
 
-             var str = "";
 
-             for (var j = 0, jj = record.length; j < jj; j += 2) {
 
-               str += String.fromCharCode(font.getUint16());
 
-             }
 
-             names[1][nameIndex] = str;
 
-           } else {
 
-             names[0][nameIndex] = (0, _util.bytesToString)(font.getBytes(record.length));
 
-           }
 
-         }
 
-         return names;
 
-       }
 
-       var TTOpsStackDeltas = [0, 0, 0, 0, 0, 0, 0, 0, -2, -2, -2, -2, 0, 0, -2, -5, -1, -1, -1, -1, -1, -1, -1, -1, 0, 0, -1, 0, -1, -1, -1, -1, 1, -1, -999, 0, 1, 0, -1, -2, 0, -1, -2, -1, -1, 0, -1, -1, 0, 0, -999, -999, -1, -1, -1, -1, -2, -999, -2, -2, -999, 0, -2, -2, 0, 0, -2, 0, -2, 0, 0, 0, -2, -1, -1, 1, 1, 0, 0, -1, -1, -1, -1, -1, -1, -1, 0, 0, -1, 0, -1, -1, 0, -999, -1, -1, -1, -1, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -2, -999, -999, -999, -999, -999, -1, -1, -2, -2, 0, 0, 0, 0, -1, -1, -999, -2, -2, 0, 0, -1, -2, -2, 0, 0, 0, -1, -1, -1, -2];
 
-       function sanitizeTTProgram(table, ttContext) {
 
-         var data = table.data;
 
-         var i = 0,
 
-             j,
 
-             n,
 
-             b,
 
-             funcId,
 
-             pc,
 
-             lastEndf = 0,
 
-             lastDeff = 0;
 
-         var stack = [];
 
-         var callstack = [];
 
-         var functionsCalled = [];
 
-         var tooComplexToFollowFunctions = ttContext.tooComplexToFollowFunctions;
 
-         var inFDEF = false,
 
-             ifLevel = 0,
 
-             inELSE = 0;
 
-         for (var ii = data.length; i < ii;) {
 
-           var op = data[i++];
 
-           if (op === 0x40) {
 
-             n = data[i++];
 
-             if (inFDEF || inELSE) {
 
-               i += n;
 
-             } else {
 
-               for (j = 0; j < n; j++) {
 
-                 stack.push(data[i++]);
 
-               }
 
-             }
 
-           } else if (op === 0x41) {
 
-             n = data[i++];
 
-             if (inFDEF || inELSE) {
 
-               i += n * 2;
 
-             } else {
 
-               for (j = 0; j < n; j++) {
 
-                 b = data[i++];
 
-                 stack.push(b << 8 | data[i++]);
 
-               }
 
-             }
 
-           } else if ((op & 0xf8) === 0xb0) {
 
-             n = op - 0xb0 + 1;
 
-             if (inFDEF || inELSE) {
 
-               i += n;
 
-             } else {
 
-               for (j = 0; j < n; j++) {
 
-                 stack.push(data[i++]);
 
-               }
 
-             }
 
-           } else if ((op & 0xf8) === 0xb8) {
 
-             n = op - 0xb8 + 1;
 
-             if (inFDEF || inELSE) {
 
-               i += n * 2;
 
-             } else {
 
-               for (j = 0; j < n; j++) {
 
-                 b = data[i++];
 
-                 stack.push(b << 8 | data[i++]);
 
-               }
 
-             }
 
-           } else if (op === 0x2b && !tooComplexToFollowFunctions) {
 
-             if (!inFDEF && !inELSE) {
 
-               funcId = stack[stack.length - 1];
 
-               if (isNaN(funcId)) {
 
-                 (0, _util.info)("TT: CALL empty stack (or invalid entry).");
 
-               } else {
 
-                 ttContext.functionsUsed[funcId] = true;
 
-                 if (funcId in ttContext.functionsStackDeltas) {
 
-                   const newStackLength = stack.length + ttContext.functionsStackDeltas[funcId];
 
-                   if (newStackLength < 0) {
 
-                     (0, _util.warn)("TT: CALL invalid functions stack delta.");
 
-                     ttContext.hintsValid = false;
 
-                     return;
 
-                   }
 
-                   stack.length = newStackLength;
 
-                 } else if (funcId in ttContext.functionsDefined && !functionsCalled.includes(funcId)) {
 
-                   callstack.push({
 
-                     data,
 
-                     i,
 
-                     stackTop: stack.length - 1
 
-                   });
 
-                   functionsCalled.push(funcId);
 
-                   pc = ttContext.functionsDefined[funcId];
 
-                   if (!pc) {
 
-                     (0, _util.warn)("TT: CALL non-existent function");
 
-                     ttContext.hintsValid = false;
 
-                     return;
 
-                   }
 
-                   data = pc.data;
 
-                   i = pc.i;
 
-                 }
 
-               }
 
-             }
 
-           } else if (op === 0x2c && !tooComplexToFollowFunctions) {
 
-             if (inFDEF || inELSE) {
 
-               (0, _util.warn)("TT: nested FDEFs not allowed");
 
-               tooComplexToFollowFunctions = true;
 
-             }
 
-             inFDEF = true;
 
-             lastDeff = i;
 
-             funcId = stack.pop();
 
-             ttContext.functionsDefined[funcId] = {
 
-               data,
 
-               i
 
-             };
 
-           } else if (op === 0x2d) {
 
-             if (inFDEF) {
 
-               inFDEF = false;
 
-               lastEndf = i;
 
-             } else {
 
-               pc = callstack.pop();
 
-               if (!pc) {
 
-                 (0, _util.warn)("TT: ENDF bad stack");
 
-                 ttContext.hintsValid = false;
 
-                 return;
 
-               }
 
-               funcId = functionsCalled.pop();
 
-               data = pc.data;
 
-               i = pc.i;
 
-               ttContext.functionsStackDeltas[funcId] = stack.length - pc.stackTop;
 
-             }
 
-           } else if (op === 0x89) {
 
-             if (inFDEF || inELSE) {
 
-               (0, _util.warn)("TT: nested IDEFs not allowed");
 
-               tooComplexToFollowFunctions = true;
 
-             }
 
-             inFDEF = true;
 
-             lastDeff = i;
 
-           } else if (op === 0x58) {
 
-             ++ifLevel;
 
-           } else if (op === 0x1b) {
 
-             inELSE = ifLevel;
 
-           } else if (op === 0x59) {
 
-             if (inELSE === ifLevel) {
 
-               inELSE = 0;
 
-             }
 
-             --ifLevel;
 
-           } else if (op === 0x1c) {
 
-             if (!inFDEF && !inELSE) {
 
-               var offset = stack[stack.length - 1];
 
-               if (offset > 0) {
 
-                 i += offset - 1;
 
-               }
 
-             }
 
-           }
 
-           if (!inFDEF && !inELSE) {
 
-             let stackDelta = 0;
 
-             if (op <= 0x8e) {
 
-               stackDelta = TTOpsStackDeltas[op];
 
-             } else if (op >= 0xc0 && op <= 0xdf) {
 
-               stackDelta = -1;
 
-             } else if (op >= 0xe0) {
 
-               stackDelta = -2;
 
-             }
 
-             if (op >= 0x71 && op <= 0x75) {
 
-               n = stack.pop();
 
-               if (!isNaN(n)) {
 
-                 stackDelta = -n * 2;
 
-               }
 
-             }
 
-             while (stackDelta < 0 && stack.length > 0) {
 
-               stack.pop();
 
-               stackDelta++;
 
-             }
 
-             while (stackDelta > 0) {
 
-               stack.push(NaN);
 
-               stackDelta--;
 
-             }
 
-           }
 
-         }
 
-         ttContext.tooComplexToFollowFunctions = tooComplexToFollowFunctions;
 
-         var content = [data];
 
-         if (i > data.length) {
 
-           content.push(new Uint8Array(i - data.length));
 
-         }
 
-         if (lastDeff > lastEndf) {
 
-           (0, _util.warn)("TT: complementing a missing function tail");
 
-           content.push(new Uint8Array([0x22, 0x2d]));
 
-         }
 
-         foldTTTable(table, content);
 
-       }
 
-       function checkInvalidFunctions(ttContext, maxFunctionDefs) {
 
-         if (ttContext.tooComplexToFollowFunctions) {
 
-           return;
 
-         }
 
-         if (ttContext.functionsDefined.length > maxFunctionDefs) {
 
-           (0, _util.warn)("TT: more functions defined than expected");
 
-           ttContext.hintsValid = false;
 
-           return;
 
-         }
 
-         for (var j = 0, jj = ttContext.functionsUsed.length; j < jj; j++) {
 
-           if (j > maxFunctionDefs) {
 
-             (0, _util.warn)("TT: invalid function id: " + j);
 
-             ttContext.hintsValid = false;
 
-             return;
 
-           }
 
-           if (ttContext.functionsUsed[j] && !ttContext.functionsDefined[j]) {
 
-             (0, _util.warn)("TT: undefined function: " + j);
 
-             ttContext.hintsValid = false;
 
-             return;
 
-           }
 
-         }
 
-       }
 
-       function foldTTTable(table, content) {
 
-         if (content.length > 1) {
 
-           var newLength = 0;
 
-           var j, jj;
 
-           for (j = 0, jj = content.length; j < jj; j++) {
 
-             newLength += content[j].length;
 
-           }
 
-           newLength = newLength + 3 & ~3;
 
-           var result = new Uint8Array(newLength);
 
-           var pos = 0;
 
-           for (j = 0, jj = content.length; j < jj; j++) {
 
-             result.set(content[j], pos);
 
-             pos += content[j].length;
 
-           }
 
-           table.data = result;
 
-           table.length = newLength;
 
-         }
 
-       }
 
-       function sanitizeTTPrograms(fpgm, prep, cvt, maxFunctionDefs) {
 
-         var ttContext = {
 
-           functionsDefined: [],
 
-           functionsUsed: [],
 
-           functionsStackDeltas: [],
 
-           tooComplexToFollowFunctions: false,
 
-           hintsValid: true
 
-         };
 
-         if (fpgm) {
 
-           sanitizeTTProgram(fpgm, ttContext);
 
-         }
 
-         if (prep) {
 
-           sanitizeTTProgram(prep, ttContext);
 
-         }
 
-         if (fpgm) {
 
-           checkInvalidFunctions(ttContext, maxFunctionDefs);
 
-         }
 
-         if (cvt && cvt.length & 1) {
 
-           var cvtData = new Uint8Array(cvt.length + 1);
 
-           cvtData.set(cvt.data);
 
-           cvt.data = cvtData;
 
-         }
 
-         return ttContext.hintsValid;
 
-       }
 
-       font = new _stream.Stream(new Uint8Array(font.getBytes()));
 
-       let header, tables;
 
-       if (isTrueTypeCollectionFile(font)) {
 
-         const ttcData = readTrueTypeCollectionData(font, this.name);
 
-         header = ttcData.header;
 
-         tables = ttcData.tables;
 
-       } else {
 
-         header = readOpenTypeHeader(font);
 
-         tables = readTables(font, header.numTables);
 
-       }
 
-       let cff, cffFile;
 
-       var isTrueType = !tables["CFF "];
 
-       if (!isTrueType) {
 
-         const isComposite = properties.composite && ((properties.cidToGidMap || []).length > 0 || !(properties.cMap instanceof _cmap.IdentityCMap));
 
-         if (header.version === "OTTO" && !isComposite || !tables["head"] || !tables["hhea"] || !tables["maxp"] || !tables["post"]) {
 
-           cffFile = new _stream.Stream(tables["CFF "].data);
 
-           cff = new CFFFont(cffFile, properties);
 
-           adjustWidths(properties);
 
-           return this.convert(name, cff, properties);
 
-         }
 
-         delete tables["glyf"];
 
-         delete tables["loca"];
 
-         delete tables["fpgm"];
 
-         delete tables["prep"];
 
-         delete tables["cvt "];
 
-         this.isOpenType = true;
 
-       } else {
 
-         if (!tables["loca"]) {
 
-           throw new _util.FormatError('Required "loca" table is not found');
 
-         }
 
-         if (!tables["glyf"]) {
 
-           (0, _util.warn)('Required "glyf" table is not found -- trying to recover.');
 
-           tables["glyf"] = {
 
-             tag: "glyf",
 
-             data: new Uint8Array(0)
 
-           };
 
-         }
 
-         this.isOpenType = false;
 
-       }
 
-       if (!tables["maxp"]) {
 
-         throw new _util.FormatError('Required "maxp" table is not found');
 
-       }
 
-       font.pos = (font.start || 0) + tables["maxp"].offset;
 
-       var version = font.getInt32();
 
-       const numGlyphs = font.getUint16();
 
-       let numGlyphsOut = numGlyphs + 1;
 
-       let dupFirstEntry = true;
 
-       if (numGlyphsOut > 0xffff) {
 
-         dupFirstEntry = false;
 
-         numGlyphsOut = numGlyphs;
 
-         (0, _util.warn)("Not enough space in glyfs to duplicate first glyph.");
 
-       }
 
-       var maxFunctionDefs = 0;
 
-       var maxSizeOfInstructions = 0;
 
-       if (version >= 0x00010000 && tables["maxp"].length >= 22) {
 
-         font.pos += 8;
 
-         var maxZones = font.getUint16();
 
-         if (maxZones > 2) {
 
-           tables["maxp"].data[14] = 0;
 
-           tables["maxp"].data[15] = 2;
 
-         }
 
-         font.pos += 4;
 
-         maxFunctionDefs = font.getUint16();
 
-         font.pos += 4;
 
-         maxSizeOfInstructions = font.getUint16();
 
-       }
 
-       tables["maxp"].data[4] = numGlyphsOut >> 8;
 
-       tables["maxp"].data[5] = numGlyphsOut & 255;
 
-       var hintsValid = sanitizeTTPrograms(tables["fpgm"], tables["prep"], tables["cvt "], maxFunctionDefs);
 
-       if (!hintsValid) {
 
-         delete tables["fpgm"];
 
-         delete tables["prep"];
 
-         delete tables["cvt "];
 
-       }
 
-       sanitizeMetrics(font, tables["hhea"], tables["hmtx"], numGlyphsOut, dupFirstEntry);
 
-       if (!tables["head"]) {
 
-         throw new _util.FormatError('Required "head" table is not found');
 
-       }
 
-       sanitizeHead(tables["head"], numGlyphs, isTrueType ? tables["loca"].length : 0);
 
-       var missingGlyphs = Object.create(null);
 
-       if (isTrueType) {
 
-         var isGlyphLocationsLong = int16(tables["head"].data[50], tables["head"].data[51]);
 
-         var glyphsInfo = sanitizeGlyphLocations(tables["loca"], tables["glyf"], numGlyphs, isGlyphLocationsLong, hintsValid, dupFirstEntry, maxSizeOfInstructions);
 
-         missingGlyphs = glyphsInfo.missingGlyphs;
 
-         if (version >= 0x00010000 && tables["maxp"].length >= 22) {
 
-           tables["maxp"].data[26] = glyphsInfo.maxSizeOfInstructions >> 8;
 
-           tables["maxp"].data[27] = glyphsInfo.maxSizeOfInstructions & 255;
 
-         }
 
-       }
 
-       if (!tables["hhea"]) {
 
-         throw new _util.FormatError('Required "hhea" table is not found');
 
-       }
 
-       if (tables["hhea"].data[10] === 0 && tables["hhea"].data[11] === 0) {
 
-         tables["hhea"].data[10] = 0xff;
 
-         tables["hhea"].data[11] = 0xff;
 
-       }
 
-       var metricsOverride = {
 
-         unitsPerEm: int16(tables["head"].data[18], tables["head"].data[19]),
 
-         yMax: int16(tables["head"].data[42], tables["head"].data[43]),
 
-         yMin: signedInt16(tables["head"].data[38], tables["head"].data[39]),
 
-         ascent: int16(tables["hhea"].data[4], tables["hhea"].data[5]),
 
-         descent: signedInt16(tables["hhea"].data[6], tables["hhea"].data[7])
 
-       };
 
-       this.ascent = metricsOverride.ascent / metricsOverride.unitsPerEm;
 
-       this.descent = metricsOverride.descent / metricsOverride.unitsPerEm;
 
-       if (tables["post"]) {
 
-         readPostScriptTable(tables["post"], properties, numGlyphs);
 
-       }
 
-       tables["post"] = {
 
-         tag: "post",
 
-         data: createPostTable(properties)
 
-       };
 
-       var charCodeToGlyphId = [],
 
-           charCode;
 
-       function hasGlyph(glyphId) {
 
-         return !missingGlyphs[glyphId];
 
-       }
 
-       if (properties.composite) {
 
-         var cidToGidMap = properties.cidToGidMap || [];
 
-         var isCidToGidMapEmpty = cidToGidMap.length === 0;
 
-         properties.cMap.forEach(function (charCode, cid) {
 
-           if (cid > 0xffff) {
 
-             throw new _util.FormatError("Max size of CID is 65,535");
 
-           }
 
-           var glyphId = -1;
 
-           if (isCidToGidMapEmpty) {
 
-             glyphId = cid;
 
-           } else if (cidToGidMap[cid] !== undefined) {
 
-             glyphId = cidToGidMap[cid];
 
-           }
 
-           if (glyphId >= 0 && glyphId < numGlyphs && hasGlyph(glyphId)) {
 
-             charCodeToGlyphId[charCode] = glyphId;
 
-           }
 
-         });
 
-       } else {
 
-         var cmapTable = readCmapTable(tables["cmap"], font, this.isSymbolicFont, properties.hasEncoding);
 
-         var cmapPlatformId = cmapTable.platformId;
 
-         var cmapEncodingId = cmapTable.encodingId;
 
-         var cmapMappings = cmapTable.mappings;
 
-         var cmapMappingsLength = cmapMappings.length;
 
-         if (properties.hasEncoding && (cmapPlatformId === 3 && cmapEncodingId === 1 || cmapPlatformId === 1 && cmapEncodingId === 0) || cmapPlatformId === -1 && cmapEncodingId === -1 && !!(0, _encodings.getEncoding)(properties.baseEncodingName)) {
 
-           var baseEncoding = [];
 
-           if (properties.baseEncodingName === "MacRomanEncoding" || properties.baseEncodingName === "WinAnsiEncoding") {
 
-             baseEncoding = (0, _encodings.getEncoding)(properties.baseEncodingName);
 
-           }
 
-           var glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-           for (charCode = 0; charCode < 256; charCode++) {
 
-             var glyphName, standardGlyphName;
 
-             if (this.differences && charCode in this.differences) {
 
-               glyphName = this.differences[charCode];
 
-             } else if (charCode in baseEncoding && baseEncoding[charCode] !== "") {
 
-               glyphName = baseEncoding[charCode];
 
-             } else {
 
-               glyphName = _encodings.StandardEncoding[charCode];
 
-             }
 
-             if (!glyphName) {
 
-               continue;
 
-             }
 
-             standardGlyphName = recoverGlyphName(glyphName, glyphsUnicodeMap);
 
-             var unicodeOrCharCode;
 
-             if (cmapPlatformId === 3 && cmapEncodingId === 1) {
 
-               unicodeOrCharCode = glyphsUnicodeMap[standardGlyphName];
 
-             } else if (cmapPlatformId === 1 && cmapEncodingId === 0) {
 
-               unicodeOrCharCode = _encodings.MacRomanEncoding.indexOf(standardGlyphName);
 
-             }
 
-             var found = false;
 
-             for (let i = 0; i < cmapMappingsLength; ++i) {
 
-               if (cmapMappings[i].charCode !== unicodeOrCharCode) {
 
-                 continue;
 
-               }
 
-               charCodeToGlyphId[charCode] = cmapMappings[i].glyphId;
 
-               found = true;
 
-               break;
 
-             }
 
-             if (!found && properties.glyphNames) {
 
-               var glyphId = properties.glyphNames.indexOf(glyphName);
 
-               if (glyphId === -1 && standardGlyphName !== glyphName) {
 
-                 glyphId = properties.glyphNames.indexOf(standardGlyphName);
 
-               }
 
-               if (glyphId > 0 && hasGlyph(glyphId)) {
 
-                 charCodeToGlyphId[charCode] = glyphId;
 
-               }
 
-             }
 
-           }
 
-         } else if (cmapPlatformId === 0 && cmapEncodingId === 0) {
 
-           for (let i = 0; i < cmapMappingsLength; ++i) {
 
-             charCodeToGlyphId[cmapMappings[i].charCode] = cmapMappings[i].glyphId;
 
-           }
 
-         } else {
 
-           for (let i = 0; i < cmapMappingsLength; ++i) {
 
-             charCode = cmapMappings[i].charCode;
 
-             if (cmapPlatformId === 3 && charCode >= 0xf000 && charCode <= 0xf0ff) {
 
-               charCode &= 0xff;
 
-             }
 
-             charCodeToGlyphId[charCode] = cmapMappings[i].glyphId;
 
-           }
 
-         }
 
-       }
 
-       if (charCodeToGlyphId.length === 0) {
 
-         charCodeToGlyphId[0] = 0;
 
-       }
 
-       let glyphZeroId = numGlyphsOut - 1;
 
-       if (!dupFirstEntry) {
 
-         glyphZeroId = 0;
 
-       }
 
-       var newMapping = adjustMapping(charCodeToGlyphId, hasGlyph, glyphZeroId);
 
-       this.toFontChar = newMapping.toFontChar;
 
-       tables["cmap"] = {
 
-         tag: "cmap",
 
-         data: createCmapTable(newMapping.charCodeToGlyphId, numGlyphsOut)
 
-       };
 
-       if (!tables["OS/2"] || !validateOS2Table(tables["OS/2"])) {
 
-         tables["OS/2"] = {
 
-           tag: "OS/2",
 
-           data: createOS2Table(properties, newMapping.charCodeToGlyphId, metricsOverride)
 
-         };
 
-       }
 
-       if (!isTrueType) {
 
-         try {
 
-           cffFile = new _stream.Stream(tables["CFF "].data);
 
-           var parser = new _cff_parser.CFFParser(cffFile, properties, SEAC_ANALYSIS_ENABLED);
 
-           cff = parser.parse();
 
-           cff.duplicateFirstGlyph();
 
-           var compiler = new _cff_parser.CFFCompiler(cff);
 
-           tables["CFF "].data = compiler.compile();
 
-         } catch (e) {
 
-           (0, _util.warn)("Failed to compile font " + properties.loadedName);
 
-         }
 
-       }
 
-       if (!tables["name"]) {
 
-         tables["name"] = {
 
-           tag: "name",
 
-           data: createNameTable(this.name)
 
-         };
 
-       } else {
 
-         var namePrototype = readNameTable(tables["name"]);
 
-         tables["name"].data = createNameTable(name, namePrototype);
 
-       }
 
-       var builder = new OpenTypeFileBuilder(header.version);
 
-       for (var tableTag in tables) {
 
-         builder.addTable(tableTag, tables[tableTag].data);
 
-       }
 
-       return builder.toArray();
 
-     },
 
-     convert: function Font_convert(fontName, font, properties) {
 
-       properties.fixedPitch = false;
 
-       if (properties.builtInEncoding) {
 
-         adjustToUnicode(properties, properties.builtInEncoding);
 
-       }
 
-       let glyphZeroId = 1;
 
-       if (font instanceof CFFFont) {
 
-         glyphZeroId = font.numGlyphs - 1;
 
-       }
 
-       var mapping = font.getGlyphMapping(properties);
 
-       var newMapping = adjustMapping(mapping, font.hasGlyphId.bind(font), glyphZeroId);
 
-       this.toFontChar = newMapping.toFontChar;
 
-       var numGlyphs = font.numGlyphs;
 
-       function getCharCodes(charCodeToGlyphId, glyphId) {
 
-         var charCodes = null;
 
-         for (var charCode in charCodeToGlyphId) {
 
-           if (glyphId === charCodeToGlyphId[charCode]) {
 
-             if (!charCodes) {
 
-               charCodes = [];
 
-             }
 
-             charCodes.push(charCode | 0);
 
-           }
 
-         }
 
-         return charCodes;
 
-       }
 
-       function createCharCode(charCodeToGlyphId, glyphId) {
 
-         for (var charCode in charCodeToGlyphId) {
 
-           if (glyphId === charCodeToGlyphId[charCode]) {
 
-             return charCode | 0;
 
-           }
 
-         }
 
-         newMapping.charCodeToGlyphId[newMapping.nextAvailableFontCharCode] = glyphId;
 
-         return newMapping.nextAvailableFontCharCode++;
 
-       }
 
-       var seacs = font.seacs;
 
-       if (SEAC_ANALYSIS_ENABLED && seacs && seacs.length) {
 
-         var matrix = properties.fontMatrix || _util.FONT_IDENTITY_MATRIX;
 
-         var charset = font.getCharset();
 
-         var seacMap = Object.create(null);
 
-         for (var glyphId in seacs) {
 
-           glyphId |= 0;
 
-           var seac = seacs[glyphId];
 
-           var baseGlyphName = _encodings.StandardEncoding[seac[2]];
 
-           var accentGlyphName = _encodings.StandardEncoding[seac[3]];
 
-           var baseGlyphId = charset.indexOf(baseGlyphName);
 
-           var accentGlyphId = charset.indexOf(accentGlyphName);
 
-           if (baseGlyphId < 0 || accentGlyphId < 0) {
 
-             continue;
 
-           }
 
-           var accentOffset = {
 
-             x: seac[0] * matrix[0] + seac[1] * matrix[2] + matrix[4],
 
-             y: seac[0] * matrix[1] + seac[1] * matrix[3] + matrix[5]
 
-           };
 
-           var charCodes = getCharCodes(mapping, glyphId);
 
-           if (!charCodes) {
 
-             continue;
 
-           }
 
-           for (var i = 0, ii = charCodes.length; i < ii; i++) {
 
-             var charCode = charCodes[i];
 
-             var charCodeToGlyphId = newMapping.charCodeToGlyphId;
 
-             var baseFontCharCode = createCharCode(charCodeToGlyphId, baseGlyphId);
 
-             var accentFontCharCode = createCharCode(charCodeToGlyphId, accentGlyphId);
 
-             seacMap[charCode] = {
 
-               baseFontCharCode,
 
-               accentFontCharCode,
 
-               accentOffset
 
-             };
 
-           }
 
-         }
 
-         properties.seacMap = seacMap;
 
-       }
 
-       var unitsPerEm = 1 / (properties.fontMatrix || _util.FONT_IDENTITY_MATRIX)[0];
 
-       var builder = new OpenTypeFileBuilder("\x4F\x54\x54\x4F");
 
-       builder.addTable("CFF ", font.data);
 
-       builder.addTable("OS/2", createOS2Table(properties, newMapping.charCodeToGlyphId));
 
-       builder.addTable("cmap", createCmapTable(newMapping.charCodeToGlyphId, numGlyphs));
 
-       builder.addTable("head", "\x00\x01\x00\x00" + "\x00\x00\x10\x00" + "\x00\x00\x00\x00" + "\x5F\x0F\x3C\xF5" + "\x00\x00" + safeString16(unitsPerEm) + "\x00\x00\x00\x00\x9e\x0b\x7e\x27" + "\x00\x00\x00\x00\x9e\x0b\x7e\x27" + "\x00\x00" + safeString16(properties.descent) + "\x0F\xFF" + safeString16(properties.ascent) + string16(properties.italicAngle ? 2 : 0) + "\x00\x11" + "\x00\x00" + "\x00\x00" + "\x00\x00");
 
-       builder.addTable("hhea", "\x00\x01\x00\x00" + safeString16(properties.ascent) + safeString16(properties.descent) + "\x00\x00" + "\xFF\xFF" + "\x00\x00" + "\x00\x00" + "\x00\x00" + safeString16(properties.capHeight) + safeString16(Math.tan(properties.italicAngle) * properties.xHeight) + "\x00\x00" + "\x00\x00" + "\x00\x00" + "\x00\x00" + "\x00\x00" + "\x00\x00" + string16(numGlyphs));
 
-       builder.addTable("hmtx", function fontFieldsHmtx() {
 
-         var charstrings = font.charstrings;
 
-         var cffWidths = font.cff ? font.cff.widths : null;
 
-         var hmtx = "\x00\x00\x00\x00";
 
-         for (var i = 1, ii = numGlyphs; i < ii; i++) {
 
-           var width = 0;
 
-           if (charstrings) {
 
-             var charstring = charstrings[i - 1];
 
-             width = "width" in charstring ? charstring.width : 0;
 
-           } else if (cffWidths) {
 
-             width = Math.ceil(cffWidths[i] || 0);
 
-           }
 
-           hmtx += string16(width) + string16(0);
 
-         }
 
-         return hmtx;
 
-       }());
 
-       builder.addTable("maxp", "\x00\x00\x50\x00" + string16(numGlyphs));
 
-       builder.addTable("name", createNameTable(fontName));
 
-       builder.addTable("post", createPostTable(properties));
 
-       return builder.toArray();
 
-     },
 
-     get spaceWidth() {
 
-       if ("_shadowWidth" in this) {
 
-         return this._shadowWidth;
 
-       }
 
-       var possibleSpaceReplacements = ["space", "minus", "one", "i", "I"];
 
-       var width;
 
-       for (var i = 0, ii = possibleSpaceReplacements.length; i < ii; i++) {
 
-         var glyphName = possibleSpaceReplacements[i];
 
-         if (glyphName in this.widths) {
 
-           width = this.widths[glyphName];
 
-           break;
 
-         }
 
-         var glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-         var glyphUnicode = glyphsUnicodeMap[glyphName];
 
-         var charcode = 0;
 
-         if (this.composite) {
 
-           if (this.cMap.contains(glyphUnicode)) {
 
-             charcode = this.cMap.lookup(glyphUnicode);
 
-           }
 
-         }
 
-         if (!charcode && this.toUnicode) {
 
-           charcode = this.toUnicode.charCodeOf(glyphUnicode);
 
-         }
 
-         if (charcode <= 0) {
 
-           charcode = glyphUnicode;
 
-         }
 
-         width = this.widths[charcode];
 
-         if (width) {
 
-           break;
 
-         }
 
-       }
 
-       width = width || this.defaultWidth;
 
-       this._shadowWidth = width;
 
-       return width;
 
-     },
 
-     charToGlyph: function Font_charToGlyph(charcode, isSpace) {
 
-       var fontCharCode, width, operatorListId;
 
-       var widthCode = charcode;
 
-       if (this.cMap && this.cMap.contains(charcode)) {
 
-         widthCode = this.cMap.lookup(charcode);
 
-       }
 
-       width = this.widths[widthCode];
 
-       width = (0, _util.isNum)(width) ? width : this.defaultWidth;
 
-       var vmetric = this.vmetrics && this.vmetrics[widthCode];
 
-       let unicode = this.toUnicode.get(charcode) || this.fallbackToUnicode.get(charcode) || charcode;
 
-       if (typeof unicode === "number") {
 
-         unicode = String.fromCharCode(unicode);
 
-       }
 
-       var isInFont = charcode in this.toFontChar;
 
-       fontCharCode = this.toFontChar[charcode] || charcode;
 
-       if (this.missingFile) {
 
-         const glyphName = this.differences[charcode] || this.defaultEncoding[charcode];
 
-         if ((glyphName === ".notdef" || glyphName === "") && this.type === "Type1") {
 
-           fontCharCode = 0x20;
 
-         }
 
-         fontCharCode = (0, _unicode.mapSpecialUnicodeValues)(fontCharCode);
 
-       }
 
-       if (this.isType3Font) {
 
-         operatorListId = fontCharCode;
 
-       }
 
-       var accent = null;
 
-       if (this.seacMap && this.seacMap[charcode]) {
 
-         isInFont = true;
 
-         var seac = this.seacMap[charcode];
 
-         fontCharCode = seac.baseFontCharCode;
 
-         accent = {
 
-           fontChar: String.fromCodePoint(seac.accentFontCharCode),
 
-           offset: seac.accentOffset
 
-         };
 
-       }
 
-       var fontChar = typeof fontCharCode === "number" ? String.fromCodePoint(fontCharCode) : "";
 
-       var glyph = this.glyphCache[charcode];
 
-       if (!glyph || !glyph.matchesForCache(fontChar, unicode, accent, width, vmetric, operatorListId, isSpace, isInFont)) {
 
-         glyph = new Glyph(fontChar, unicode, accent, width, vmetric, operatorListId, isSpace, isInFont);
 
-         this.glyphCache[charcode] = glyph;
 
-       }
 
-       return glyph;
 
-     },
 
-     charsToGlyphs: function Font_charsToGlyphs(chars) {
 
-       var charsCache = this.charsCache;
 
-       var glyphs, glyph, charcode;
 
-       if (charsCache) {
 
-         glyphs = charsCache[chars];
 
-         if (glyphs) {
 
-           return glyphs;
 
-         }
 
-       }
 
-       if (!charsCache) {
 
-         charsCache = this.charsCache = Object.create(null);
 
-       }
 
-       glyphs = [];
 
-       var charsCacheKey = chars;
 
-       var i = 0,
 
-           ii;
 
-       if (this.cMap) {
 
-         var c = Object.create(null);
 
-         while (i < chars.length) {
 
-           this.cMap.readCharCode(chars, i, c);
 
-           charcode = c.charcode;
 
-           var length = c.length;
 
-           i += length;
 
-           var isSpace = length === 1 && chars.charCodeAt(i - 1) === 0x20;
 
-           glyph = this.charToGlyph(charcode, isSpace);
 
-           glyphs.push(glyph);
 
-         }
 
-       } else {
 
-         for (i = 0, ii = chars.length; i < ii; ++i) {
 
-           charcode = chars.charCodeAt(i);
 
-           glyph = this.charToGlyph(charcode, charcode === 0x20);
 
-           glyphs.push(glyph);
 
-         }
 
-       }
 
-       return charsCache[charsCacheKey] = glyphs;
 
-     },
 
-     get glyphCacheValues() {
 
-       return Object.values(this.glyphCache);
 
-     }
 
-   };
 
-   return Font;
 
- }();
 
- exports.Font = Font;
 
- var ErrorFont = function ErrorFontClosure() {
 
-   function ErrorFont(error) {
 
-     this.error = error;
 
-     this.loadedName = "g_font_error";
 
-     this.missingFile = true;
 
-   }
 
-   ErrorFont.prototype = {
 
-     charsToGlyphs: function ErrorFont_charsToGlyphs() {
 
-       return [];
 
-     },
 
-     exportData: function ErrorFont_exportData() {
 
-       return {
 
-         error: this.error
 
-       };
 
-     }
 
-   };
 
-   return ErrorFont;
 
- }();
 
- exports.ErrorFont = ErrorFont;
 
- function type1FontGlyphMapping(properties, builtInEncoding, glyphNames) {
 
-   var charCodeToGlyphId = Object.create(null);
 
-   var glyphId, charCode, baseEncoding;
 
-   var isSymbolicFont = !!(properties.flags & FontFlags.Symbolic);
 
-   if (properties.baseEncodingName) {
 
-     baseEncoding = (0, _encodings.getEncoding)(properties.baseEncodingName);
 
-     for (charCode = 0; charCode < baseEncoding.length; charCode++) {
 
-       glyphId = glyphNames.indexOf(baseEncoding[charCode]);
 
-       if (glyphId >= 0) {
 
-         charCodeToGlyphId[charCode] = glyphId;
 
-       } else {
 
-         charCodeToGlyphId[charCode] = 0;
 
-       }
 
-     }
 
-   } else if (isSymbolicFont) {
 
-     for (charCode in builtInEncoding) {
 
-       charCodeToGlyphId[charCode] = builtInEncoding[charCode];
 
-     }
 
-   } else {
 
-     baseEncoding = _encodings.StandardEncoding;
 
-     for (charCode = 0; charCode < baseEncoding.length; charCode++) {
 
-       glyphId = glyphNames.indexOf(baseEncoding[charCode]);
 
-       if (glyphId >= 0) {
 
-         charCodeToGlyphId[charCode] = glyphId;
 
-       } else {
 
-         charCodeToGlyphId[charCode] = 0;
 
-       }
 
-     }
 
-   }
 
-   var differences = properties.differences,
 
-       glyphsUnicodeMap;
 
-   if (differences) {
 
-     for (charCode in differences) {
 
-       var glyphName = differences[charCode];
 
-       glyphId = glyphNames.indexOf(glyphName);
 
-       if (glyphId === -1) {
 
-         if (!glyphsUnicodeMap) {
 
-           glyphsUnicodeMap = (0, _glyphlist.getGlyphsUnicode)();
 
-         }
 
-         var standardGlyphName = recoverGlyphName(glyphName, glyphsUnicodeMap);
 
-         if (standardGlyphName !== glyphName) {
 
-           glyphId = glyphNames.indexOf(standardGlyphName);
 
-         }
 
-       }
 
-       if (glyphId >= 0) {
 
-         charCodeToGlyphId[charCode] = glyphId;
 
-       } else {
 
-         charCodeToGlyphId[charCode] = 0;
 
-       }
 
-     }
 
-   }
 
-   return charCodeToGlyphId;
 
- }
 
- var Type1Font = function Type1FontClosure() {
 
-   function findBlock(streamBytes, signature, startIndex) {
 
-     var streamBytesLength = streamBytes.length;
 
-     var signatureLength = signature.length;
 
-     var scanLength = streamBytesLength - signatureLength;
 
-     var i = startIndex,
 
-         j,
 
-         found = false;
 
-     while (i < scanLength) {
 
-       j = 0;
 
-       while (j < signatureLength && streamBytes[i + j] === signature[j]) {
 
-         j++;
 
-       }
 
-       if (j >= signatureLength) {
 
-         i += j;
 
-         while (i < streamBytesLength && (0, _core_utils.isWhiteSpace)(streamBytes[i])) {
 
-           i++;
 
-         }
 
-         found = true;
 
-         break;
 
-       }
 
-       i++;
 
-     }
 
-     return {
 
-       found,
 
-       length: i
 
-     };
 
-   }
 
-   function getHeaderBlock(stream, suggestedLength) {
 
-     var EEXEC_SIGNATURE = [0x65, 0x65, 0x78, 0x65, 0x63];
 
-     var streamStartPos = stream.pos;
 
-     var headerBytes, headerBytesLength, block;
 
-     try {
 
-       headerBytes = stream.getBytes(suggestedLength);
 
-       headerBytesLength = headerBytes.length;
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-     }
 
-     if (headerBytesLength === suggestedLength) {
 
-       block = findBlock(headerBytes, EEXEC_SIGNATURE, suggestedLength - 2 * EEXEC_SIGNATURE.length);
 
-       if (block.found && block.length === suggestedLength) {
 
-         return {
 
-           stream: new _stream.Stream(headerBytes),
 
-           length: suggestedLength
 
-         };
 
-       }
 
-     }
 
-     (0, _util.warn)('Invalid "Length1" property in Type1 font -- trying to recover.');
 
-     stream.pos = streamStartPos;
 
-     var SCAN_BLOCK_LENGTH = 2048;
 
-     var actualLength;
 
-     while (true) {
 
-       var scanBytes = stream.peekBytes(SCAN_BLOCK_LENGTH);
 
-       block = findBlock(scanBytes, EEXEC_SIGNATURE, 0);
 
-       if (block.length === 0) {
 
-         break;
 
-       }
 
-       stream.pos += block.length;
 
-       if (block.found) {
 
-         actualLength = stream.pos - streamStartPos;
 
-         break;
 
-       }
 
-     }
 
-     stream.pos = streamStartPos;
 
-     if (actualLength) {
 
-       return {
 
-         stream: new _stream.Stream(stream.getBytes(actualLength)),
 
-         length: actualLength
 
-       };
 
-     }
 
-     (0, _util.warn)('Unable to recover "Length1" property in Type1 font -- using as is.');
 
-     return {
 
-       stream: new _stream.Stream(stream.getBytes(suggestedLength)),
 
-       length: suggestedLength
 
-     };
 
-   }
 
-   function getEexecBlock(stream, suggestedLength) {
 
-     var eexecBytes = stream.getBytes();
 
-     return {
 
-       stream: new _stream.Stream(eexecBytes),
 
-       length: eexecBytes.length
 
-     };
 
-   }
 
-   function Type1Font(name, file, properties) {
 
-     var PFB_HEADER_SIZE = 6;
 
-     var headerBlockLength = properties.length1;
 
-     var eexecBlockLength = properties.length2;
 
-     var pfbHeader = file.peekBytes(PFB_HEADER_SIZE);
 
-     var pfbHeaderPresent = pfbHeader[0] === 0x80 && pfbHeader[1] === 0x01;
 
-     if (pfbHeaderPresent) {
 
-       file.skip(PFB_HEADER_SIZE);
 
-       headerBlockLength = pfbHeader[5] << 24 | pfbHeader[4] << 16 | pfbHeader[3] << 8 | pfbHeader[2];
 
-     }
 
-     var headerBlock = getHeaderBlock(file, headerBlockLength);
 
-     var headerBlockParser = new _type1_parser.Type1Parser(headerBlock.stream, false, SEAC_ANALYSIS_ENABLED);
 
-     headerBlockParser.extractFontHeader(properties);
 
-     if (pfbHeaderPresent) {
 
-       pfbHeader = file.getBytes(PFB_HEADER_SIZE);
 
-       eexecBlockLength = pfbHeader[5] << 24 | pfbHeader[4] << 16 | pfbHeader[3] << 8 | pfbHeader[2];
 
-     }
 
-     var eexecBlock = getEexecBlock(file, eexecBlockLength);
 
-     var eexecBlockParser = new _type1_parser.Type1Parser(eexecBlock.stream, true, SEAC_ANALYSIS_ENABLED);
 
-     var data = eexecBlockParser.extractFontProgram(properties);
 
-     for (var info in data.properties) {
 
-       properties[info] = data.properties[info];
 
-     }
 
-     var charstrings = data.charstrings;
 
-     var type2Charstrings = this.getType2Charstrings(charstrings);
 
-     var subrs = this.getType2Subrs(data.subrs);
 
-     this.charstrings = charstrings;
 
-     this.data = this.wrap(name, type2Charstrings, this.charstrings, subrs, properties);
 
-     this.seacs = this.getSeacs(data.charstrings);
 
-   }
 
-   Type1Font.prototype = {
 
-     get numGlyphs() {
 
-       return this.charstrings.length + 1;
 
-     },
 
-     getCharset: function Type1Font_getCharset() {
 
-       var charset = [".notdef"];
 
-       var charstrings = this.charstrings;
 
-       for (var glyphId = 0; glyphId < charstrings.length; glyphId++) {
 
-         charset.push(charstrings[glyphId].glyphName);
 
-       }
 
-       return charset;
 
-     },
 
-     getGlyphMapping: function Type1Font_getGlyphMapping(properties) {
 
-       var charstrings = this.charstrings;
 
-       var glyphNames = [".notdef"],
 
-           glyphId;
 
-       for (glyphId = 0; glyphId < charstrings.length; glyphId++) {
 
-         glyphNames.push(charstrings[glyphId].glyphName);
 
-       }
 
-       var encoding = properties.builtInEncoding;
 
-       if (encoding) {
 
-         var builtInEncoding = Object.create(null);
 
-         for (var charCode in encoding) {
 
-           glyphId = glyphNames.indexOf(encoding[charCode]);
 
-           if (glyphId >= 0) {
 
-             builtInEncoding[charCode] = glyphId;
 
-           }
 
-         }
 
-       }
 
-       return type1FontGlyphMapping(properties, builtInEncoding, glyphNames);
 
-     },
 
-     hasGlyphId: function Type1Font_hasGlyphID(id) {
 
-       if (id < 0 || id >= this.numGlyphs) {
 
-         return false;
 
-       }
 
-       if (id === 0) {
 
-         return true;
 
-       }
 
-       var glyph = this.charstrings[id - 1];
 
-       return glyph.charstring.length > 0;
 
-     },
 
-     getSeacs: function Type1Font_getSeacs(charstrings) {
 
-       var i, ii;
 
-       var seacMap = [];
 
-       for (i = 0, ii = charstrings.length; i < ii; i++) {
 
-         var charstring = charstrings[i];
 
-         if (charstring.seac) {
 
-           seacMap[i + 1] = charstring.seac;
 
-         }
 
-       }
 
-       return seacMap;
 
-     },
 
-     getType2Charstrings: function Type1Font_getType2Charstrings(type1Charstrings) {
 
-       var type2Charstrings = [];
 
-       for (var i = 0, ii = type1Charstrings.length; i < ii; i++) {
 
-         type2Charstrings.push(type1Charstrings[i].charstring);
 
-       }
 
-       return type2Charstrings;
 
-     },
 
-     getType2Subrs: function Type1Font_getType2Subrs(type1Subrs) {
 
-       var bias = 0;
 
-       var count = type1Subrs.length;
 
-       if (count < 1133) {
 
-         bias = 107;
 
-       } else if (count < 33769) {
 
-         bias = 1131;
 
-       } else {
 
-         bias = 32768;
 
-       }
 
-       var type2Subrs = [];
 
-       var i;
 
-       for (i = 0; i < bias; i++) {
 
-         type2Subrs.push([0x0b]);
 
-       }
 
-       for (i = 0; i < count; i++) {
 
-         type2Subrs.push(type1Subrs[i]);
 
-       }
 
-       return type2Subrs;
 
-     },
 
-     wrap: function Type1Font_wrap(name, glyphs, charstrings, subrs, properties) {
 
-       var cff = new _cff_parser.CFF();
 
-       cff.header = new _cff_parser.CFFHeader(1, 0, 4, 4);
 
-       cff.names = [name];
 
-       var topDict = new _cff_parser.CFFTopDict();
 
-       topDict.setByName("version", 391);
 
-       topDict.setByName("Notice", 392);
 
-       topDict.setByName("FullName", 393);
 
-       topDict.setByName("FamilyName", 394);
 
-       topDict.setByName("Weight", 395);
 
-       topDict.setByName("Encoding", null);
 
-       topDict.setByName("FontMatrix", properties.fontMatrix);
 
-       topDict.setByName("FontBBox", properties.bbox);
 
-       topDict.setByName("charset", null);
 
-       topDict.setByName("CharStrings", null);
 
-       topDict.setByName("Private", null);
 
-       cff.topDict = topDict;
 
-       var strings = new _cff_parser.CFFStrings();
 
-       strings.add("Version 0.11");
 
-       strings.add("See original notice");
 
-       strings.add(name);
 
-       strings.add(name);
 
-       strings.add("Medium");
 
-       cff.strings = strings;
 
-       cff.globalSubrIndex = new _cff_parser.CFFIndex();
 
-       var count = glyphs.length;
 
-       var charsetArray = [".notdef"];
 
-       var i, ii;
 
-       for (i = 0; i < count; i++) {
 
-         const glyphName = charstrings[i].glyphName;
 
-         const index = _cff_parser.CFFStandardStrings.indexOf(glyphName);
 
-         if (index === -1) {
 
-           strings.add(glyphName);
 
-         }
 
-         charsetArray.push(glyphName);
 
-       }
 
-       cff.charset = new _cff_parser.CFFCharset(false, 0, charsetArray);
 
-       var charStringsIndex = new _cff_parser.CFFIndex();
 
-       charStringsIndex.add([0x8b, 0x0e]);
 
-       for (i = 0; i < count; i++) {
 
-         charStringsIndex.add(glyphs[i]);
 
-       }
 
-       cff.charStrings = charStringsIndex;
 
-       var privateDict = new _cff_parser.CFFPrivateDict();
 
-       privateDict.setByName("Subrs", null);
 
-       var fields = ["BlueValues", "OtherBlues", "FamilyBlues", "FamilyOtherBlues", "StemSnapH", "StemSnapV", "BlueShift", "BlueFuzz", "BlueScale", "LanguageGroup", "ExpansionFactor", "ForceBold", "StdHW", "StdVW"];
 
-       for (i = 0, ii = fields.length; i < ii; i++) {
 
-         var field = fields[i];
 
-         if (!(field in properties.privateData)) {
 
-           continue;
 
-         }
 
-         var value = properties.privateData[field];
 
-         if (Array.isArray(value)) {
 
-           for (var j = value.length - 1; j > 0; j--) {
 
-             value[j] -= value[j - 1];
 
-           }
 
-         }
 
-         privateDict.setByName(field, value);
 
-       }
 
-       cff.topDict.privateDict = privateDict;
 
-       var subrIndex = new _cff_parser.CFFIndex();
 
-       for (i = 0, ii = subrs.length; i < ii; i++) {
 
-         subrIndex.add(subrs[i]);
 
-       }
 
-       privateDict.subrsIndex = subrIndex;
 
-       var compiler = new _cff_parser.CFFCompiler(cff);
 
-       return compiler.compile();
 
-     }
 
-   };
 
-   return Type1Font;
 
- }();
 
- var CFFFont = function CFFFontClosure() {
 
-   function CFFFont(file, properties) {
 
-     this.properties = properties;
 
-     var parser = new _cff_parser.CFFParser(file, properties, SEAC_ANALYSIS_ENABLED);
 
-     this.cff = parser.parse();
 
-     this.cff.duplicateFirstGlyph();
 
-     var compiler = new _cff_parser.CFFCompiler(this.cff);
 
-     this.seacs = this.cff.seacs;
 
-     try {
 
-       this.data = compiler.compile();
 
-     } catch (e) {
 
-       (0, _util.warn)("Failed to compile font " + properties.loadedName);
 
-       this.data = file;
 
-     }
 
-   }
 
-   CFFFont.prototype = {
 
-     get numGlyphs() {
 
-       return this.cff.charStrings.count;
 
-     },
 
-     getCharset: function CFFFont_getCharset() {
 
-       return this.cff.charset.charset;
 
-     },
 
-     getGlyphMapping: function CFFFont_getGlyphMapping() {
 
-       var cff = this.cff;
 
-       var properties = this.properties;
 
-       var charsets = cff.charset.charset;
 
-       var charCodeToGlyphId;
 
-       var glyphId;
 
-       if (properties.composite) {
 
-         charCodeToGlyphId = Object.create(null);
 
-         let charCode;
 
-         if (cff.isCIDFont) {
 
-           for (glyphId = 0; glyphId < charsets.length; glyphId++) {
 
-             var cid = charsets[glyphId];
 
-             charCode = properties.cMap.charCodeOf(cid);
 
-             charCodeToGlyphId[charCode] = glyphId;
 
-           }
 
-         } else {
 
-           for (glyphId = 0; glyphId < cff.charStrings.count; glyphId++) {
 
-             charCode = properties.cMap.charCodeOf(glyphId);
 
-             charCodeToGlyphId[charCode] = glyphId;
 
-           }
 
-         }
 
-         return charCodeToGlyphId;
 
-       }
 
-       var encoding = cff.encoding ? cff.encoding.encoding : null;
 
-       charCodeToGlyphId = type1FontGlyphMapping(properties, encoding, charsets);
 
-       return charCodeToGlyphId;
 
-     },
 
-     hasGlyphId: function CFFFont_hasGlyphID(id) {
 
-       return this.cff.hasGlyphId(id);
 
-     }
 
-   };
 
-   return CFFFont;
 
- }();
 
- /***/ }),
 
- /* 28 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.CFFFDSelect = exports.CFFCompiler = exports.CFFPrivateDict = exports.CFFTopDict = exports.CFFCharset = exports.CFFIndex = exports.CFFStrings = exports.CFFHeader = exports.CFF = exports.CFFParser = exports.CFFStandardStrings = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _charsets = __w_pdfjs_require__(29);
 
- var _encodings = __w_pdfjs_require__(30);
 
- var MAX_SUBR_NESTING = 10;
 
- var CFFStandardStrings = [".notdef", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quoteright", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "quoteleft", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "exclamdown", "cent", "sterling", "fraction", "yen", "florin", "section", "currency", "quotesingle", "quotedblleft", "guillemotleft", "guilsinglleft", "guilsinglright", "fi", "fl", "endash", "dagger", "daggerdbl", "periodcentered", "paragraph", "bullet", "quotesinglbase", "quotedblbase", "quotedblright", "guillemotright", "ellipsis", "perthousand", "questiondown", "grave", "acute", "circumflex", "tilde", "macron", "breve", "dotaccent", "dieresis", "ring", "cedilla", "hungarumlaut", "ogonek", "caron", "emdash", "AE", "ordfeminine", "Lslash", "Oslash", "OE", "ordmasculine", "ae", "dotlessi", "lslash", "oslash", "oe", "germandbls", "onesuperior", "logicalnot", "mu", "trademark", "Eth", "onehalf", "plusminus", "Thorn", "onequarter", "divide", "brokenbar", "degree", "thorn", "threequarters", "twosuperior", "registered", "minus", "eth", "multiply", "threesuperior", "copyright", "Aacute", "Acircumflex", "Adieresis", "Agrave", "Aring", "Atilde", "Ccedilla", "Eacute", "Ecircumflex", "Edieresis", "Egrave", "Iacute", "Icircumflex", "Idieresis", "Igrave", "Ntilde", "Oacute", "Ocircumflex", "Odieresis", "Ograve", "Otilde", "Scaron", "Uacute", "Ucircumflex", "Udieresis", "Ugrave", "Yacute", "Ydieresis", "Zcaron", "aacute", "acircumflex", "adieresis", "agrave", "aring", "atilde", "ccedilla", "eacute", "ecircumflex", "edieresis", "egrave", "iacute", "icircumflex", "idieresis", "igrave", "ntilde", "oacute", "ocircumflex", "odieresis", "ograve", "otilde", "scaron", "uacute", "ucircumflex", "udieresis", "ugrave", "yacute", "ydieresis", "zcaron", "exclamsmall", "Hungarumlautsmall", "dollaroldstyle", "dollarsuperior", "ampersandsmall", "Acutesmall", "parenleftsuperior", "parenrightsuperior", "twodotenleader", "onedotenleader", "zerooldstyle", "oneoldstyle", "twooldstyle", "threeoldstyle", "fouroldstyle", "fiveoldstyle", "sixoldstyle", "sevenoldstyle", "eightoldstyle", "nineoldstyle", "commasuperior", "threequartersemdash", "periodsuperior", "questionsmall", "asuperior", "bsuperior", "centsuperior", "dsuperior", "esuperior", "isuperior", "lsuperior", "msuperior", "nsuperior", "osuperior", "rsuperior", "ssuperior", "tsuperior", "ff", "ffi", "ffl", "parenleftinferior", "parenrightinferior", "Circumflexsmall", "hyphensuperior", "Gravesmall", "Asmall", "Bsmall", "Csmall", "Dsmall", "Esmall", "Fsmall", "Gsmall", "Hsmall", "Ismall", "Jsmall", "Ksmall", "Lsmall", "Msmall", "Nsmall", "Osmall", "Psmall", "Qsmall", "Rsmall", "Ssmall", "Tsmall", "Usmall", "Vsmall", "Wsmall", "Xsmall", "Ysmall", "Zsmall", "colonmonetary", "onefitted", "rupiah", "Tildesmall", "exclamdownsmall", "centoldstyle", "Lslashsmall", "Scaronsmall", "Zcaronsmall", "Dieresissmall", "Brevesmall", "Caronsmall", "Dotaccentsmall", "Macronsmall", "figuredash", "hypheninferior", "Ogoneksmall", "Ringsmall", "Cedillasmall", "questiondownsmall", "oneeighth", "threeeighths", "fiveeighths", "seveneighths", "onethird", "twothirds", "zerosuperior", "foursuperior", "fivesuperior", "sixsuperior", "sevensuperior", "eightsuperior", "ninesuperior", "zeroinferior", "oneinferior", "twoinferior", "threeinferior", "fourinferior", "fiveinferior", "sixinferior", "seveninferior", "eightinferior", "nineinferior", "centinferior", "dollarinferior", "periodinferior", "commainferior", "Agravesmall", "Aacutesmall", "Acircumflexsmall", "Atildesmall", "Adieresissmall", "Aringsmall", "AEsmall", "Ccedillasmall", "Egravesmall", "Eacutesmall", "Ecircumflexsmall", "Edieresissmall", "Igravesmall", "Iacutesmall", "Icircumflexsmall", "Idieresissmall", "Ethsmall", "Ntildesmall", "Ogravesmall", "Oacutesmall", "Ocircumflexsmall", "Otildesmall", "Odieresissmall", "OEsmall", "Oslashsmall", "Ugravesmall", "Uacutesmall", "Ucircumflexsmall", "Udieresissmall", "Yacutesmall", "Thornsmall", "Ydieresissmall", "001.000", "001.001", "001.002", "001.003", "Black", "Bold", "Book", "Light", "Medium", "Regular", "Roman", "Semibold"];
 
- exports.CFFStandardStrings = CFFStandardStrings;
 
- const NUM_STANDARD_CFF_STRINGS = 391;
 
- var CFFParser = function CFFParserClosure() {
 
-   var CharstringValidationData = [null, {
 
-     id: "hstem",
 
-     min: 2,
 
-     stackClearing: true,
 
-     stem: true
 
-   }, null, {
 
-     id: "vstem",
 
-     min: 2,
 
-     stackClearing: true,
 
-     stem: true
 
-   }, {
 
-     id: "vmoveto",
 
-     min: 1,
 
-     stackClearing: true
 
-   }, {
 
-     id: "rlineto",
 
-     min: 2,
 
-     resetStack: true
 
-   }, {
 
-     id: "hlineto",
 
-     min: 1,
 
-     resetStack: true
 
-   }, {
 
-     id: "vlineto",
 
-     min: 1,
 
-     resetStack: true
 
-   }, {
 
-     id: "rrcurveto",
 
-     min: 6,
 
-     resetStack: true
 
-   }, null, {
 
-     id: "callsubr",
 
-     min: 1,
 
-     undefStack: true
 
-   }, {
 
-     id: "return",
 
-     min: 0,
 
-     undefStack: true
 
-   }, null, null, {
 
-     id: "endchar",
 
-     min: 0,
 
-     stackClearing: true
 
-   }, null, null, null, {
 
-     id: "hstemhm",
 
-     min: 2,
 
-     stackClearing: true,
 
-     stem: true
 
-   }, {
 
-     id: "hintmask",
 
-     min: 0,
 
-     stackClearing: true
 
-   }, {
 
-     id: "cntrmask",
 
-     min: 0,
 
-     stackClearing: true
 
-   }, {
 
-     id: "rmoveto",
 
-     min: 2,
 
-     stackClearing: true
 
-   }, {
 
-     id: "hmoveto",
 
-     min: 1,
 
-     stackClearing: true
 
-   }, {
 
-     id: "vstemhm",
 
-     min: 2,
 
-     stackClearing: true,
 
-     stem: true
 
-   }, {
 
-     id: "rcurveline",
 
-     min: 8,
 
-     resetStack: true
 
-   }, {
 
-     id: "rlinecurve",
 
-     min: 8,
 
-     resetStack: true
 
-   }, {
 
-     id: "vvcurveto",
 
-     min: 4,
 
-     resetStack: true
 
-   }, {
 
-     id: "hhcurveto",
 
-     min: 4,
 
-     resetStack: true
 
-   }, null, {
 
-     id: "callgsubr",
 
-     min: 1,
 
-     undefStack: true
 
-   }, {
 
-     id: "vhcurveto",
 
-     min: 4,
 
-     resetStack: true
 
-   }, {
 
-     id: "hvcurveto",
 
-     min: 4,
 
-     resetStack: true
 
-   }];
 
-   var CharstringValidationData12 = [null, null, null, {
 
-     id: "and",
 
-     min: 2,
 
-     stackDelta: -1
 
-   }, {
 
-     id: "or",
 
-     min: 2,
 
-     stackDelta: -1
 
-   }, {
 
-     id: "not",
 
-     min: 1,
 
-     stackDelta: 0
 
-   }, null, null, null, {
 
-     id: "abs",
 
-     min: 1,
 
-     stackDelta: 0
 
-   }, {
 
-     id: "add",
 
-     min: 2,
 
-     stackDelta: -1,
 
-     stackFn: function stack_div(stack, index) {
 
-       stack[index - 2] = stack[index - 2] + stack[index - 1];
 
-     }
 
-   }, {
 
-     id: "sub",
 
-     min: 2,
 
-     stackDelta: -1,
 
-     stackFn: function stack_div(stack, index) {
 
-       stack[index - 2] = stack[index - 2] - stack[index - 1];
 
-     }
 
-   }, {
 
-     id: "div",
 
-     min: 2,
 
-     stackDelta: -1,
 
-     stackFn: function stack_div(stack, index) {
 
-       stack[index - 2] = stack[index - 2] / stack[index - 1];
 
-     }
 
-   }, null, {
 
-     id: "neg",
 
-     min: 1,
 
-     stackDelta: 0,
 
-     stackFn: function stack_div(stack, index) {
 
-       stack[index - 1] = -stack[index - 1];
 
-     }
 
-   }, {
 
-     id: "eq",
 
-     min: 2,
 
-     stackDelta: -1
 
-   }, null, null, {
 
-     id: "drop",
 
-     min: 1,
 
-     stackDelta: -1
 
-   }, null, {
 
-     id: "put",
 
-     min: 2,
 
-     stackDelta: -2
 
-   }, {
 
-     id: "get",
 
-     min: 1,
 
-     stackDelta: 0
 
-   }, {
 
-     id: "ifelse",
 
-     min: 4,
 
-     stackDelta: -3
 
-   }, {
 
-     id: "random",
 
-     min: 0,
 
-     stackDelta: 1
 
-   }, {
 
-     id: "mul",
 
-     min: 2,
 
-     stackDelta: -1,
 
-     stackFn: function stack_div(stack, index) {
 
-       stack[index - 2] = stack[index - 2] * stack[index - 1];
 
-     }
 
-   }, null, {
 
-     id: "sqrt",
 
-     min: 1,
 
-     stackDelta: 0
 
-   }, {
 
-     id: "dup",
 
-     min: 1,
 
-     stackDelta: 1
 
-   }, {
 
-     id: "exch",
 
-     min: 2,
 
-     stackDelta: 0
 
-   }, {
 
-     id: "index",
 
-     min: 2,
 
-     stackDelta: 0
 
-   }, {
 
-     id: "roll",
 
-     min: 3,
 
-     stackDelta: -2
 
-   }, null, null, null, {
 
-     id: "hflex",
 
-     min: 7,
 
-     resetStack: true
 
-   }, {
 
-     id: "flex",
 
-     min: 13,
 
-     resetStack: true
 
-   }, {
 
-     id: "hflex1",
 
-     min: 9,
 
-     resetStack: true
 
-   }, {
 
-     id: "flex1",
 
-     min: 11,
 
-     resetStack: true
 
-   }];
 
-   function CFFParser(file, properties, seacAnalysisEnabled) {
 
-     this.bytes = file.getBytes();
 
-     this.properties = properties;
 
-     this.seacAnalysisEnabled = !!seacAnalysisEnabled;
 
-   }
 
-   CFFParser.prototype = {
 
-     parse: function CFFParser_parse() {
 
-       var properties = this.properties;
 
-       var cff = new CFF();
 
-       this.cff = cff;
 
-       var header = this.parseHeader();
 
-       var nameIndex = this.parseIndex(header.endPos);
 
-       var topDictIndex = this.parseIndex(nameIndex.endPos);
 
-       var stringIndex = this.parseIndex(topDictIndex.endPos);
 
-       var globalSubrIndex = this.parseIndex(stringIndex.endPos);
 
-       var topDictParsed = this.parseDict(topDictIndex.obj.get(0));
 
-       var topDict = this.createDict(CFFTopDict, topDictParsed, cff.strings);
 
-       cff.header = header.obj;
 
-       cff.names = this.parseNameIndex(nameIndex.obj);
 
-       cff.strings = this.parseStringIndex(stringIndex.obj);
 
-       cff.topDict = topDict;
 
-       cff.globalSubrIndex = globalSubrIndex.obj;
 
-       this.parsePrivateDict(cff.topDict);
 
-       cff.isCIDFont = topDict.hasName("ROS");
 
-       var charStringOffset = topDict.getByName("CharStrings");
 
-       var charStringIndex = this.parseIndex(charStringOffset).obj;
 
-       var fontMatrix = topDict.getByName("FontMatrix");
 
-       if (fontMatrix) {
 
-         properties.fontMatrix = fontMatrix;
 
-       }
 
-       var fontBBox = topDict.getByName("FontBBox");
 
-       if (fontBBox) {
 
-         properties.ascent = Math.max(fontBBox[3], fontBBox[1]);
 
-         properties.descent = Math.min(fontBBox[1], fontBBox[3]);
 
-         properties.ascentScaled = true;
 
-       }
 
-       var charset, encoding;
 
-       if (cff.isCIDFont) {
 
-         var fdArrayIndex = this.parseIndex(topDict.getByName("FDArray")).obj;
 
-         for (var i = 0, ii = fdArrayIndex.count; i < ii; ++i) {
 
-           var dictRaw = fdArrayIndex.get(i);
 
-           var fontDict = this.createDict(CFFTopDict, this.parseDict(dictRaw), cff.strings);
 
-           this.parsePrivateDict(fontDict);
 
-           cff.fdArray.push(fontDict);
 
-         }
 
-         encoding = null;
 
-         charset = this.parseCharsets(topDict.getByName("charset"), charStringIndex.count, cff.strings, true);
 
-         cff.fdSelect = this.parseFDSelect(topDict.getByName("FDSelect"), charStringIndex.count);
 
-       } else {
 
-         charset = this.parseCharsets(topDict.getByName("charset"), charStringIndex.count, cff.strings, false);
 
-         encoding = this.parseEncoding(topDict.getByName("Encoding"), properties, cff.strings, charset.charset);
 
-       }
 
-       cff.charset = charset;
 
-       cff.encoding = encoding;
 
-       var charStringsAndSeacs = this.parseCharStrings({
 
-         charStrings: charStringIndex,
 
-         localSubrIndex: topDict.privateDict.subrsIndex,
 
-         globalSubrIndex: globalSubrIndex.obj,
 
-         fdSelect: cff.fdSelect,
 
-         fdArray: cff.fdArray,
 
-         privateDict: topDict.privateDict
 
-       });
 
-       cff.charStrings = charStringsAndSeacs.charStrings;
 
-       cff.seacs = charStringsAndSeacs.seacs;
 
-       cff.widths = charStringsAndSeacs.widths;
 
-       return cff;
 
-     },
 
-     parseHeader: function CFFParser_parseHeader() {
 
-       var bytes = this.bytes;
 
-       var bytesLength = bytes.length;
 
-       var offset = 0;
 
-       while (offset < bytesLength && bytes[offset] !== 1) {
 
-         ++offset;
 
-       }
 
-       if (offset >= bytesLength) {
 
-         throw new _util.FormatError("Invalid CFF header");
 
-       }
 
-       if (offset !== 0) {
 
-         (0, _util.info)("cff data is shifted");
 
-         bytes = bytes.subarray(offset);
 
-         this.bytes = bytes;
 
-       }
 
-       var major = bytes[0];
 
-       var minor = bytes[1];
 
-       var hdrSize = bytes[2];
 
-       var offSize = bytes[3];
 
-       var header = new CFFHeader(major, minor, hdrSize, offSize);
 
-       return {
 
-         obj: header,
 
-         endPos: hdrSize
 
-       };
 
-     },
 
-     parseDict: function CFFParser_parseDict(dict) {
 
-       var pos = 0;
 
-       function parseOperand() {
 
-         var value = dict[pos++];
 
-         if (value === 30) {
 
-           return parseFloatOperand();
 
-         } else if (value === 28) {
 
-           value = dict[pos++];
 
-           value = (value << 24 | dict[pos++] << 16) >> 16;
 
-           return value;
 
-         } else if (value === 29) {
 
-           value = dict[pos++];
 
-           value = value << 8 | dict[pos++];
 
-           value = value << 8 | dict[pos++];
 
-           value = value << 8 | dict[pos++];
 
-           return value;
 
-         } else if (value >= 32 && value <= 246) {
 
-           return value - 139;
 
-         } else if (value >= 247 && value <= 250) {
 
-           return (value - 247) * 256 + dict[pos++] + 108;
 
-         } else if (value >= 251 && value <= 254) {
 
-           return -((value - 251) * 256) - dict[pos++] - 108;
 
-         }
 
-         (0, _util.warn)('CFFParser_parseDict: "' + value + '" is a reserved command.');
 
-         return NaN;
 
-       }
 
-       function parseFloatOperand() {
 
-         var str = "";
 
-         var eof = 15;
 
-         const lookup = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", ".", "E", "E-", null, "-"];
 
-         var length = dict.length;
 
-         while (pos < length) {
 
-           var b = dict[pos++];
 
-           var b1 = b >> 4;
 
-           var b2 = b & 15;
 
-           if (b1 === eof) {
 
-             break;
 
-           }
 
-           str += lookup[b1];
 
-           if (b2 === eof) {
 
-             break;
 
-           }
 
-           str += lookup[b2];
 
-         }
 
-         return parseFloat(str);
 
-       }
 
-       var operands = [];
 
-       var entries = [];
 
-       pos = 0;
 
-       var end = dict.length;
 
-       while (pos < end) {
 
-         var b = dict[pos];
 
-         if (b <= 21) {
 
-           if (b === 12) {
 
-             b = b << 8 | dict[++pos];
 
-           }
 
-           entries.push([b, operands]);
 
-           operands = [];
 
-           ++pos;
 
-         } else {
 
-           operands.push(parseOperand());
 
-         }
 
-       }
 
-       return entries;
 
-     },
 
-     parseIndex: function CFFParser_parseIndex(pos) {
 
-       var cffIndex = new CFFIndex();
 
-       var bytes = this.bytes;
 
-       var count = bytes[pos++] << 8 | bytes[pos++];
 
-       var offsets = [];
 
-       var end = pos;
 
-       var i, ii;
 
-       if (count !== 0) {
 
-         var offsetSize = bytes[pos++];
 
-         var startPos = pos + (count + 1) * offsetSize - 1;
 
-         for (i = 0, ii = count + 1; i < ii; ++i) {
 
-           var offset = 0;
 
-           for (var j = 0; j < offsetSize; ++j) {
 
-             offset <<= 8;
 
-             offset += bytes[pos++];
 
-           }
 
-           offsets.push(startPos + offset);
 
-         }
 
-         end = offsets[count];
 
-       }
 
-       for (i = 0, ii = offsets.length - 1; i < ii; ++i) {
 
-         var offsetStart = offsets[i];
 
-         var offsetEnd = offsets[i + 1];
 
-         cffIndex.add(bytes.subarray(offsetStart, offsetEnd));
 
-       }
 
-       return {
 
-         obj: cffIndex,
 
-         endPos: end
 
-       };
 
-     },
 
-     parseNameIndex: function CFFParser_parseNameIndex(index) {
 
-       var names = [];
 
-       for (var i = 0, ii = index.count; i < ii; ++i) {
 
-         var name = index.get(i);
 
-         names.push((0, _util.bytesToString)(name));
 
-       }
 
-       return names;
 
-     },
 
-     parseStringIndex: function CFFParser_parseStringIndex(index) {
 
-       var strings = new CFFStrings();
 
-       for (var i = 0, ii = index.count; i < ii; ++i) {
 
-         var data = index.get(i);
 
-         strings.add((0, _util.bytesToString)(data));
 
-       }
 
-       return strings;
 
-     },
 
-     createDict: function CFFParser_createDict(Type, dict, strings) {
 
-       var cffDict = new Type(strings);
 
-       for (var i = 0, ii = dict.length; i < ii; ++i) {
 
-         var pair = dict[i];
 
-         var key = pair[0];
 
-         var value = pair[1];
 
-         cffDict.setByKey(key, value);
 
-       }
 
-       return cffDict;
 
-     },
 
-     parseCharString: function CFFParser_parseCharString(state, data, localSubrIndex, globalSubrIndex) {
 
-       if (!data || state.callDepth > MAX_SUBR_NESTING) {
 
-         return false;
 
-       }
 
-       var stackSize = state.stackSize;
 
-       var stack = state.stack;
 
-       var length = data.length;
 
-       for (var j = 0; j < length;) {
 
-         var value = data[j++];
 
-         var validationCommand = null;
 
-         if (value === 12) {
 
-           var q = data[j++];
 
-           if (q === 0) {
 
-             data[j - 2] = 139;
 
-             data[j - 1] = 22;
 
-             stackSize = 0;
 
-           } else {
 
-             validationCommand = CharstringValidationData12[q];
 
-           }
 
-         } else if (value === 28) {
 
-           stack[stackSize] = (data[j] << 24 | data[j + 1] << 16) >> 16;
 
-           j += 2;
 
-           stackSize++;
 
-         } else if (value === 14) {
 
-           if (stackSize >= 4) {
 
-             stackSize -= 4;
 
-             if (this.seacAnalysisEnabled) {
 
-               state.seac = stack.slice(stackSize, stackSize + 4);
 
-               return false;
 
-             }
 
-           }
 
-           validationCommand = CharstringValidationData[value];
 
-         } else if (value >= 32 && value <= 246) {
 
-           stack[stackSize] = value - 139;
 
-           stackSize++;
 
-         } else if (value >= 247 && value <= 254) {
 
-           stack[stackSize] = value < 251 ? (value - 247 << 8) + data[j] + 108 : -(value - 251 << 8) - data[j] - 108;
 
-           j++;
 
-           stackSize++;
 
-         } else if (value === 255) {
 
-           stack[stackSize] = (data[j] << 24 | data[j + 1] << 16 | data[j + 2] << 8 | data[j + 3]) / 65536;
 
-           j += 4;
 
-           stackSize++;
 
-         } else if (value === 19 || value === 20) {
 
-           state.hints += stackSize >> 1;
 
-           j += state.hints + 7 >> 3;
 
-           stackSize %= 2;
 
-           validationCommand = CharstringValidationData[value];
 
-         } else if (value === 10 || value === 29) {
 
-           var subrsIndex;
 
-           if (value === 10) {
 
-             subrsIndex = localSubrIndex;
 
-           } else {
 
-             subrsIndex = globalSubrIndex;
 
-           }
 
-           if (!subrsIndex) {
 
-             validationCommand = CharstringValidationData[value];
 
-             (0, _util.warn)("Missing subrsIndex for " + validationCommand.id);
 
-             return false;
 
-           }
 
-           var bias = 32768;
 
-           if (subrsIndex.count < 1240) {
 
-             bias = 107;
 
-           } else if (subrsIndex.count < 33900) {
 
-             bias = 1131;
 
-           }
 
-           var subrNumber = stack[--stackSize] + bias;
 
-           if (subrNumber < 0 || subrNumber >= subrsIndex.count || isNaN(subrNumber)) {
 
-             validationCommand = CharstringValidationData[value];
 
-             (0, _util.warn)("Out of bounds subrIndex for " + validationCommand.id);
 
-             return false;
 
-           }
 
-           state.stackSize = stackSize;
 
-           state.callDepth++;
 
-           var valid = this.parseCharString(state, subrsIndex.get(subrNumber), localSubrIndex, globalSubrIndex);
 
-           if (!valid) {
 
-             return false;
 
-           }
 
-           state.callDepth--;
 
-           stackSize = state.stackSize;
 
-           continue;
 
-         } else if (value === 11) {
 
-           state.stackSize = stackSize;
 
-           return true;
 
-         } else {
 
-           validationCommand = CharstringValidationData[value];
 
-         }
 
-         if (validationCommand) {
 
-           if (validationCommand.stem) {
 
-             state.hints += stackSize >> 1;
 
-             if (value === 3 || value === 23) {
 
-               state.hasVStems = true;
 
-             } else if (state.hasVStems && (value === 1 || value === 18)) {
 
-               (0, _util.warn)("CFF stem hints are in wrong order");
 
-               data[j - 1] = value === 1 ? 3 : 23;
 
-             }
 
-           }
 
-           if ("min" in validationCommand) {
 
-             if (!state.undefStack && stackSize < validationCommand.min) {
 
-               (0, _util.warn)("Not enough parameters for " + validationCommand.id + "; actual: " + stackSize + ", expected: " + validationCommand.min);
 
-               return false;
 
-             }
 
-           }
 
-           if (state.firstStackClearing && validationCommand.stackClearing) {
 
-             state.firstStackClearing = false;
 
-             stackSize -= validationCommand.min;
 
-             if (stackSize >= 2 && validationCommand.stem) {
 
-               stackSize %= 2;
 
-             } else if (stackSize > 1) {
 
-               (0, _util.warn)("Found too many parameters for stack-clearing command");
 
-             }
 
-             if (stackSize > 0 && stack[stackSize - 1] >= 0) {
 
-               state.width = stack[stackSize - 1];
 
-             }
 
-           }
 
-           if ("stackDelta" in validationCommand) {
 
-             if ("stackFn" in validationCommand) {
 
-               validationCommand.stackFn(stack, stackSize);
 
-             }
 
-             stackSize += validationCommand.stackDelta;
 
-           } else if (validationCommand.stackClearing) {
 
-             stackSize = 0;
 
-           } else if (validationCommand.resetStack) {
 
-             stackSize = 0;
 
-             state.undefStack = false;
 
-           } else if (validationCommand.undefStack) {
 
-             stackSize = 0;
 
-             state.undefStack = true;
 
-             state.firstStackClearing = false;
 
-           }
 
-         }
 
-       }
 
-       state.stackSize = stackSize;
 
-       return true;
 
-     },
 
-     parseCharStrings({
 
-       charStrings,
 
-       localSubrIndex,
 
-       globalSubrIndex,
 
-       fdSelect,
 
-       fdArray,
 
-       privateDict
 
-     }) {
 
-       var seacs = [];
 
-       var widths = [];
 
-       var count = charStrings.count;
 
-       for (var i = 0; i < count; i++) {
 
-         var charstring = charStrings.get(i);
 
-         var state = {
 
-           callDepth: 0,
 
-           stackSize: 0,
 
-           stack: [],
 
-           undefStack: true,
 
-           hints: 0,
 
-           firstStackClearing: true,
 
-           seac: null,
 
-           width: null,
 
-           hasVStems: false
 
-         };
 
-         var valid = true;
 
-         var localSubrToUse = null;
 
-         var privateDictToUse = privateDict;
 
-         if (fdSelect && fdArray.length) {
 
-           var fdIndex = fdSelect.getFDIndex(i);
 
-           if (fdIndex === -1) {
 
-             (0, _util.warn)("Glyph index is not in fd select.");
 
-             valid = false;
 
-           }
 
-           if (fdIndex >= fdArray.length) {
 
-             (0, _util.warn)("Invalid fd index for glyph index.");
 
-             valid = false;
 
-           }
 
-           if (valid) {
 
-             privateDictToUse = fdArray[fdIndex].privateDict;
 
-             localSubrToUse = privateDictToUse.subrsIndex;
 
-           }
 
-         } else if (localSubrIndex) {
 
-           localSubrToUse = localSubrIndex;
 
-         }
 
-         if (valid) {
 
-           valid = this.parseCharString(state, charstring, localSubrToUse, globalSubrIndex);
 
-         }
 
-         if (state.width !== null) {
 
-           const nominalWidth = privateDictToUse.getByName("nominalWidthX");
 
-           widths[i] = nominalWidth + state.width;
 
-         } else {
 
-           const defaultWidth = privateDictToUse.getByName("defaultWidthX");
 
-           widths[i] = defaultWidth;
 
-         }
 
-         if (state.seac !== null) {
 
-           seacs[i] = state.seac;
 
-         }
 
-         if (!valid) {
 
-           charStrings.set(i, new Uint8Array([14]));
 
-         }
 
-       }
 
-       return {
 
-         charStrings,
 
-         seacs,
 
-         widths
 
-       };
 
-     },
 
-     emptyPrivateDictionary: function CFFParser_emptyPrivateDictionary(parentDict) {
 
-       var privateDict = this.createDict(CFFPrivateDict, [], parentDict.strings);
 
-       parentDict.setByKey(18, [0, 0]);
 
-       parentDict.privateDict = privateDict;
 
-     },
 
-     parsePrivateDict: function CFFParser_parsePrivateDict(parentDict) {
 
-       if (!parentDict.hasName("Private")) {
 
-         this.emptyPrivateDictionary(parentDict);
 
-         return;
 
-       }
 
-       var privateOffset = parentDict.getByName("Private");
 
-       if (!Array.isArray(privateOffset) || privateOffset.length !== 2) {
 
-         parentDict.removeByName("Private");
 
-         return;
 
-       }
 
-       var size = privateOffset[0];
 
-       var offset = privateOffset[1];
 
-       if (size === 0 || offset >= this.bytes.length) {
 
-         this.emptyPrivateDictionary(parentDict);
 
-         return;
 
-       }
 
-       var privateDictEnd = offset + size;
 
-       var dictData = this.bytes.subarray(offset, privateDictEnd);
 
-       var dict = this.parseDict(dictData);
 
-       var privateDict = this.createDict(CFFPrivateDict, dict, parentDict.strings);
 
-       parentDict.privateDict = privateDict;
 
-       if (!privateDict.getByName("Subrs")) {
 
-         return;
 
-       }
 
-       var subrsOffset = privateDict.getByName("Subrs");
 
-       var relativeOffset = offset + subrsOffset;
 
-       if (subrsOffset === 0 || relativeOffset >= this.bytes.length) {
 
-         this.emptyPrivateDictionary(parentDict);
 
-         return;
 
-       }
 
-       var subrsIndex = this.parseIndex(relativeOffset);
 
-       privateDict.subrsIndex = subrsIndex.obj;
 
-     },
 
-     parseCharsets: function CFFParser_parseCharsets(pos, length, strings, cid) {
 
-       if (pos === 0) {
 
-         return new CFFCharset(true, CFFCharsetPredefinedTypes.ISO_ADOBE, _charsets.ISOAdobeCharset);
 
-       } else if (pos === 1) {
 
-         return new CFFCharset(true, CFFCharsetPredefinedTypes.EXPERT, _charsets.ExpertCharset);
 
-       } else if (pos === 2) {
 
-         return new CFFCharset(true, CFFCharsetPredefinedTypes.EXPERT_SUBSET, _charsets.ExpertSubsetCharset);
 
-       }
 
-       var bytes = this.bytes;
 
-       var start = pos;
 
-       var format = bytes[pos++];
 
-       var charset = [".notdef"];
 
-       var id, count, i;
 
-       length -= 1;
 
-       switch (format) {
 
-         case 0:
 
-           for (i = 0; i < length; i++) {
 
-             id = bytes[pos++] << 8 | bytes[pos++];
 
-             charset.push(cid ? id : strings.get(id));
 
-           }
 
-           break;
 
-         case 1:
 
-           while (charset.length <= length) {
 
-             id = bytes[pos++] << 8 | bytes[pos++];
 
-             count = bytes[pos++];
 
-             for (i = 0; i <= count; i++) {
 
-               charset.push(cid ? id++ : strings.get(id++));
 
-             }
 
-           }
 
-           break;
 
-         case 2:
 
-           while (charset.length <= length) {
 
-             id = bytes[pos++] << 8 | bytes[pos++];
 
-             count = bytes[pos++] << 8 | bytes[pos++];
 
-             for (i = 0; i <= count; i++) {
 
-               charset.push(cid ? id++ : strings.get(id++));
 
-             }
 
-           }
 
-           break;
 
-         default:
 
-           throw new _util.FormatError("Unknown charset format");
 
-       }
 
-       var end = pos;
 
-       var raw = bytes.subarray(start, end);
 
-       return new CFFCharset(false, format, charset, raw);
 
-     },
 
-     parseEncoding: function CFFParser_parseEncoding(pos, properties, strings, charset) {
 
-       var encoding = Object.create(null);
 
-       var bytes = this.bytes;
 
-       var predefined = false;
 
-       var format, i, ii;
 
-       var raw = null;
 
-       function readSupplement() {
 
-         var supplementsCount = bytes[pos++];
 
-         for (i = 0; i < supplementsCount; i++) {
 
-           var code = bytes[pos++];
 
-           var sid = (bytes[pos++] << 8) + (bytes[pos++] & 0xff);
 
-           encoding[code] = charset.indexOf(strings.get(sid));
 
-         }
 
-       }
 
-       if (pos === 0 || pos === 1) {
 
-         predefined = true;
 
-         format = pos;
 
-         var baseEncoding = pos ? _encodings.ExpertEncoding : _encodings.StandardEncoding;
 
-         for (i = 0, ii = charset.length; i < ii; i++) {
 
-           var index = baseEncoding.indexOf(charset[i]);
 
-           if (index !== -1) {
 
-             encoding[index] = i;
 
-           }
 
-         }
 
-       } else {
 
-         var dataStart = pos;
 
-         format = bytes[pos++];
 
-         switch (format & 0x7f) {
 
-           case 0:
 
-             var glyphsCount = bytes[pos++];
 
-             for (i = 1; i <= glyphsCount; i++) {
 
-               encoding[bytes[pos++]] = i;
 
-             }
 
-             break;
 
-           case 1:
 
-             var rangesCount = bytes[pos++];
 
-             var gid = 1;
 
-             for (i = 0; i < rangesCount; i++) {
 
-               var start = bytes[pos++];
 
-               var left = bytes[pos++];
 
-               for (var j = start; j <= start + left; j++) {
 
-                 encoding[j] = gid++;
 
-               }
 
-             }
 
-             break;
 
-           default:
 
-             throw new _util.FormatError(`Unknown encoding format: ${format} in CFF`);
 
-         }
 
-         var dataEnd = pos;
 
-         if (format & 0x80) {
 
-           bytes[dataStart] &= 0x7f;
 
-           readSupplement();
 
-         }
 
-         raw = bytes.subarray(dataStart, dataEnd);
 
-       }
 
-       format = format & 0x7f;
 
-       return new CFFEncoding(predefined, format, encoding, raw);
 
-     },
 
-     parseFDSelect: function CFFParser_parseFDSelect(pos, length) {
 
-       var bytes = this.bytes;
 
-       var format = bytes[pos++];
 
-       var fdSelect = [];
 
-       var i;
 
-       switch (format) {
 
-         case 0:
 
-           for (i = 0; i < length; ++i) {
 
-             var id = bytes[pos++];
 
-             fdSelect.push(id);
 
-           }
 
-           break;
 
-         case 3:
 
-           var rangesCount = bytes[pos++] << 8 | bytes[pos++];
 
-           for (i = 0; i < rangesCount; ++i) {
 
-             var first = bytes[pos++] << 8 | bytes[pos++];
 
-             if (i === 0 && first !== 0) {
 
-               (0, _util.warn)("parseFDSelect: The first range must have a first GID of 0" + " -- trying to recover.");
 
-               first = 0;
 
-             }
 
-             var fdIndex = bytes[pos++];
 
-             var next = bytes[pos] << 8 | bytes[pos + 1];
 
-             for (var j = first; j < next; ++j) {
 
-               fdSelect.push(fdIndex);
 
-             }
 
-           }
 
-           pos += 2;
 
-           break;
 
-         default:
 
-           throw new _util.FormatError(`parseFDSelect: Unknown format "${format}".`);
 
-       }
 
-       if (fdSelect.length !== length) {
 
-         throw new _util.FormatError("parseFDSelect: Invalid font data.");
 
-       }
 
-       return new CFFFDSelect(format, fdSelect);
 
-     }
 
-   };
 
-   return CFFParser;
 
- }();
 
- exports.CFFParser = CFFParser;
 
- var CFF = function CFFClosure() {
 
-   function CFF() {
 
-     this.header = null;
 
-     this.names = [];
 
-     this.topDict = null;
 
-     this.strings = new CFFStrings();
 
-     this.globalSubrIndex = null;
 
-     this.encoding = null;
 
-     this.charset = null;
 
-     this.charStrings = null;
 
-     this.fdArray = [];
 
-     this.fdSelect = null;
 
-     this.isCIDFont = false;
 
-   }
 
-   CFF.prototype = {
 
-     duplicateFirstGlyph: function CFF_duplicateFirstGlyph() {
 
-       if (this.charStrings.count >= 65535) {
 
-         (0, _util.warn)("Not enough space in charstrings to duplicate first glyph.");
 
-         return;
 
-       }
 
-       var glyphZero = this.charStrings.get(0);
 
-       this.charStrings.add(glyphZero);
 
-       if (this.isCIDFont) {
 
-         this.fdSelect.fdSelect.push(this.fdSelect.fdSelect[0]);
 
-       }
 
-     },
 
-     hasGlyphId: function CFF_hasGlyphID(id) {
 
-       if (id < 0 || id >= this.charStrings.count) {
 
-         return false;
 
-       }
 
-       var glyph = this.charStrings.get(id);
 
-       return glyph.length > 0;
 
-     }
 
-   };
 
-   return CFF;
 
- }();
 
- exports.CFF = CFF;
 
- var CFFHeader = function CFFHeaderClosure() {
 
-   function CFFHeader(major, minor, hdrSize, offSize) {
 
-     this.major = major;
 
-     this.minor = minor;
 
-     this.hdrSize = hdrSize;
 
-     this.offSize = offSize;
 
-   }
 
-   return CFFHeader;
 
- }();
 
- exports.CFFHeader = CFFHeader;
 
- var CFFStrings = function CFFStringsClosure() {
 
-   function CFFStrings() {
 
-     this.strings = [];
 
-   }
 
-   CFFStrings.prototype = {
 
-     get: function CFFStrings_get(index) {
 
-       if (index >= 0 && index <= NUM_STANDARD_CFF_STRINGS - 1) {
 
-         return CFFStandardStrings[index];
 
-       }
 
-       if (index - NUM_STANDARD_CFF_STRINGS <= this.strings.length) {
 
-         return this.strings[index - NUM_STANDARD_CFF_STRINGS];
 
-       }
 
-       return CFFStandardStrings[0];
 
-     },
 
-     getSID: function CFFStrings_getSID(str) {
 
-       let index = CFFStandardStrings.indexOf(str);
 
-       if (index !== -1) {
 
-         return index;
 
-       }
 
-       index = this.strings.indexOf(str);
 
-       if (index !== -1) {
 
-         return index + NUM_STANDARD_CFF_STRINGS;
 
-       }
 
-       return -1;
 
-     },
 
-     add: function CFFStrings_add(value) {
 
-       this.strings.push(value);
 
-     },
 
-     get count() {
 
-       return this.strings.length;
 
-     }
 
-   };
 
-   return CFFStrings;
 
- }();
 
- exports.CFFStrings = CFFStrings;
 
- var CFFIndex = function CFFIndexClosure() {
 
-   function CFFIndex() {
 
-     this.objects = [];
 
-     this.length = 0;
 
-   }
 
-   CFFIndex.prototype = {
 
-     add: function CFFIndex_add(data) {
 
-       this.length += data.length;
 
-       this.objects.push(data);
 
-     },
 
-     set: function CFFIndex_set(index, data) {
 
-       this.length += data.length - this.objects[index].length;
 
-       this.objects[index] = data;
 
-     },
 
-     get: function CFFIndex_get(index) {
 
-       return this.objects[index];
 
-     },
 
-     get count() {
 
-       return this.objects.length;
 
-     }
 
-   };
 
-   return CFFIndex;
 
- }();
 
- exports.CFFIndex = CFFIndex;
 
- var CFFDict = function CFFDictClosure() {
 
-   function CFFDict(tables, strings) {
 
-     this.keyToNameMap = tables.keyToNameMap;
 
-     this.nameToKeyMap = tables.nameToKeyMap;
 
-     this.defaults = tables.defaults;
 
-     this.types = tables.types;
 
-     this.opcodes = tables.opcodes;
 
-     this.order = tables.order;
 
-     this.strings = strings;
 
-     this.values = Object.create(null);
 
-   }
 
-   CFFDict.prototype = {
 
-     setByKey: function CFFDict_setByKey(key, value) {
 
-       if (!(key in this.keyToNameMap)) {
 
-         return false;
 
-       }
 
-       var valueLength = value.length;
 
-       if (valueLength === 0) {
 
-         return true;
 
-       }
 
-       for (var i = 0; i < valueLength; i++) {
 
-         if (isNaN(value[i])) {
 
-           (0, _util.warn)('Invalid CFFDict value: "' + value + '" for key "' + key + '".');
 
-           return true;
 
-         }
 
-       }
 
-       var type = this.types[key];
 
-       if (type === "num" || type === "sid" || type === "offset") {
 
-         value = value[0];
 
-       }
 
-       this.values[key] = value;
 
-       return true;
 
-     },
 
-     setByName: function CFFDict_setByName(name, value) {
 
-       if (!(name in this.nameToKeyMap)) {
 
-         throw new _util.FormatError(`Invalid dictionary name "${name}"`);
 
-       }
 
-       this.values[this.nameToKeyMap[name]] = value;
 
-     },
 
-     hasName: function CFFDict_hasName(name) {
 
-       return this.nameToKeyMap[name] in this.values;
 
-     },
 
-     getByName: function CFFDict_getByName(name) {
 
-       if (!(name in this.nameToKeyMap)) {
 
-         throw new _util.FormatError(`Invalid dictionary name ${name}"`);
 
-       }
 
-       var key = this.nameToKeyMap[name];
 
-       if (!(key in this.values)) {
 
-         return this.defaults[key];
 
-       }
 
-       return this.values[key];
 
-     },
 
-     removeByName: function CFFDict_removeByName(name) {
 
-       delete this.values[this.nameToKeyMap[name]];
 
-     }
 
-   };
 
-   CFFDict.createTables = function CFFDict_createTables(layout) {
 
-     var tables = {
 
-       keyToNameMap: {},
 
-       nameToKeyMap: {},
 
-       defaults: {},
 
-       types: {},
 
-       opcodes: {},
 
-       order: []
 
-     };
 
-     for (var i = 0, ii = layout.length; i < ii; ++i) {
 
-       var entry = layout[i];
 
-       var key = Array.isArray(entry[0]) ? (entry[0][0] << 8) + entry[0][1] : entry[0];
 
-       tables.keyToNameMap[key] = entry[1];
 
-       tables.nameToKeyMap[entry[1]] = key;
 
-       tables.types[key] = entry[2];
 
-       tables.defaults[key] = entry[3];
 
-       tables.opcodes[key] = Array.isArray(entry[0]) ? entry[0] : [entry[0]];
 
-       tables.order.push(key);
 
-     }
 
-     return tables;
 
-   };
 
-   return CFFDict;
 
- }();
 
- var CFFTopDict = function CFFTopDictClosure() {
 
-   var layout = [[[12, 30], "ROS", ["sid", "sid", "num"], null], [[12, 20], "SyntheticBase", "num", null], [0, "version", "sid", null], [1, "Notice", "sid", null], [[12, 0], "Copyright", "sid", null], [2, "FullName", "sid", null], [3, "FamilyName", "sid", null], [4, "Weight", "sid", null], [[12, 1], "isFixedPitch", "num", 0], [[12, 2], "ItalicAngle", "num", 0], [[12, 3], "UnderlinePosition", "num", -100], [[12, 4], "UnderlineThickness", "num", 50], [[12, 5], "PaintType", "num", 0], [[12, 6], "CharstringType", "num", 2], [[12, 7], "FontMatrix", ["num", "num", "num", "num", "num", "num"], [0.001, 0, 0, 0.001, 0, 0]], [13, "UniqueID", "num", null], [5, "FontBBox", ["num", "num", "num", "num"], [0, 0, 0, 0]], [[12, 8], "StrokeWidth", "num", 0], [14, "XUID", "array", null], [15, "charset", "offset", 0], [16, "Encoding", "offset", 0], [17, "CharStrings", "offset", 0], [18, "Private", ["offset", "offset"], null], [[12, 21], "PostScript", "sid", null], [[12, 22], "BaseFontName", "sid", null], [[12, 23], "BaseFontBlend", "delta", null], [[12, 31], "CIDFontVersion", "num", 0], [[12, 32], "CIDFontRevision", "num", 0], [[12, 33], "CIDFontType", "num", 0], [[12, 34], "CIDCount", "num", 8720], [[12, 35], "UIDBase", "num", null], [[12, 37], "FDSelect", "offset", null], [[12, 36], "FDArray", "offset", null], [[12, 38], "FontName", "sid", null]];
 
-   var tables = null;
 
-   function CFFTopDict(strings) {
 
-     if (tables === null) {
 
-       tables = CFFDict.createTables(layout);
 
-     }
 
-     CFFDict.call(this, tables, strings);
 
-     this.privateDict = null;
 
-   }
 
-   CFFTopDict.prototype = Object.create(CFFDict.prototype);
 
-   return CFFTopDict;
 
- }();
 
- exports.CFFTopDict = CFFTopDict;
 
- var CFFPrivateDict = function CFFPrivateDictClosure() {
 
-   var layout = [[6, "BlueValues", "delta", null], [7, "OtherBlues", "delta", null], [8, "FamilyBlues", "delta", null], [9, "FamilyOtherBlues", "delta", null], [[12, 9], "BlueScale", "num", 0.039625], [[12, 10], "BlueShift", "num", 7], [[12, 11], "BlueFuzz", "num", 1], [10, "StdHW", "num", null], [11, "StdVW", "num", null], [[12, 12], "StemSnapH", "delta", null], [[12, 13], "StemSnapV", "delta", null], [[12, 14], "ForceBold", "num", 0], [[12, 17], "LanguageGroup", "num", 0], [[12, 18], "ExpansionFactor", "num", 0.06], [[12, 19], "initialRandomSeed", "num", 0], [20, "defaultWidthX", "num", 0], [21, "nominalWidthX", "num", 0], [19, "Subrs", "offset", null]];
 
-   var tables = null;
 
-   function CFFPrivateDict(strings) {
 
-     if (tables === null) {
 
-       tables = CFFDict.createTables(layout);
 
-     }
 
-     CFFDict.call(this, tables, strings);
 
-     this.subrsIndex = null;
 
-   }
 
-   CFFPrivateDict.prototype = Object.create(CFFDict.prototype);
 
-   return CFFPrivateDict;
 
- }();
 
- exports.CFFPrivateDict = CFFPrivateDict;
 
- var CFFCharsetPredefinedTypes = {
 
-   ISO_ADOBE: 0,
 
-   EXPERT: 1,
 
-   EXPERT_SUBSET: 2
 
- };
 
- var CFFCharset = function CFFCharsetClosure() {
 
-   function CFFCharset(predefined, format, charset, raw) {
 
-     this.predefined = predefined;
 
-     this.format = format;
 
-     this.charset = charset;
 
-     this.raw = raw;
 
-   }
 
-   return CFFCharset;
 
- }();
 
- exports.CFFCharset = CFFCharset;
 
- var CFFEncoding = function CFFEncodingClosure() {
 
-   function CFFEncoding(predefined, format, encoding, raw) {
 
-     this.predefined = predefined;
 
-     this.format = format;
 
-     this.encoding = encoding;
 
-     this.raw = raw;
 
-   }
 
-   return CFFEncoding;
 
- }();
 
- var CFFFDSelect = function CFFFDSelectClosure() {
 
-   function CFFFDSelect(format, fdSelect) {
 
-     this.format = format;
 
-     this.fdSelect = fdSelect;
 
-   }
 
-   CFFFDSelect.prototype = {
 
-     getFDIndex: function CFFFDSelect_get(glyphIndex) {
 
-       if (glyphIndex < 0 || glyphIndex >= this.fdSelect.length) {
 
-         return -1;
 
-       }
 
-       return this.fdSelect[glyphIndex];
 
-     }
 
-   };
 
-   return CFFFDSelect;
 
- }();
 
- exports.CFFFDSelect = CFFFDSelect;
 
- var CFFOffsetTracker = function CFFOffsetTrackerClosure() {
 
-   function CFFOffsetTracker() {
 
-     this.offsets = Object.create(null);
 
-   }
 
-   CFFOffsetTracker.prototype = {
 
-     isTracking: function CFFOffsetTracker_isTracking(key) {
 
-       return key in this.offsets;
 
-     },
 
-     track: function CFFOffsetTracker_track(key, location) {
 
-       if (key in this.offsets) {
 
-         throw new _util.FormatError(`Already tracking location of ${key}`);
 
-       }
 
-       this.offsets[key] = location;
 
-     },
 
-     offset: function CFFOffsetTracker_offset(value) {
 
-       for (var key in this.offsets) {
 
-         this.offsets[key] += value;
 
-       }
 
-     },
 
-     setEntryLocation: function CFFOffsetTracker_setEntryLocation(key, values, output) {
 
-       if (!(key in this.offsets)) {
 
-         throw new _util.FormatError(`Not tracking location of ${key}`);
 
-       }
 
-       var data = output.data;
 
-       var dataOffset = this.offsets[key];
 
-       var size = 5;
 
-       for (var i = 0, ii = values.length; i < ii; ++i) {
 
-         var offset0 = i * size + dataOffset;
 
-         var offset1 = offset0 + 1;
 
-         var offset2 = offset0 + 2;
 
-         var offset3 = offset0 + 3;
 
-         var offset4 = offset0 + 4;
 
-         if (data[offset0] !== 0x1d || data[offset1] !== 0 || data[offset2] !== 0 || data[offset3] !== 0 || data[offset4] !== 0) {
 
-           throw new _util.FormatError("writing to an offset that is not empty");
 
-         }
 
-         var value = values[i];
 
-         data[offset0] = 0x1d;
 
-         data[offset1] = value >> 24 & 0xff;
 
-         data[offset2] = value >> 16 & 0xff;
 
-         data[offset3] = value >> 8 & 0xff;
 
-         data[offset4] = value & 0xff;
 
-       }
 
-     }
 
-   };
 
-   return CFFOffsetTracker;
 
- }();
 
- var CFFCompiler = function CFFCompilerClosure() {
 
-   function CFFCompiler(cff) {
 
-     this.cff = cff;
 
-   }
 
-   CFFCompiler.prototype = {
 
-     compile: function CFFCompiler_compile() {
 
-       var cff = this.cff;
 
-       var output = {
 
-         data: [],
 
-         length: 0,
 
-         add: function CFFCompiler_add(data) {
 
-           this.data = this.data.concat(data);
 
-           this.length = this.data.length;
 
-         }
 
-       };
 
-       var header = this.compileHeader(cff.header);
 
-       output.add(header);
 
-       var nameIndex = this.compileNameIndex(cff.names);
 
-       output.add(nameIndex);
 
-       if (cff.isCIDFont) {
 
-         if (cff.topDict.hasName("FontMatrix")) {
 
-           var base = cff.topDict.getByName("FontMatrix");
 
-           cff.topDict.removeByName("FontMatrix");
 
-           for (var i = 0, ii = cff.fdArray.length; i < ii; i++) {
 
-             var subDict = cff.fdArray[i];
 
-             var matrix = base.slice(0);
 
-             if (subDict.hasName("FontMatrix")) {
 
-               matrix = _util.Util.transform(matrix, subDict.getByName("FontMatrix"));
 
-             }
 
-             subDict.setByName("FontMatrix", matrix);
 
-           }
 
-         }
 
-       }
 
-       cff.topDict.setByName("charset", 0);
 
-       var compiled = this.compileTopDicts([cff.topDict], output.length, cff.isCIDFont);
 
-       output.add(compiled.output);
 
-       var topDictTracker = compiled.trackers[0];
 
-       var stringIndex = this.compileStringIndex(cff.strings.strings);
 
-       output.add(stringIndex);
 
-       var globalSubrIndex = this.compileIndex(cff.globalSubrIndex);
 
-       output.add(globalSubrIndex);
 
-       if (cff.encoding && cff.topDict.hasName("Encoding")) {
 
-         if (cff.encoding.predefined) {
 
-           topDictTracker.setEntryLocation("Encoding", [cff.encoding.format], output);
 
-         } else {
 
-           var encoding = this.compileEncoding(cff.encoding);
 
-           topDictTracker.setEntryLocation("Encoding", [output.length], output);
 
-           output.add(encoding);
 
-         }
 
-       }
 
-       var charset = this.compileCharset(cff.charset, cff.charStrings.count, cff.strings, cff.isCIDFont);
 
-       topDictTracker.setEntryLocation("charset", [output.length], output);
 
-       output.add(charset);
 
-       var charStrings = this.compileCharStrings(cff.charStrings);
 
-       topDictTracker.setEntryLocation("CharStrings", [output.length], output);
 
-       output.add(charStrings);
 
-       if (cff.isCIDFont) {
 
-         topDictTracker.setEntryLocation("FDSelect", [output.length], output);
 
-         var fdSelect = this.compileFDSelect(cff.fdSelect);
 
-         output.add(fdSelect);
 
-         compiled = this.compileTopDicts(cff.fdArray, output.length, true);
 
-         topDictTracker.setEntryLocation("FDArray", [output.length], output);
 
-         output.add(compiled.output);
 
-         var fontDictTrackers = compiled.trackers;
 
-         this.compilePrivateDicts(cff.fdArray, fontDictTrackers, output);
 
-       }
 
-       this.compilePrivateDicts([cff.topDict], [topDictTracker], output);
 
-       output.add([0]);
 
-       return output.data;
 
-     },
 
-     encodeNumber: function CFFCompiler_encodeNumber(value) {
 
-       if (parseFloat(value) === parseInt(value, 10) && !isNaN(value)) {
 
-         return this.encodeInteger(value);
 
-       }
 
-       return this.encodeFloat(value);
 
-     },
 
-     encodeFloat: function CFFCompiler_encodeFloat(num) {
 
-       var value = num.toString();
 
-       var m = /\.(\d*?)(?:9{5,20}|0{5,20})\d{0,2}(?:e(.+)|$)/.exec(value);
 
-       if (m) {
 
-         var epsilon = parseFloat("1e" + ((m[2] ? +m[2] : 0) + m[1].length));
 
-         value = (Math.round(num * epsilon) / epsilon).toString();
 
-       }
 
-       var nibbles = "";
 
-       var i, ii;
 
-       for (i = 0, ii = value.length; i < ii; ++i) {
 
-         var a = value[i];
 
-         if (a === "e") {
 
-           nibbles += value[++i] === "-" ? "c" : "b";
 
-         } else if (a === ".") {
 
-           nibbles += "a";
 
-         } else if (a === "-") {
 
-           nibbles += "e";
 
-         } else {
 
-           nibbles += a;
 
-         }
 
-       }
 
-       nibbles += nibbles.length & 1 ? "f" : "ff";
 
-       var out = [30];
 
-       for (i = 0, ii = nibbles.length; i < ii; i += 2) {
 
-         out.push(parseInt(nibbles.substring(i, i + 2), 16));
 
-       }
 
-       return out;
 
-     },
 
-     encodeInteger: function CFFCompiler_encodeInteger(value) {
 
-       var code;
 
-       if (value >= -107 && value <= 107) {
 
-         code = [value + 139];
 
-       } else if (value >= 108 && value <= 1131) {
 
-         value = value - 108;
 
-         code = [(value >> 8) + 247, value & 0xff];
 
-       } else if (value >= -1131 && value <= -108) {
 
-         value = -value - 108;
 
-         code = [(value >> 8) + 251, value & 0xff];
 
-       } else if (value >= -32768 && value <= 32767) {
 
-         code = [0x1c, value >> 8 & 0xff, value & 0xff];
 
-       } else {
 
-         code = [0x1d, value >> 24 & 0xff, value >> 16 & 0xff, value >> 8 & 0xff, value & 0xff];
 
-       }
 
-       return code;
 
-     },
 
-     compileHeader: function CFFCompiler_compileHeader(header) {
 
-       return [header.major, header.minor, header.hdrSize, header.offSize];
 
-     },
 
-     compileNameIndex: function CFFCompiler_compileNameIndex(names) {
 
-       var nameIndex = new CFFIndex();
 
-       for (var i = 0, ii = names.length; i < ii; ++i) {
 
-         var name = names[i];
 
-         var length = Math.min(name.length, 127);
 
-         var sanitizedName = new Array(length);
 
-         for (var j = 0; j < length; j++) {
 
-           var char = name[j];
 
-           if (char < "!" || char > "~" || char === "[" || char === "]" || char === "(" || char === ")" || char === "{" || char === "}" || char === "<" || char === ">" || char === "/" || char === "%") {
 
-             char = "_";
 
-           }
 
-           sanitizedName[j] = char;
 
-         }
 
-         sanitizedName = sanitizedName.join("");
 
-         if (sanitizedName === "") {
 
-           sanitizedName = "Bad_Font_Name";
 
-         }
 
-         nameIndex.add((0, _util.stringToBytes)(sanitizedName));
 
-       }
 
-       return this.compileIndex(nameIndex);
 
-     },
 
-     compileTopDicts: function CFFCompiler_compileTopDicts(dicts, length, removeCidKeys) {
 
-       var fontDictTrackers = [];
 
-       var fdArrayIndex = new CFFIndex();
 
-       for (var i = 0, ii = dicts.length; i < ii; ++i) {
 
-         var fontDict = dicts[i];
 
-         if (removeCidKeys) {
 
-           fontDict.removeByName("CIDFontVersion");
 
-           fontDict.removeByName("CIDFontRevision");
 
-           fontDict.removeByName("CIDFontType");
 
-           fontDict.removeByName("CIDCount");
 
-           fontDict.removeByName("UIDBase");
 
-         }
 
-         var fontDictTracker = new CFFOffsetTracker();
 
-         var fontDictData = this.compileDict(fontDict, fontDictTracker);
 
-         fontDictTrackers.push(fontDictTracker);
 
-         fdArrayIndex.add(fontDictData);
 
-         fontDictTracker.offset(length);
 
-       }
 
-       fdArrayIndex = this.compileIndex(fdArrayIndex, fontDictTrackers);
 
-       return {
 
-         trackers: fontDictTrackers,
 
-         output: fdArrayIndex
 
-       };
 
-     },
 
-     compilePrivateDicts: function CFFCompiler_compilePrivateDicts(dicts, trackers, output) {
 
-       for (var i = 0, ii = dicts.length; i < ii; ++i) {
 
-         var fontDict = dicts[i];
 
-         var privateDict = fontDict.privateDict;
 
-         if (!privateDict || !fontDict.hasName("Private")) {
 
-           throw new _util.FormatError("There must be a private dictionary.");
 
-         }
 
-         var privateDictTracker = new CFFOffsetTracker();
 
-         var privateDictData = this.compileDict(privateDict, privateDictTracker);
 
-         var outputLength = output.length;
 
-         privateDictTracker.offset(outputLength);
 
-         if (!privateDictData.length) {
 
-           outputLength = 0;
 
-         }
 
-         trackers[i].setEntryLocation("Private", [privateDictData.length, outputLength], output);
 
-         output.add(privateDictData);
 
-         if (privateDict.subrsIndex && privateDict.hasName("Subrs")) {
 
-           var subrs = this.compileIndex(privateDict.subrsIndex);
 
-           privateDictTracker.setEntryLocation("Subrs", [privateDictData.length], output);
 
-           output.add(subrs);
 
-         }
 
-       }
 
-     },
 
-     compileDict: function CFFCompiler_compileDict(dict, offsetTracker) {
 
-       var out = [];
 
-       var order = dict.order;
 
-       for (var i = 0; i < order.length; ++i) {
 
-         var key = order[i];
 
-         if (!(key in dict.values)) {
 
-           continue;
 
-         }
 
-         var values = dict.values[key];
 
-         var types = dict.types[key];
 
-         if (!Array.isArray(types)) {
 
-           types = [types];
 
-         }
 
-         if (!Array.isArray(values)) {
 
-           values = [values];
 
-         }
 
-         if (values.length === 0) {
 
-           continue;
 
-         }
 
-         for (var j = 0, jj = types.length; j < jj; ++j) {
 
-           var type = types[j];
 
-           var value = values[j];
 
-           switch (type) {
 
-             case "num":
 
-             case "sid":
 
-               out = out.concat(this.encodeNumber(value));
 
-               break;
 
-             case "offset":
 
-               var name = dict.keyToNameMap[key];
 
-               if (!offsetTracker.isTracking(name)) {
 
-                 offsetTracker.track(name, out.length);
 
-               }
 
-               out = out.concat([0x1d, 0, 0, 0, 0]);
 
-               break;
 
-             case "array":
 
-             case "delta":
 
-               out = out.concat(this.encodeNumber(value));
 
-               for (var k = 1, kk = values.length; k < kk; ++k) {
 
-                 out = out.concat(this.encodeNumber(values[k]));
 
-               }
 
-               break;
 
-             default:
 
-               throw new _util.FormatError(`Unknown data type of ${type}`);
 
-           }
 
-         }
 
-         out = out.concat(dict.opcodes[key]);
 
-       }
 
-       return out;
 
-     },
 
-     compileStringIndex: function CFFCompiler_compileStringIndex(strings) {
 
-       var stringIndex = new CFFIndex();
 
-       for (var i = 0, ii = strings.length; i < ii; ++i) {
 
-         stringIndex.add((0, _util.stringToBytes)(strings[i]));
 
-       }
 
-       return this.compileIndex(stringIndex);
 
-     },
 
-     compileGlobalSubrIndex: function CFFCompiler_compileGlobalSubrIndex() {
 
-       var globalSubrIndex = this.cff.globalSubrIndex;
 
-       this.out.writeByteArray(this.compileIndex(globalSubrIndex));
 
-     },
 
-     compileCharStrings: function CFFCompiler_compileCharStrings(charStrings) {
 
-       var charStringsIndex = new CFFIndex();
 
-       for (var i = 0; i < charStrings.count; i++) {
 
-         var glyph = charStrings.get(i);
 
-         if (glyph.length === 0) {
 
-           charStringsIndex.add(new Uint8Array([0x8b, 0x0e]));
 
-           continue;
 
-         }
 
-         charStringsIndex.add(glyph);
 
-       }
 
-       return this.compileIndex(charStringsIndex);
 
-     },
 
-     compileCharset: function CFFCompiler_compileCharset(charset, numGlyphs, strings, isCIDFont) {
 
-       let out;
 
-       const numGlyphsLessNotDef = numGlyphs - 1;
 
-       if (isCIDFont) {
 
-         out = new Uint8Array([2, 0, 0, numGlyphsLessNotDef >> 8 & 0xff, numGlyphsLessNotDef & 0xff]);
 
-       } else {
 
-         const length = 1 + numGlyphsLessNotDef * 2;
 
-         out = new Uint8Array(length);
 
-         out[0] = 0;
 
-         let charsetIndex = 0;
 
-         const numCharsets = charset.charset.length;
 
-         let warned = false;
 
-         for (let i = 1; i < out.length; i += 2) {
 
-           let sid = 0;
 
-           if (charsetIndex < numCharsets) {
 
-             const name = charset.charset[charsetIndex++];
 
-             sid = strings.getSID(name);
 
-             if (sid === -1) {
 
-               sid = 0;
 
-               if (!warned) {
 
-                 warned = true;
 
-                 (0, _util.warn)(`Couldn't find ${name} in CFF strings`);
 
-               }
 
-             }
 
-           }
 
-           out[i] = sid >> 8 & 0xff;
 
-           out[i + 1] = sid & 0xff;
 
-         }
 
-       }
 
-       return this.compileTypedArray(out);
 
-     },
 
-     compileEncoding: function CFFCompiler_compileEncoding(encoding) {
 
-       return this.compileTypedArray(encoding.raw);
 
-     },
 
-     compileFDSelect: function CFFCompiler_compileFDSelect(fdSelect) {
 
-       const format = fdSelect.format;
 
-       let out, i;
 
-       switch (format) {
 
-         case 0:
 
-           out = new Uint8Array(1 + fdSelect.fdSelect.length);
 
-           out[0] = format;
 
-           for (i = 0; i < fdSelect.fdSelect.length; i++) {
 
-             out[i + 1] = fdSelect.fdSelect[i];
 
-           }
 
-           break;
 
-         case 3:
 
-           const start = 0;
 
-           let lastFD = fdSelect.fdSelect[0];
 
-           const ranges = [format, 0, 0, start >> 8 & 0xff, start & 0xff, lastFD];
 
-           for (i = 1; i < fdSelect.fdSelect.length; i++) {
 
-             const currentFD = fdSelect.fdSelect[i];
 
-             if (currentFD !== lastFD) {
 
-               ranges.push(i >> 8 & 0xff, i & 0xff, currentFD);
 
-               lastFD = currentFD;
 
-             }
 
-           }
 
-           const numRanges = (ranges.length - 3) / 3;
 
-           ranges[1] = numRanges >> 8 & 0xff;
 
-           ranges[2] = numRanges & 0xff;
 
-           ranges.push(i >> 8 & 0xff, i & 0xff);
 
-           out = new Uint8Array(ranges);
 
-           break;
 
-       }
 
-       return this.compileTypedArray(out);
 
-     },
 
-     compileTypedArray: function CFFCompiler_compileTypedArray(data) {
 
-       var out = [];
 
-       for (var i = 0, ii = data.length; i < ii; ++i) {
 
-         out[i] = data[i];
 
-       }
 
-       return out;
 
-     },
 
-     compileIndex: function CFFCompiler_compileIndex(index, trackers) {
 
-       trackers = trackers || [];
 
-       var objects = index.objects;
 
-       var count = objects.length;
 
-       if (count === 0) {
 
-         return [0, 0, 0];
 
-       }
 
-       var data = [count >> 8 & 0xff, count & 0xff];
 
-       var lastOffset = 1,
 
-           i;
 
-       for (i = 0; i < count; ++i) {
 
-         lastOffset += objects[i].length;
 
-       }
 
-       var offsetSize;
 
-       if (lastOffset < 0x100) {
 
-         offsetSize = 1;
 
-       } else if (lastOffset < 0x10000) {
 
-         offsetSize = 2;
 
-       } else if (lastOffset < 0x1000000) {
 
-         offsetSize = 3;
 
-       } else {
 
-         offsetSize = 4;
 
-       }
 
-       data.push(offsetSize);
 
-       var relativeOffset = 1;
 
-       for (i = 0; i < count + 1; i++) {
 
-         if (offsetSize === 1) {
 
-           data.push(relativeOffset & 0xff);
 
-         } else if (offsetSize === 2) {
 
-           data.push(relativeOffset >> 8 & 0xff, relativeOffset & 0xff);
 
-         } else if (offsetSize === 3) {
 
-           data.push(relativeOffset >> 16 & 0xff, relativeOffset >> 8 & 0xff, relativeOffset & 0xff);
 
-         } else {
 
-           data.push(relativeOffset >>> 24 & 0xff, relativeOffset >> 16 & 0xff, relativeOffset >> 8 & 0xff, relativeOffset & 0xff);
 
-         }
 
-         if (objects[i]) {
 
-           relativeOffset += objects[i].length;
 
-         }
 
-       }
 
-       for (i = 0; i < count; i++) {
 
-         if (trackers[i]) {
 
-           trackers[i].offset(data.length);
 
-         }
 
-         for (var j = 0, jj = objects[i].length; j < jj; j++) {
 
-           data.push(objects[i][j]);
 
-         }
 
-       }
 
-       return data;
 
-     }
 
-   };
 
-   return CFFCompiler;
 
- }();
 
- exports.CFFCompiler = CFFCompiler;
 
- /***/ }),
 
- /* 29 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.ExpertSubsetCharset = exports.ExpertCharset = exports.ISOAdobeCharset = void 0;
 
- const ISOAdobeCharset = [".notdef", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quoteright", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "quoteleft", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "exclamdown", "cent", "sterling", "fraction", "yen", "florin", "section", "currency", "quotesingle", "quotedblleft", "guillemotleft", "guilsinglleft", "guilsinglright", "fi", "fl", "endash", "dagger", "daggerdbl", "periodcentered", "paragraph", "bullet", "quotesinglbase", "quotedblbase", "quotedblright", "guillemotright", "ellipsis", "perthousand", "questiondown", "grave", "acute", "circumflex", "tilde", "macron", "breve", "dotaccent", "dieresis", "ring", "cedilla", "hungarumlaut", "ogonek", "caron", "emdash", "AE", "ordfeminine", "Lslash", "Oslash", "OE", "ordmasculine", "ae", "dotlessi", "lslash", "oslash", "oe", "germandbls", "onesuperior", "logicalnot", "mu", "trademark", "Eth", "onehalf", "plusminus", "Thorn", "onequarter", "divide", "brokenbar", "degree", "thorn", "threequarters", "twosuperior", "registered", "minus", "eth", "multiply", "threesuperior", "copyright", "Aacute", "Acircumflex", "Adieresis", "Agrave", "Aring", "Atilde", "Ccedilla", "Eacute", "Ecircumflex", "Edieresis", "Egrave", "Iacute", "Icircumflex", "Idieresis", "Igrave", "Ntilde", "Oacute", "Ocircumflex", "Odieresis", "Ograve", "Otilde", "Scaron", "Uacute", "Ucircumflex", "Udieresis", "Ugrave", "Yacute", "Ydieresis", "Zcaron", "aacute", "acircumflex", "adieresis", "agrave", "aring", "atilde", "ccedilla", "eacute", "ecircumflex", "edieresis", "egrave", "iacute", "icircumflex", "idieresis", "igrave", "ntilde", "oacute", "ocircumflex", "odieresis", "ograve", "otilde", "scaron", "uacute", "ucircumflex", "udieresis", "ugrave", "yacute", "ydieresis", "zcaron"];
 
- exports.ISOAdobeCharset = ISOAdobeCharset;
 
- const ExpertCharset = [".notdef", "space", "exclamsmall", "Hungarumlautsmall", "dollaroldstyle", "dollarsuperior", "ampersandsmall", "Acutesmall", "parenleftsuperior", "parenrightsuperior", "twodotenleader", "onedotenleader", "comma", "hyphen", "period", "fraction", "zerooldstyle", "oneoldstyle", "twooldstyle", "threeoldstyle", "fouroldstyle", "fiveoldstyle", "sixoldstyle", "sevenoldstyle", "eightoldstyle", "nineoldstyle", "colon", "semicolon", "commasuperior", "threequartersemdash", "periodsuperior", "questionsmall", "asuperior", "bsuperior", "centsuperior", "dsuperior", "esuperior", "isuperior", "lsuperior", "msuperior", "nsuperior", "osuperior", "rsuperior", "ssuperior", "tsuperior", "ff", "fi", "fl", "ffi", "ffl", "parenleftinferior", "parenrightinferior", "Circumflexsmall", "hyphensuperior", "Gravesmall", "Asmall", "Bsmall", "Csmall", "Dsmall", "Esmall", "Fsmall", "Gsmall", "Hsmall", "Ismall", "Jsmall", "Ksmall", "Lsmall", "Msmall", "Nsmall", "Osmall", "Psmall", "Qsmall", "Rsmall", "Ssmall", "Tsmall", "Usmall", "Vsmall", "Wsmall", "Xsmall", "Ysmall", "Zsmall", "colonmonetary", "onefitted", "rupiah", "Tildesmall", "exclamdownsmall", "centoldstyle", "Lslashsmall", "Scaronsmall", "Zcaronsmall", "Dieresissmall", "Brevesmall", "Caronsmall", "Dotaccentsmall", "Macronsmall", "figuredash", "hypheninferior", "Ogoneksmall", "Ringsmall", "Cedillasmall", "onequarter", "onehalf", "threequarters", "questiondownsmall", "oneeighth", "threeeighths", "fiveeighths", "seveneighths", "onethird", "twothirds", "zerosuperior", "onesuperior", "twosuperior", "threesuperior", "foursuperior", "fivesuperior", "sixsuperior", "sevensuperior", "eightsuperior", "ninesuperior", "zeroinferior", "oneinferior", "twoinferior", "threeinferior", "fourinferior", "fiveinferior", "sixinferior", "seveninferior", "eightinferior", "nineinferior", "centinferior", "dollarinferior", "periodinferior", "commainferior", "Agravesmall", "Aacutesmall", "Acircumflexsmall", "Atildesmall", "Adieresissmall", "Aringsmall", "AEsmall", "Ccedillasmall", "Egravesmall", "Eacutesmall", "Ecircumflexsmall", "Edieresissmall", "Igravesmall", "Iacutesmall", "Icircumflexsmall", "Idieresissmall", "Ethsmall", "Ntildesmall", "Ogravesmall", "Oacutesmall", "Ocircumflexsmall", "Otildesmall", "Odieresissmall", "OEsmall", "Oslashsmall", "Ugravesmall", "Uacutesmall", "Ucircumflexsmall", "Udieresissmall", "Yacutesmall", "Thornsmall", "Ydieresissmall"];
 
- exports.ExpertCharset = ExpertCharset;
 
- const ExpertSubsetCharset = [".notdef", "space", "dollaroldstyle", "dollarsuperior", "parenleftsuperior", "parenrightsuperior", "twodotenleader", "onedotenleader", "comma", "hyphen", "period", "fraction", "zerooldstyle", "oneoldstyle", "twooldstyle", "threeoldstyle", "fouroldstyle", "fiveoldstyle", "sixoldstyle", "sevenoldstyle", "eightoldstyle", "nineoldstyle", "colon", "semicolon", "commasuperior", "threequartersemdash", "periodsuperior", "asuperior", "bsuperior", "centsuperior", "dsuperior", "esuperior", "isuperior", "lsuperior", "msuperior", "nsuperior", "osuperior", "rsuperior", "ssuperior", "tsuperior", "ff", "fi", "fl", "ffi", "ffl", "parenleftinferior", "parenrightinferior", "hyphensuperior", "colonmonetary", "onefitted", "rupiah", "centoldstyle", "figuredash", "hypheninferior", "onequarter", "onehalf", "threequarters", "oneeighth", "threeeighths", "fiveeighths", "seveneighths", "onethird", "twothirds", "zerosuperior", "onesuperior", "twosuperior", "threesuperior", "foursuperior", "fivesuperior", "sixsuperior", "sevensuperior", "eightsuperior", "ninesuperior", "zeroinferior", "oneinferior", "twoinferior", "threeinferior", "fourinferior", "fiveinferior", "sixinferior", "seveninferior", "eightinferior", "nineinferior", "centinferior", "dollarinferior", "periodinferior", "commainferior"];
 
- exports.ExpertSubsetCharset = ExpertSubsetCharset;
 
- /***/ }),
 
- /* 30 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getEncoding = getEncoding;
 
- exports.ExpertEncoding = exports.ZapfDingbatsEncoding = exports.SymbolSetEncoding = exports.MacRomanEncoding = exports.StandardEncoding = exports.WinAnsiEncoding = void 0;
 
- const ExpertEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclamsmall", "Hungarumlautsmall", "", "dollaroldstyle", "dollarsuperior", "ampersandsmall", "Acutesmall", "parenleftsuperior", "parenrightsuperior", "twodotenleader", "onedotenleader", "comma", "hyphen", "period", "fraction", "zerooldstyle", "oneoldstyle", "twooldstyle", "threeoldstyle", "fouroldstyle", "fiveoldstyle", "sixoldstyle", "sevenoldstyle", "eightoldstyle", "nineoldstyle", "colon", "semicolon", "commasuperior", "threequartersemdash", "periodsuperior", "questionsmall", "", "asuperior", "bsuperior", "centsuperior", "dsuperior", "esuperior", "", "", "", "isuperior", "", "", "lsuperior", "msuperior", "nsuperior", "osuperior", "", "", "rsuperior", "ssuperior", "tsuperior", "", "ff", "fi", "fl", "ffi", "ffl", "parenleftinferior", "", "parenrightinferior", "Circumflexsmall", "hyphensuperior", "Gravesmall", "Asmall", "Bsmall", "Csmall", "Dsmall", "Esmall", "Fsmall", "Gsmall", "Hsmall", "Ismall", "Jsmall", "Ksmall", "Lsmall", "Msmall", "Nsmall", "Osmall", "Psmall", "Qsmall", "Rsmall", "Ssmall", "Tsmall", "Usmall", "Vsmall", "Wsmall", "Xsmall", "Ysmall", "Zsmall", "colonmonetary", "onefitted", "rupiah", "Tildesmall", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "exclamdownsmall", "centoldstyle", "Lslashsmall", "", "", "Scaronsmall", "Zcaronsmall", "Dieresissmall", "Brevesmall", "Caronsmall", "", "Dotaccentsmall", "", "", "Macronsmall", "", "", "figuredash", "hypheninferior", "", "", "Ogoneksmall", "Ringsmall", "Cedillasmall", "", "", "", "onequarter", "onehalf", "threequarters", "questiondownsmall", "oneeighth", "threeeighths", "fiveeighths", "seveneighths", "onethird", "twothirds", "", "", "zerosuperior", "onesuperior", "twosuperior", "threesuperior", "foursuperior", "fivesuperior", "sixsuperior", "sevensuperior", "eightsuperior", "ninesuperior", "zeroinferior", "oneinferior", "twoinferior", "threeinferior", "fourinferior", "fiveinferior", "sixinferior", "seveninferior", "eightinferior", "nineinferior", "centinferior", "dollarinferior", "periodinferior", "commainferior", "Agravesmall", "Aacutesmall", "Acircumflexsmall", "Atildesmall", "Adieresissmall", "Aringsmall", "AEsmall", "Ccedillasmall", "Egravesmall", "Eacutesmall", "Ecircumflexsmall", "Edieresissmall", "Igravesmall", "Iacutesmall", "Icircumflexsmall", "Idieresissmall", "Ethsmall", "Ntildesmall", "Ogravesmall", "Oacutesmall", "Ocircumflexsmall", "Otildesmall", "Odieresissmall", "OEsmall", "Oslashsmall", "Ugravesmall", "Uacutesmall", "Ucircumflexsmall", "Udieresissmall", "Yacutesmall", "Thornsmall", "Ydieresissmall"];
 
- exports.ExpertEncoding = ExpertEncoding;
 
- const MacExpertEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclamsmall", "Hungarumlautsmall", "centoldstyle", "dollaroldstyle", "dollarsuperior", "ampersandsmall", "Acutesmall", "parenleftsuperior", "parenrightsuperior", "twodotenleader", "onedotenleader", "comma", "hyphen", "period", "fraction", "zerooldstyle", "oneoldstyle", "twooldstyle", "threeoldstyle", "fouroldstyle", "fiveoldstyle", "sixoldstyle", "sevenoldstyle", "eightoldstyle", "nineoldstyle", "colon", "semicolon", "", "threequartersemdash", "", "questionsmall", "", "", "", "", "Ethsmall", "", "", "onequarter", "onehalf", "threequarters", "oneeighth", "threeeighths", "fiveeighths", "seveneighths", "onethird", "twothirds", "", "", "", "", "", "", "ff", "fi", "fl", "ffi", "ffl", "parenleftinferior", "", "parenrightinferior", "Circumflexsmall", "hypheninferior", "Gravesmall", "Asmall", "Bsmall", "Csmall", "Dsmall", "Esmall", "Fsmall", "Gsmall", "Hsmall", "Ismall", "Jsmall", "Ksmall", "Lsmall", "Msmall", "Nsmall", "Osmall", "Psmall", "Qsmall", "Rsmall", "Ssmall", "Tsmall", "Usmall", "Vsmall", "Wsmall", "Xsmall", "Ysmall", "Zsmall", "colonmonetary", "onefitted", "rupiah", "Tildesmall", "", "", "asuperior", "centsuperior", "", "", "", "", "Aacutesmall", "Agravesmall", "Acircumflexsmall", "Adieresissmall", "Atildesmall", "Aringsmall", "Ccedillasmall", "Eacutesmall", "Egravesmall", "Ecircumflexsmall", "Edieresissmall", "Iacutesmall", "Igravesmall", "Icircumflexsmall", "Idieresissmall", "Ntildesmall", "Oacutesmall", "Ogravesmall", "Ocircumflexsmall", "Odieresissmall", "Otildesmall", "Uacutesmall", "Ugravesmall", "Ucircumflexsmall", "Udieresissmall", "", "eightsuperior", "fourinferior", "threeinferior", "sixinferior", "eightinferior", "seveninferior", "Scaronsmall", "", "centinferior", "twoinferior", "", "Dieresissmall", "", "Caronsmall", "osuperior", "fiveinferior", "", "commainferior", "periodinferior", "Yacutesmall", "", "dollarinferior", "", "", "Thornsmall", "", "nineinferior", "zeroinferior", "Zcaronsmall", "AEsmall", "Oslashsmall", "questiondownsmall", "oneinferior", "Lslashsmall", "", "", "", "", "", "", "Cedillasmall", "", "", "", "", "", "OEsmall", "figuredash", "hyphensuperior", "", "", "", "", "exclamdownsmall", "", "Ydieresissmall", "", "onesuperior", "twosuperior", "threesuperior", "foursuperior", "fivesuperior", "sixsuperior", "sevensuperior", "ninesuperior", "zerosuperior", "", "esuperior", "rsuperior", "tsuperior", "", "", "isuperior", "ssuperior", "dsuperior", "", "", "", "", "", "lsuperior", "Ogoneksmall", "Brevesmall", "Macronsmall", "bsuperior", "nsuperior", "msuperior", "commasuperior", "periodsuperior", "Dotaccentsmall", "Ringsmall", "", "", "", ""];
 
- const MacRomanEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quotesingle", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "grave", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "", "Adieresis", "Aring", "Ccedilla", "Eacute", "Ntilde", "Odieresis", "Udieresis", "aacute", "agrave", "acircumflex", "adieresis", "atilde", "aring", "ccedilla", "eacute", "egrave", "ecircumflex", "edieresis", "iacute", "igrave", "icircumflex", "idieresis", "ntilde", "oacute", "ograve", "ocircumflex", "odieresis", "otilde", "uacute", "ugrave", "ucircumflex", "udieresis", "dagger", "degree", "cent", "sterling", "section", "bullet", "paragraph", "germandbls", "registered", "copyright", "trademark", "acute", "dieresis", "notequal", "AE", "Oslash", "infinity", "plusminus", "lessequal", "greaterequal", "yen", "mu", "partialdiff", "summation", "product", "pi", "integral", "ordfeminine", "ordmasculine", "Omega", "ae", "oslash", "questiondown", "exclamdown", "logicalnot", "radical", "florin", "approxequal", "Delta", "guillemotleft", "guillemotright", "ellipsis", "space", "Agrave", "Atilde", "Otilde", "OE", "oe", "endash", "emdash", "quotedblleft", "quotedblright", "quoteleft", "quoteright", "divide", "lozenge", "ydieresis", "Ydieresis", "fraction", "currency", "guilsinglleft", "guilsinglright", "fi", "fl", "daggerdbl", "periodcentered", "quotesinglbase", "quotedblbase", "perthousand", "Acircumflex", "Ecircumflex", "Aacute", "Edieresis", "Egrave", "Iacute", "Icircumflex", "Idieresis", "Igrave", "Oacute", "Ocircumflex", "apple", "Ograve", "Uacute", "Ucircumflex", "Ugrave", "dotlessi", "circumflex", "tilde", "macron", "breve", "dotaccent", "ring", "cedilla", "hungarumlaut", "ogonek", "caron"];
 
- exports.MacRomanEncoding = MacRomanEncoding;
 
- const StandardEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quoteright", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "quoteleft", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "exclamdown", "cent", "sterling", "fraction", "yen", "florin", "section", "currency", "quotesingle", "quotedblleft", "guillemotleft", "guilsinglleft", "guilsinglright", "fi", "fl", "", "endash", "dagger", "daggerdbl", "periodcentered", "", "paragraph", "bullet", "quotesinglbase", "quotedblbase", "quotedblright", "guillemotright", "ellipsis", "perthousand", "", "questiondown", "", "grave", "acute", "circumflex", "tilde", "macron", "breve", "dotaccent", "dieresis", "", "ring", "cedilla", "", "hungarumlaut", "ogonek", "caron", "emdash", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "AE", "", "ordfeminine", "", "", "", "", "Lslash", "Oslash", "OE", "ordmasculine", "", "", "", "", "", "ae", "", "", "", "dotlessi", "", "", "lslash", "oslash", "oe", "germandbls", "", "", "", ""];
 
- exports.StandardEncoding = StandardEncoding;
 
- const WinAnsiEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclam", "quotedbl", "numbersign", "dollar", "percent", "ampersand", "quotesingle", "parenleft", "parenright", "asterisk", "plus", "comma", "hyphen", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "at", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "bracketleft", "backslash", "bracketright", "asciicircum", "underscore", "grave", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "braceleft", "bar", "braceright", "asciitilde", "bullet", "Euro", "bullet", "quotesinglbase", "florin", "quotedblbase", "ellipsis", "dagger", "daggerdbl", "circumflex", "perthousand", "Scaron", "guilsinglleft", "OE", "bullet", "Zcaron", "bullet", "bullet", "quoteleft", "quoteright", "quotedblleft", "quotedblright", "bullet", "endash", "emdash", "tilde", "trademark", "scaron", "guilsinglright", "oe", "bullet", "zcaron", "Ydieresis", "space", "exclamdown", "cent", "sterling", "currency", "yen", "brokenbar", "section", "dieresis", "copyright", "ordfeminine", "guillemotleft", "logicalnot", "hyphen", "registered", "macron", "degree", "plusminus", "twosuperior", "threesuperior", "acute", "mu", "paragraph", "periodcentered", "cedilla", "onesuperior", "ordmasculine", "guillemotright", "onequarter", "onehalf", "threequarters", "questiondown", "Agrave", "Aacute", "Acircumflex", "Atilde", "Adieresis", "Aring", "AE", "Ccedilla", "Egrave", "Eacute", "Ecircumflex", "Edieresis", "Igrave", "Iacute", "Icircumflex", "Idieresis", "Eth", "Ntilde", "Ograve", "Oacute", "Ocircumflex", "Otilde", "Odieresis", "multiply", "Oslash", "Ugrave", "Uacute", "Ucircumflex", "Udieresis", "Yacute", "Thorn", "germandbls", "agrave", "aacute", "acircumflex", "atilde", "adieresis", "aring", "ae", "ccedilla", "egrave", "eacute", "ecircumflex", "edieresis", "igrave", "iacute", "icircumflex", "idieresis", "eth", "ntilde", "ograve", "oacute", "ocircumflex", "otilde", "odieresis", "divide", "oslash", "ugrave", "uacute", "ucircumflex", "udieresis", "yacute", "thorn", "ydieresis"];
 
- exports.WinAnsiEncoding = WinAnsiEncoding;
 
- const SymbolSetEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "exclam", "universal", "numbersign", "existential", "percent", "ampersand", "suchthat", "parenleft", "parenright", "asteriskmath", "plus", "comma", "minus", "period", "slash", "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "colon", "semicolon", "less", "equal", "greater", "question", "congruent", "Alpha", "Beta", "Chi", "Delta", "Epsilon", "Phi", "Gamma", "Eta", "Iota", "theta1", "Kappa", "Lambda", "Mu", "Nu", "Omicron", "Pi", "Theta", "Rho", "Sigma", "Tau", "Upsilon", "sigma1", "Omega", "Xi", "Psi", "Zeta", "bracketleft", "therefore", "bracketright", "perpendicular", "underscore", "radicalex", "alpha", "beta", "chi", "delta", "epsilon", "phi", "gamma", "eta", "iota", "phi1", "kappa", "lambda", "mu", "nu", "omicron", "pi", "theta", "rho", "sigma", "tau", "upsilon", "omega1", "omega", "xi", "psi", "zeta", "braceleft", "bar", "braceright", "similar", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "Euro", "Upsilon1", "minute", "lessequal", "fraction", "infinity", "florin", "club", "diamond", "heart", "spade", "arrowboth", "arrowleft", "arrowup", "arrowright", "arrowdown", "degree", "plusminus", "second", "greaterequal", "multiply", "proportional", "partialdiff", "bullet", "divide", "notequal", "equivalence", "approxequal", "ellipsis", "arrowvertex", "arrowhorizex", "carriagereturn", "aleph", "Ifraktur", "Rfraktur", "weierstrass", "circlemultiply", "circleplus", "emptyset", "intersection", "union", "propersuperset", "reflexsuperset", "notsubset", "propersubset", "reflexsubset", "element", "notelement", "angle", "gradient", "registerserif", "copyrightserif", "trademarkserif", "product", "radical", "dotmath", "logicalnot", "logicaland", "logicalor", "arrowdblboth", "arrowdblleft", "arrowdblup", "arrowdblright", "arrowdbldown", "lozenge", "angleleft", "registersans", "copyrightsans", "trademarksans", "summation", "parenlefttp", "parenleftex", "parenleftbt", "bracketlefttp", "bracketleftex", "bracketleftbt", "bracelefttp", "braceleftmid", "braceleftbt", "braceex", "", "angleright", "integral", "integraltp", "integralex", "integralbt", "parenrighttp", "parenrightex", "parenrightbt", "bracketrighttp", "bracketrightex", "bracketrightbt", "bracerighttp", "bracerightmid", "bracerightbt", ""];
 
- exports.SymbolSetEncoding = SymbolSetEncoding;
 
- const ZapfDingbatsEncoding = ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "space", "a1", "a2", "a202", "a3", "a4", "a5", "a119", "a118", "a117", "a11", "a12", "a13", "a14", "a15", "a16", "a105", "a17", "a18", "a19", "a20", "a21", "a22", "a23", "a24", "a25", "a26", "a27", "a28", "a6", "a7", "a8", "a9", "a10", "a29", "a30", "a31", "a32", "a33", "a34", "a35", "a36", "a37", "a38", "a39", "a40", "a41", "a42", "a43", "a44", "a45", "a46", "a47", "a48", "a49", "a50", "a51", "a52", "a53", "a54", "a55", "a56", "a57", "a58", "a59", "a60", "a61", "a62", "a63", "a64", "a65", "a66", "a67", "a68", "a69", "a70", "a71", "a72", "a73", "a74", "a203", "a75", "a204", "a76", "a77", "a78", "a79", "a81", "a82", "a83", "a84", "a97", "a98", "a99", "a100", "", "a89", "a90", "a93", "a94", "a91", "a92", "a205", "a85", "a206", "a86", "a87", "a88", "a95", "a96", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "a101", "a102", "a103", "a104", "a106", "a107", "a108", "a112", "a111", "a110", "a109", "a120", "a121", "a122", "a123", "a124", "a125", "a126", "a127", "a128", "a129", "a130", "a131", "a132", "a133", "a134", "a135", "a136", "a137", "a138", "a139", "a140", "a141", "a142", "a143", "a144", "a145", "a146", "a147", "a148", "a149", "a150", "a151", "a152", "a153", "a154", "a155", "a156", "a157", "a158", "a159", "a160", "a161", "a163", "a164", "a196", "a165", "a192", "a166", "a167", "a168", "a169", "a170", "a171", "a172", "a173", "a162", "a174", "a175", "a176", "a177", "a178", "a179", "a193", "a180", "a199", "a181", "a200", "a182", "", "a201", "a183", "a184", "a197", "a185", "a194", "a198", "a186", "a195", "a187", "a188", "a189", "a190", "a191", ""];
 
- exports.ZapfDingbatsEncoding = ZapfDingbatsEncoding;
 
- function getEncoding(encodingName) {
 
-   switch (encodingName) {
 
-     case "WinAnsiEncoding":
 
-       return WinAnsiEncoding;
 
-     case "StandardEncoding":
 
-       return StandardEncoding;
 
-     case "MacRomanEncoding":
 
-       return MacRomanEncoding;
 
-     case "SymbolSetEncoding":
 
-       return SymbolSetEncoding;
 
-     case "ZapfDingbatsEncoding":
 
-       return ZapfDingbatsEncoding;
 
-     case "ExpertEncoding":
 
-       return ExpertEncoding;
 
-     case "MacExpertEncoding":
 
-       return MacExpertEncoding;
 
-     default:
 
-       return null;
 
-   }
 
- }
 
- /***/ }),
 
- /* 31 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- var getLookupTableFactory = __w_pdfjs_require__(7).getLookupTableFactory;
 
- var getGlyphsUnicode = getLookupTableFactory(function (t) {
 
-  t["A"] = 0x0041;
 
-  t["AE"] = 0x00c6;
 
-  t["AEacute"] = 0x01fc;
 
-  t["AEmacron"] = 0x01e2;
 
-  t["AEsmall"] = 0xf7e6;
 
-  t["Aacute"] = 0x00c1;
 
-  t["Aacutesmall"] = 0xf7e1;
 
-  t["Abreve"] = 0x0102;
 
-  t["Abreveacute"] = 0x1eae;
 
-  t["Abrevecyrillic"] = 0x04d0;
 
-  t["Abrevedotbelow"] = 0x1eb6;
 
-  t["Abrevegrave"] = 0x1eb0;
 
-  t["Abrevehookabove"] = 0x1eb2;
 
-  t["Abrevetilde"] = 0x1eb4;
 
-  t["Acaron"] = 0x01cd;
 
-  t["Acircle"] = 0x24b6;
 
-  t["Acircumflex"] = 0x00c2;
 
-  t["Acircumflexacute"] = 0x1ea4;
 
-  t["Acircumflexdotbelow"] = 0x1eac;
 
-  t["Acircumflexgrave"] = 0x1ea6;
 
-  t["Acircumflexhookabove"] = 0x1ea8;
 
-  t["Acircumflexsmall"] = 0xf7e2;
 
-  t["Acircumflextilde"] = 0x1eaa;
 
-  t["Acute"] = 0xf6c9;
 
-  t["Acutesmall"] = 0xf7b4;
 
-  t["Acyrillic"] = 0x0410;
 
-  t["Adblgrave"] = 0x0200;
 
-  t["Adieresis"] = 0x00c4;
 
-  t["Adieresiscyrillic"] = 0x04d2;
 
-  t["Adieresismacron"] = 0x01de;
 
-  t["Adieresissmall"] = 0xf7e4;
 
-  t["Adotbelow"] = 0x1ea0;
 
-  t["Adotmacron"] = 0x01e0;
 
-  t["Agrave"] = 0x00c0;
 
-  t["Agravesmall"] = 0xf7e0;
 
-  t["Ahookabove"] = 0x1ea2;
 
-  t["Aiecyrillic"] = 0x04d4;
 
-  t["Ainvertedbreve"] = 0x0202;
 
-  t["Alpha"] = 0x0391;
 
-  t["Alphatonos"] = 0x0386;
 
-  t["Amacron"] = 0x0100;
 
-  t["Amonospace"] = 0xff21;
 
-  t["Aogonek"] = 0x0104;
 
-  t["Aring"] = 0x00c5;
 
-  t["Aringacute"] = 0x01fa;
 
-  t["Aringbelow"] = 0x1e00;
 
-  t["Aringsmall"] = 0xf7e5;
 
-  t["Asmall"] = 0xf761;
 
-  t["Atilde"] = 0x00c3;
 
-  t["Atildesmall"] = 0xf7e3;
 
-  t["Aybarmenian"] = 0x0531;
 
-  t["B"] = 0x0042;
 
-  t["Bcircle"] = 0x24b7;
 
-  t["Bdotaccent"] = 0x1e02;
 
-  t["Bdotbelow"] = 0x1e04;
 
-  t["Becyrillic"] = 0x0411;
 
-  t["Benarmenian"] = 0x0532;
 
-  t["Beta"] = 0x0392;
 
-  t["Bhook"] = 0x0181;
 
-  t["Blinebelow"] = 0x1e06;
 
-  t["Bmonospace"] = 0xff22;
 
-  t["Brevesmall"] = 0xf6f4;
 
-  t["Bsmall"] = 0xf762;
 
-  t["Btopbar"] = 0x0182;
 
-  t["C"] = 0x0043;
 
-  t["Caarmenian"] = 0x053e;
 
-  t["Cacute"] = 0x0106;
 
-  t["Caron"] = 0xf6ca;
 
-  t["Caronsmall"] = 0xf6f5;
 
-  t["Ccaron"] = 0x010c;
 
-  t["Ccedilla"] = 0x00c7;
 
-  t["Ccedillaacute"] = 0x1e08;
 
-  t["Ccedillasmall"] = 0xf7e7;
 
-  t["Ccircle"] = 0x24b8;
 
-  t["Ccircumflex"] = 0x0108;
 
-  t["Cdot"] = 0x010a;
 
-  t["Cdotaccent"] = 0x010a;
 
-  t["Cedillasmall"] = 0xf7b8;
 
-  t["Chaarmenian"] = 0x0549;
 
-  t["Cheabkhasiancyrillic"] = 0x04bc;
 
-  t["Checyrillic"] = 0x0427;
 
-  t["Chedescenderabkhasiancyrillic"] = 0x04be;
 
-  t["Chedescendercyrillic"] = 0x04b6;
 
-  t["Chedieresiscyrillic"] = 0x04f4;
 
-  t["Cheharmenian"] = 0x0543;
 
-  t["Chekhakassiancyrillic"] = 0x04cb;
 
-  t["Cheverticalstrokecyrillic"] = 0x04b8;
 
-  t["Chi"] = 0x03a7;
 
-  t["Chook"] = 0x0187;
 
-  t["Circumflexsmall"] = 0xf6f6;
 
-  t["Cmonospace"] = 0xff23;
 
-  t["Coarmenian"] = 0x0551;
 
-  t["Csmall"] = 0xf763;
 
-  t["D"] = 0x0044;
 
-  t["DZ"] = 0x01f1;
 
-  t["DZcaron"] = 0x01c4;
 
-  t["Daarmenian"] = 0x0534;
 
-  t["Dafrican"] = 0x0189;
 
-  t["Dcaron"] = 0x010e;
 
-  t["Dcedilla"] = 0x1e10;
 
-  t["Dcircle"] = 0x24b9;
 
-  t["Dcircumflexbelow"] = 0x1e12;
 
-  t["Dcroat"] = 0x0110;
 
-  t["Ddotaccent"] = 0x1e0a;
 
-  t["Ddotbelow"] = 0x1e0c;
 
-  t["Decyrillic"] = 0x0414;
 
-  t["Deicoptic"] = 0x03ee;
 
-  t["Delta"] = 0x2206;
 
-  t["Deltagreek"] = 0x0394;
 
-  t["Dhook"] = 0x018a;
 
-  t["Dieresis"] = 0xf6cb;
 
-  t["DieresisAcute"] = 0xf6cc;
 
-  t["DieresisGrave"] = 0xf6cd;
 
-  t["Dieresissmall"] = 0xf7a8;
 
-  t["Digammagreek"] = 0x03dc;
 
-  t["Djecyrillic"] = 0x0402;
 
-  t["Dlinebelow"] = 0x1e0e;
 
-  t["Dmonospace"] = 0xff24;
 
-  t["Dotaccentsmall"] = 0xf6f7;
 
-  t["Dslash"] = 0x0110;
 
-  t["Dsmall"] = 0xf764;
 
-  t["Dtopbar"] = 0x018b;
 
-  t["Dz"] = 0x01f2;
 
-  t["Dzcaron"] = 0x01c5;
 
-  t["Dzeabkhasiancyrillic"] = 0x04e0;
 
-  t["Dzecyrillic"] = 0x0405;
 
-  t["Dzhecyrillic"] = 0x040f;
 
-  t["E"] = 0x0045;
 
-  t["Eacute"] = 0x00c9;
 
-  t["Eacutesmall"] = 0xf7e9;
 
-  t["Ebreve"] = 0x0114;
 
-  t["Ecaron"] = 0x011a;
 
-  t["Ecedillabreve"] = 0x1e1c;
 
-  t["Echarmenian"] = 0x0535;
 
-  t["Ecircle"] = 0x24ba;
 
-  t["Ecircumflex"] = 0x00ca;
 
-  t["Ecircumflexacute"] = 0x1ebe;
 
-  t["Ecircumflexbelow"] = 0x1e18;
 
-  t["Ecircumflexdotbelow"] = 0x1ec6;
 
-  t["Ecircumflexgrave"] = 0x1ec0;
 
-  t["Ecircumflexhookabove"] = 0x1ec2;
 
-  t["Ecircumflexsmall"] = 0xf7ea;
 
-  t["Ecircumflextilde"] = 0x1ec4;
 
-  t["Ecyrillic"] = 0x0404;
 
-  t["Edblgrave"] = 0x0204;
 
-  t["Edieresis"] = 0x00cb;
 
-  t["Edieresissmall"] = 0xf7eb;
 
-  t["Edot"] = 0x0116;
 
-  t["Edotaccent"] = 0x0116;
 
-  t["Edotbelow"] = 0x1eb8;
 
-  t["Efcyrillic"] = 0x0424;
 
-  t["Egrave"] = 0x00c8;
 
-  t["Egravesmall"] = 0xf7e8;
 
-  t["Eharmenian"] = 0x0537;
 
-  t["Ehookabove"] = 0x1eba;
 
-  t["Eightroman"] = 0x2167;
 
-  t["Einvertedbreve"] = 0x0206;
 
-  t["Eiotifiedcyrillic"] = 0x0464;
 
-  t["Elcyrillic"] = 0x041b;
 
-  t["Elevenroman"] = 0x216a;
 
-  t["Emacron"] = 0x0112;
 
-  t["Emacronacute"] = 0x1e16;
 
-  t["Emacrongrave"] = 0x1e14;
 
-  t["Emcyrillic"] = 0x041c;
 
-  t["Emonospace"] = 0xff25;
 
-  t["Encyrillic"] = 0x041d;
 
-  t["Endescendercyrillic"] = 0x04a2;
 
-  t["Eng"] = 0x014a;
 
-  t["Enghecyrillic"] = 0x04a4;
 
-  t["Enhookcyrillic"] = 0x04c7;
 
-  t["Eogonek"] = 0x0118;
 
-  t["Eopen"] = 0x0190;
 
-  t["Epsilon"] = 0x0395;
 
-  t["Epsilontonos"] = 0x0388;
 
-  t["Ercyrillic"] = 0x0420;
 
-  t["Ereversed"] = 0x018e;
 
-  t["Ereversedcyrillic"] = 0x042d;
 
-  t["Escyrillic"] = 0x0421;
 
-  t["Esdescendercyrillic"] = 0x04aa;
 
-  t["Esh"] = 0x01a9;
 
-  t["Esmall"] = 0xf765;
 
-  t["Eta"] = 0x0397;
 
-  t["Etarmenian"] = 0x0538;
 
-  t["Etatonos"] = 0x0389;
 
-  t["Eth"] = 0x00d0;
 
-  t["Ethsmall"] = 0xf7f0;
 
-  t["Etilde"] = 0x1ebc;
 
-  t["Etildebelow"] = 0x1e1a;
 
-  t["Euro"] = 0x20ac;
 
-  t["Ezh"] = 0x01b7;
 
-  t["Ezhcaron"] = 0x01ee;
 
-  t["Ezhreversed"] = 0x01b8;
 
-  t["F"] = 0x0046;
 
-  t["Fcircle"] = 0x24bb;
 
-  t["Fdotaccent"] = 0x1e1e;
 
-  t["Feharmenian"] = 0x0556;
 
-  t["Feicoptic"] = 0x03e4;
 
-  t["Fhook"] = 0x0191;
 
-  t["Fitacyrillic"] = 0x0472;
 
-  t["Fiveroman"] = 0x2164;
 
-  t["Fmonospace"] = 0xff26;
 
-  t["Fourroman"] = 0x2163;
 
-  t["Fsmall"] = 0xf766;
 
-  t["G"] = 0x0047;
 
-  t["GBsquare"] = 0x3387;
 
-  t["Gacute"] = 0x01f4;
 
-  t["Gamma"] = 0x0393;
 
-  t["Gammaafrican"] = 0x0194;
 
-  t["Gangiacoptic"] = 0x03ea;
 
-  t["Gbreve"] = 0x011e;
 
-  t["Gcaron"] = 0x01e6;
 
-  t["Gcedilla"] = 0x0122;
 
-  t["Gcircle"] = 0x24bc;
 
-  t["Gcircumflex"] = 0x011c;
 
-  t["Gcommaaccent"] = 0x0122;
 
-  t["Gdot"] = 0x0120;
 
-  t["Gdotaccent"] = 0x0120;
 
-  t["Gecyrillic"] = 0x0413;
 
-  t["Ghadarmenian"] = 0x0542;
 
-  t["Ghemiddlehookcyrillic"] = 0x0494;
 
-  t["Ghestrokecyrillic"] = 0x0492;
 
-  t["Gheupturncyrillic"] = 0x0490;
 
-  t["Ghook"] = 0x0193;
 
-  t["Gimarmenian"] = 0x0533;
 
-  t["Gjecyrillic"] = 0x0403;
 
-  t["Gmacron"] = 0x1e20;
 
-  t["Gmonospace"] = 0xff27;
 
-  t["Grave"] = 0xf6ce;
 
-  t["Gravesmall"] = 0xf760;
 
-  t["Gsmall"] = 0xf767;
 
-  t["Gsmallhook"] = 0x029b;
 
-  t["Gstroke"] = 0x01e4;
 
-  t["H"] = 0x0048;
 
-  t["H18533"] = 0x25cf;
 
-  t["H18543"] = 0x25aa;
 
-  t["H18551"] = 0x25ab;
 
-  t["H22073"] = 0x25a1;
 
-  t["HPsquare"] = 0x33cb;
 
-  t["Haabkhasiancyrillic"] = 0x04a8;
 
-  t["Hadescendercyrillic"] = 0x04b2;
 
-  t["Hardsigncyrillic"] = 0x042a;
 
-  t["Hbar"] = 0x0126;
 
-  t["Hbrevebelow"] = 0x1e2a;
 
-  t["Hcedilla"] = 0x1e28;
 
-  t["Hcircle"] = 0x24bd;
 
-  t["Hcircumflex"] = 0x0124;
 
-  t["Hdieresis"] = 0x1e26;
 
-  t["Hdotaccent"] = 0x1e22;
 
-  t["Hdotbelow"] = 0x1e24;
 
-  t["Hmonospace"] = 0xff28;
 
-  t["Hoarmenian"] = 0x0540;
 
-  t["Horicoptic"] = 0x03e8;
 
-  t["Hsmall"] = 0xf768;
 
-  t["Hungarumlaut"] = 0xf6cf;
 
-  t["Hungarumlautsmall"] = 0xf6f8;
 
-  t["Hzsquare"] = 0x3390;
 
-  t["I"] = 0x0049;
 
-  t["IAcyrillic"] = 0x042f;
 
-  t["IJ"] = 0x0132;
 
-  t["IUcyrillic"] = 0x042e;
 
-  t["Iacute"] = 0x00cd;
 
-  t["Iacutesmall"] = 0xf7ed;
 
-  t["Ibreve"] = 0x012c;
 
-  t["Icaron"] = 0x01cf;
 
-  t["Icircle"] = 0x24be;
 
-  t["Icircumflex"] = 0x00ce;
 
-  t["Icircumflexsmall"] = 0xf7ee;
 
-  t["Icyrillic"] = 0x0406;
 
-  t["Idblgrave"] = 0x0208;
 
-  t["Idieresis"] = 0x00cf;
 
-  t["Idieresisacute"] = 0x1e2e;
 
-  t["Idieresiscyrillic"] = 0x04e4;
 
-  t["Idieresissmall"] = 0xf7ef;
 
-  t["Idot"] = 0x0130;
 
-  t["Idotaccent"] = 0x0130;
 
-  t["Idotbelow"] = 0x1eca;
 
-  t["Iebrevecyrillic"] = 0x04d6;
 
-  t["Iecyrillic"] = 0x0415;
 
-  t["Ifraktur"] = 0x2111;
 
-  t["Igrave"] = 0x00cc;
 
-  t["Igravesmall"] = 0xf7ec;
 
-  t["Ihookabove"] = 0x1ec8;
 
-  t["Iicyrillic"] = 0x0418;
 
-  t["Iinvertedbreve"] = 0x020a;
 
-  t["Iishortcyrillic"] = 0x0419;
 
-  t["Imacron"] = 0x012a;
 
-  t["Imacroncyrillic"] = 0x04e2;
 
-  t["Imonospace"] = 0xff29;
 
-  t["Iniarmenian"] = 0x053b;
 
-  t["Iocyrillic"] = 0x0401;
 
-  t["Iogonek"] = 0x012e;
 
-  t["Iota"] = 0x0399;
 
-  t["Iotaafrican"] = 0x0196;
 
-  t["Iotadieresis"] = 0x03aa;
 
-  t["Iotatonos"] = 0x038a;
 
-  t["Ismall"] = 0xf769;
 
-  t["Istroke"] = 0x0197;
 
-  t["Itilde"] = 0x0128;
 
-  t["Itildebelow"] = 0x1e2c;
 
-  t["Izhitsacyrillic"] = 0x0474;
 
-  t["Izhitsadblgravecyrillic"] = 0x0476;
 
-  t["J"] = 0x004a;
 
-  t["Jaarmenian"] = 0x0541;
 
-  t["Jcircle"] = 0x24bf;
 
-  t["Jcircumflex"] = 0x0134;
 
-  t["Jecyrillic"] = 0x0408;
 
-  t["Jheharmenian"] = 0x054b;
 
-  t["Jmonospace"] = 0xff2a;
 
-  t["Jsmall"] = 0xf76a;
 
-  t["K"] = 0x004b;
 
-  t["KBsquare"] = 0x3385;
 
-  t["KKsquare"] = 0x33cd;
 
-  t["Kabashkircyrillic"] = 0x04a0;
 
-  t["Kacute"] = 0x1e30;
 
-  t["Kacyrillic"] = 0x041a;
 
-  t["Kadescendercyrillic"] = 0x049a;
 
-  t["Kahookcyrillic"] = 0x04c3;
 
-  t["Kappa"] = 0x039a;
 
-  t["Kastrokecyrillic"] = 0x049e;
 
-  t["Kaverticalstrokecyrillic"] = 0x049c;
 
-  t["Kcaron"] = 0x01e8;
 
-  t["Kcedilla"] = 0x0136;
 
-  t["Kcircle"] = 0x24c0;
 
-  t["Kcommaaccent"] = 0x0136;
 
-  t["Kdotbelow"] = 0x1e32;
 
-  t["Keharmenian"] = 0x0554;
 
-  t["Kenarmenian"] = 0x053f;
 
-  t["Khacyrillic"] = 0x0425;
 
-  t["Kheicoptic"] = 0x03e6;
 
-  t["Khook"] = 0x0198;
 
-  t["Kjecyrillic"] = 0x040c;
 
-  t["Klinebelow"] = 0x1e34;
 
-  t["Kmonospace"] = 0xff2b;
 
-  t["Koppacyrillic"] = 0x0480;
 
-  t["Koppagreek"] = 0x03de;
 
-  t["Ksicyrillic"] = 0x046e;
 
-  t["Ksmall"] = 0xf76b;
 
-  t["L"] = 0x004c;
 
-  t["LJ"] = 0x01c7;
 
-  t["LL"] = 0xf6bf;
 
-  t["Lacute"] = 0x0139;
 
-  t["Lambda"] = 0x039b;
 
-  t["Lcaron"] = 0x013d;
 
-  t["Lcedilla"] = 0x013b;
 
-  t["Lcircle"] = 0x24c1;
 
-  t["Lcircumflexbelow"] = 0x1e3c;
 
-  t["Lcommaaccent"] = 0x013b;
 
-  t["Ldot"] = 0x013f;
 
-  t["Ldotaccent"] = 0x013f;
 
-  t["Ldotbelow"] = 0x1e36;
 
-  t["Ldotbelowmacron"] = 0x1e38;
 
-  t["Liwnarmenian"] = 0x053c;
 
-  t["Lj"] = 0x01c8;
 
-  t["Ljecyrillic"] = 0x0409;
 
-  t["Llinebelow"] = 0x1e3a;
 
-  t["Lmonospace"] = 0xff2c;
 
-  t["Lslash"] = 0x0141;
 
-  t["Lslashsmall"] = 0xf6f9;
 
-  t["Lsmall"] = 0xf76c;
 
-  t["M"] = 0x004d;
 
-  t["MBsquare"] = 0x3386;
 
-  t["Macron"] = 0xf6d0;
 
-  t["Macronsmall"] = 0xf7af;
 
-  t["Macute"] = 0x1e3e;
 
-  t["Mcircle"] = 0x24c2;
 
-  t["Mdotaccent"] = 0x1e40;
 
-  t["Mdotbelow"] = 0x1e42;
 
-  t["Menarmenian"] = 0x0544;
 
-  t["Mmonospace"] = 0xff2d;
 
-  t["Msmall"] = 0xf76d;
 
-  t["Mturned"] = 0x019c;
 
-  t["Mu"] = 0x039c;
 
-  t["N"] = 0x004e;
 
-  t["NJ"] = 0x01ca;
 
-  t["Nacute"] = 0x0143;
 
-  t["Ncaron"] = 0x0147;
 
-  t["Ncedilla"] = 0x0145;
 
-  t["Ncircle"] = 0x24c3;
 
-  t["Ncircumflexbelow"] = 0x1e4a;
 
-  t["Ncommaaccent"] = 0x0145;
 
-  t["Ndotaccent"] = 0x1e44;
 
-  t["Ndotbelow"] = 0x1e46;
 
-  t["Nhookleft"] = 0x019d;
 
-  t["Nineroman"] = 0x2168;
 
-  t["Nj"] = 0x01cb;
 
-  t["Njecyrillic"] = 0x040a;
 
-  t["Nlinebelow"] = 0x1e48;
 
-  t["Nmonospace"] = 0xff2e;
 
-  t["Nowarmenian"] = 0x0546;
 
-  t["Nsmall"] = 0xf76e;
 
-  t["Ntilde"] = 0x00d1;
 
-  t["Ntildesmall"] = 0xf7f1;
 
-  t["Nu"] = 0x039d;
 
-  t["O"] = 0x004f;
 
-  t["OE"] = 0x0152;
 
-  t["OEsmall"] = 0xf6fa;
 
-  t["Oacute"] = 0x00d3;
 
-  t["Oacutesmall"] = 0xf7f3;
 
-  t["Obarredcyrillic"] = 0x04e8;
 
-  t["Obarreddieresiscyrillic"] = 0x04ea;
 
-  t["Obreve"] = 0x014e;
 
-  t["Ocaron"] = 0x01d1;
 
-  t["Ocenteredtilde"] = 0x019f;
 
-  t["Ocircle"] = 0x24c4;
 
-  t["Ocircumflex"] = 0x00d4;
 
-  t["Ocircumflexacute"] = 0x1ed0;
 
-  t["Ocircumflexdotbelow"] = 0x1ed8;
 
-  t["Ocircumflexgrave"] = 0x1ed2;
 
-  t["Ocircumflexhookabove"] = 0x1ed4;
 
-  t["Ocircumflexsmall"] = 0xf7f4;
 
-  t["Ocircumflextilde"] = 0x1ed6;
 
-  t["Ocyrillic"] = 0x041e;
 
-  t["Odblacute"] = 0x0150;
 
-  t["Odblgrave"] = 0x020c;
 
-  t["Odieresis"] = 0x00d6;
 
-  t["Odieresiscyrillic"] = 0x04e6;
 
-  t["Odieresissmall"] = 0xf7f6;
 
-  t["Odotbelow"] = 0x1ecc;
 
-  t["Ogoneksmall"] = 0xf6fb;
 
-  t["Ograve"] = 0x00d2;
 
-  t["Ogravesmall"] = 0xf7f2;
 
-  t["Oharmenian"] = 0x0555;
 
-  t["Ohm"] = 0x2126;
 
-  t["Ohookabove"] = 0x1ece;
 
-  t["Ohorn"] = 0x01a0;
 
-  t["Ohornacute"] = 0x1eda;
 
-  t["Ohorndotbelow"] = 0x1ee2;
 
-  t["Ohorngrave"] = 0x1edc;
 
-  t["Ohornhookabove"] = 0x1ede;
 
-  t["Ohorntilde"] = 0x1ee0;
 
-  t["Ohungarumlaut"] = 0x0150;
 
-  t["Oi"] = 0x01a2;
 
-  t["Oinvertedbreve"] = 0x020e;
 
-  t["Omacron"] = 0x014c;
 
-  t["Omacronacute"] = 0x1e52;
 
-  t["Omacrongrave"] = 0x1e50;
 
-  t["Omega"] = 0x2126;
 
-  t["Omegacyrillic"] = 0x0460;
 
-  t["Omegagreek"] = 0x03a9;
 
-  t["Omegaroundcyrillic"] = 0x047a;
 
-  t["Omegatitlocyrillic"] = 0x047c;
 
-  t["Omegatonos"] = 0x038f;
 
-  t["Omicron"] = 0x039f;
 
-  t["Omicrontonos"] = 0x038c;
 
-  t["Omonospace"] = 0xff2f;
 
-  t["Oneroman"] = 0x2160;
 
-  t["Oogonek"] = 0x01ea;
 
-  t["Oogonekmacron"] = 0x01ec;
 
-  t["Oopen"] = 0x0186;
 
-  t["Oslash"] = 0x00d8;
 
-  t["Oslashacute"] = 0x01fe;
 
-  t["Oslashsmall"] = 0xf7f8;
 
-  t["Osmall"] = 0xf76f;
 
-  t["Ostrokeacute"] = 0x01fe;
 
-  t["Otcyrillic"] = 0x047e;
 
-  t["Otilde"] = 0x00d5;
 
-  t["Otildeacute"] = 0x1e4c;
 
-  t["Otildedieresis"] = 0x1e4e;
 
-  t["Otildesmall"] = 0xf7f5;
 
-  t["P"] = 0x0050;
 
-  t["Pacute"] = 0x1e54;
 
-  t["Pcircle"] = 0x24c5;
 
-  t["Pdotaccent"] = 0x1e56;
 
-  t["Pecyrillic"] = 0x041f;
 
-  t["Peharmenian"] = 0x054a;
 
-  t["Pemiddlehookcyrillic"] = 0x04a6;
 
-  t["Phi"] = 0x03a6;
 
-  t["Phook"] = 0x01a4;
 
-  t["Pi"] = 0x03a0;
 
-  t["Piwrarmenian"] = 0x0553;
 
-  t["Pmonospace"] = 0xff30;
 
-  t["Psi"] = 0x03a8;
 
-  t["Psicyrillic"] = 0x0470;
 
-  t["Psmall"] = 0xf770;
 
-  t["Q"] = 0x0051;
 
-  t["Qcircle"] = 0x24c6;
 
-  t["Qmonospace"] = 0xff31;
 
-  t["Qsmall"] = 0xf771;
 
-  t["R"] = 0x0052;
 
-  t["Raarmenian"] = 0x054c;
 
-  t["Racute"] = 0x0154;
 
-  t["Rcaron"] = 0x0158;
 
-  t["Rcedilla"] = 0x0156;
 
-  t["Rcircle"] = 0x24c7;
 
-  t["Rcommaaccent"] = 0x0156;
 
-  t["Rdblgrave"] = 0x0210;
 
-  t["Rdotaccent"] = 0x1e58;
 
-  t["Rdotbelow"] = 0x1e5a;
 
-  t["Rdotbelowmacron"] = 0x1e5c;
 
-  t["Reharmenian"] = 0x0550;
 
-  t["Rfraktur"] = 0x211c;
 
-  t["Rho"] = 0x03a1;
 
-  t["Ringsmall"] = 0xf6fc;
 
-  t["Rinvertedbreve"] = 0x0212;
 
-  t["Rlinebelow"] = 0x1e5e;
 
-  t["Rmonospace"] = 0xff32;
 
-  t["Rsmall"] = 0xf772;
 
-  t["Rsmallinverted"] = 0x0281;
 
-  t["Rsmallinvertedsuperior"] = 0x02b6;
 
-  t["S"] = 0x0053;
 
-  t["SF010000"] = 0x250c;
 
-  t["SF020000"] = 0x2514;
 
-  t["SF030000"] = 0x2510;
 
-  t["SF040000"] = 0x2518;
 
-  t["SF050000"] = 0x253c;
 
-  t["SF060000"] = 0x252c;
 
-  t["SF070000"] = 0x2534;
 
-  t["SF080000"] = 0x251c;
 
-  t["SF090000"] = 0x2524;
 
-  t["SF100000"] = 0x2500;
 
-  t["SF110000"] = 0x2502;
 
-  t["SF190000"] = 0x2561;
 
-  t["SF200000"] = 0x2562;
 
-  t["SF210000"] = 0x2556;
 
-  t["SF220000"] = 0x2555;
 
-  t["SF230000"] = 0x2563;
 
-  t["SF240000"] = 0x2551;
 
-  t["SF250000"] = 0x2557;
 
-  t["SF260000"] = 0x255d;
 
-  t["SF270000"] = 0x255c;
 
-  t["SF280000"] = 0x255b;
 
-  t["SF360000"] = 0x255e;
 
-  t["SF370000"] = 0x255f;
 
-  t["SF380000"] = 0x255a;
 
-  t["SF390000"] = 0x2554;
 
-  t["SF400000"] = 0x2569;
 
-  t["SF410000"] = 0x2566;
 
-  t["SF420000"] = 0x2560;
 
-  t["SF430000"] = 0x2550;
 
-  t["SF440000"] = 0x256c;
 
-  t["SF450000"] = 0x2567;
 
-  t["SF460000"] = 0x2568;
 
-  t["SF470000"] = 0x2564;
 
-  t["SF480000"] = 0x2565;
 
-  t["SF490000"] = 0x2559;
 
-  t["SF500000"] = 0x2558;
 
-  t["SF510000"] = 0x2552;
 
-  t["SF520000"] = 0x2553;
 
-  t["SF530000"] = 0x256b;
 
-  t["SF540000"] = 0x256a;
 
-  t["Sacute"] = 0x015a;
 
-  t["Sacutedotaccent"] = 0x1e64;
 
-  t["Sampigreek"] = 0x03e0;
 
-  t["Scaron"] = 0x0160;
 
-  t["Scarondotaccent"] = 0x1e66;
 
-  t["Scaronsmall"] = 0xf6fd;
 
-  t["Scedilla"] = 0x015e;
 
-  t["Schwa"] = 0x018f;
 
-  t["Schwacyrillic"] = 0x04d8;
 
-  t["Schwadieresiscyrillic"] = 0x04da;
 
-  t["Scircle"] = 0x24c8;
 
-  t["Scircumflex"] = 0x015c;
 
-  t["Scommaaccent"] = 0x0218;
 
-  t["Sdotaccent"] = 0x1e60;
 
-  t["Sdotbelow"] = 0x1e62;
 
-  t["Sdotbelowdotaccent"] = 0x1e68;
 
-  t["Seharmenian"] = 0x054d;
 
-  t["Sevenroman"] = 0x2166;
 
-  t["Shaarmenian"] = 0x0547;
 
-  t["Shacyrillic"] = 0x0428;
 
-  t["Shchacyrillic"] = 0x0429;
 
-  t["Sheicoptic"] = 0x03e2;
 
-  t["Shhacyrillic"] = 0x04ba;
 
-  t["Shimacoptic"] = 0x03ec;
 
-  t["Sigma"] = 0x03a3;
 
-  t["Sixroman"] = 0x2165;
 
-  t["Smonospace"] = 0xff33;
 
-  t["Softsigncyrillic"] = 0x042c;
 
-  t["Ssmall"] = 0xf773;
 
-  t["Stigmagreek"] = 0x03da;
 
-  t["T"] = 0x0054;
 
-  t["Tau"] = 0x03a4;
 
-  t["Tbar"] = 0x0166;
 
-  t["Tcaron"] = 0x0164;
 
-  t["Tcedilla"] = 0x0162;
 
-  t["Tcircle"] = 0x24c9;
 
-  t["Tcircumflexbelow"] = 0x1e70;
 
-  t["Tcommaaccent"] = 0x0162;
 
-  t["Tdotaccent"] = 0x1e6a;
 
-  t["Tdotbelow"] = 0x1e6c;
 
-  t["Tecyrillic"] = 0x0422;
 
-  t["Tedescendercyrillic"] = 0x04ac;
 
-  t["Tenroman"] = 0x2169;
 
-  t["Tetsecyrillic"] = 0x04b4;
 
-  t["Theta"] = 0x0398;
 
-  t["Thook"] = 0x01ac;
 
-  t["Thorn"] = 0x00de;
 
-  t["Thornsmall"] = 0xf7fe;
 
-  t["Threeroman"] = 0x2162;
 
-  t["Tildesmall"] = 0xf6fe;
 
-  t["Tiwnarmenian"] = 0x054f;
 
-  t["Tlinebelow"] = 0x1e6e;
 
-  t["Tmonospace"] = 0xff34;
 
-  t["Toarmenian"] = 0x0539;
 
-  t["Tonefive"] = 0x01bc;
 
-  t["Tonesix"] = 0x0184;
 
-  t["Tonetwo"] = 0x01a7;
 
-  t["Tretroflexhook"] = 0x01ae;
 
-  t["Tsecyrillic"] = 0x0426;
 
-  t["Tshecyrillic"] = 0x040b;
 
-  t["Tsmall"] = 0xf774;
 
-  t["Twelveroman"] = 0x216b;
 
-  t["Tworoman"] = 0x2161;
 
-  t["U"] = 0x0055;
 
-  t["Uacute"] = 0x00da;
 
-  t["Uacutesmall"] = 0xf7fa;
 
-  t["Ubreve"] = 0x016c;
 
-  t["Ucaron"] = 0x01d3;
 
-  t["Ucircle"] = 0x24ca;
 
-  t["Ucircumflex"] = 0x00db;
 
-  t["Ucircumflexbelow"] = 0x1e76;
 
-  t["Ucircumflexsmall"] = 0xf7fb;
 
-  t["Ucyrillic"] = 0x0423;
 
-  t["Udblacute"] = 0x0170;
 
-  t["Udblgrave"] = 0x0214;
 
-  t["Udieresis"] = 0x00dc;
 
-  t["Udieresisacute"] = 0x01d7;
 
-  t["Udieresisbelow"] = 0x1e72;
 
-  t["Udieresiscaron"] = 0x01d9;
 
-  t["Udieresiscyrillic"] = 0x04f0;
 
-  t["Udieresisgrave"] = 0x01db;
 
-  t["Udieresismacron"] = 0x01d5;
 
-  t["Udieresissmall"] = 0xf7fc;
 
-  t["Udotbelow"] = 0x1ee4;
 
-  t["Ugrave"] = 0x00d9;
 
-  t["Ugravesmall"] = 0xf7f9;
 
-  t["Uhookabove"] = 0x1ee6;
 
-  t["Uhorn"] = 0x01af;
 
-  t["Uhornacute"] = 0x1ee8;
 
-  t["Uhorndotbelow"] = 0x1ef0;
 
-  t["Uhorngrave"] = 0x1eea;
 
-  t["Uhornhookabove"] = 0x1eec;
 
-  t["Uhorntilde"] = 0x1eee;
 
-  t["Uhungarumlaut"] = 0x0170;
 
-  t["Uhungarumlautcyrillic"] = 0x04f2;
 
-  t["Uinvertedbreve"] = 0x0216;
 
-  t["Ukcyrillic"] = 0x0478;
 
-  t["Umacron"] = 0x016a;
 
-  t["Umacroncyrillic"] = 0x04ee;
 
-  t["Umacrondieresis"] = 0x1e7a;
 
-  t["Umonospace"] = 0xff35;
 
-  t["Uogonek"] = 0x0172;
 
-  t["Upsilon"] = 0x03a5;
 
-  t["Upsilon1"] = 0x03d2;
 
-  t["Upsilonacutehooksymbolgreek"] = 0x03d3;
 
-  t["Upsilonafrican"] = 0x01b1;
 
-  t["Upsilondieresis"] = 0x03ab;
 
-  t["Upsilondieresishooksymbolgreek"] = 0x03d4;
 
-  t["Upsilonhooksymbol"] = 0x03d2;
 
-  t["Upsilontonos"] = 0x038e;
 
-  t["Uring"] = 0x016e;
 
-  t["Ushortcyrillic"] = 0x040e;
 
-  t["Usmall"] = 0xf775;
 
-  t["Ustraightcyrillic"] = 0x04ae;
 
-  t["Ustraightstrokecyrillic"] = 0x04b0;
 
-  t["Utilde"] = 0x0168;
 
-  t["Utildeacute"] = 0x1e78;
 
-  t["Utildebelow"] = 0x1e74;
 
-  t["V"] = 0x0056;
 
-  t["Vcircle"] = 0x24cb;
 
-  t["Vdotbelow"] = 0x1e7e;
 
-  t["Vecyrillic"] = 0x0412;
 
-  t["Vewarmenian"] = 0x054e;
 
-  t["Vhook"] = 0x01b2;
 
-  t["Vmonospace"] = 0xff36;
 
-  t["Voarmenian"] = 0x0548;
 
-  t["Vsmall"] = 0xf776;
 
-  t["Vtilde"] = 0x1e7c;
 
-  t["W"] = 0x0057;
 
-  t["Wacute"] = 0x1e82;
 
-  t["Wcircle"] = 0x24cc;
 
-  t["Wcircumflex"] = 0x0174;
 
-  t["Wdieresis"] = 0x1e84;
 
-  t["Wdotaccent"] = 0x1e86;
 
-  t["Wdotbelow"] = 0x1e88;
 
-  t["Wgrave"] = 0x1e80;
 
-  t["Wmonospace"] = 0xff37;
 
-  t["Wsmall"] = 0xf777;
 
-  t["X"] = 0x0058;
 
-  t["Xcircle"] = 0x24cd;
 
-  t["Xdieresis"] = 0x1e8c;
 
-  t["Xdotaccent"] = 0x1e8a;
 
-  t["Xeharmenian"] = 0x053d;
 
-  t["Xi"] = 0x039e;
 
-  t["Xmonospace"] = 0xff38;
 
-  t["Xsmall"] = 0xf778;
 
-  t["Y"] = 0x0059;
 
-  t["Yacute"] = 0x00dd;
 
-  t["Yacutesmall"] = 0xf7fd;
 
-  t["Yatcyrillic"] = 0x0462;
 
-  t["Ycircle"] = 0x24ce;
 
-  t["Ycircumflex"] = 0x0176;
 
-  t["Ydieresis"] = 0x0178;
 
-  t["Ydieresissmall"] = 0xf7ff;
 
-  t["Ydotaccent"] = 0x1e8e;
 
-  t["Ydotbelow"] = 0x1ef4;
 
-  t["Yericyrillic"] = 0x042b;
 
-  t["Yerudieresiscyrillic"] = 0x04f8;
 
-  t["Ygrave"] = 0x1ef2;
 
-  t["Yhook"] = 0x01b3;
 
-  t["Yhookabove"] = 0x1ef6;
 
-  t["Yiarmenian"] = 0x0545;
 
-  t["Yicyrillic"] = 0x0407;
 
-  t["Yiwnarmenian"] = 0x0552;
 
-  t["Ymonospace"] = 0xff39;
 
-  t["Ysmall"] = 0xf779;
 
-  t["Ytilde"] = 0x1ef8;
 
-  t["Yusbigcyrillic"] = 0x046a;
 
-  t["Yusbigiotifiedcyrillic"] = 0x046c;
 
-  t["Yuslittlecyrillic"] = 0x0466;
 
-  t["Yuslittleiotifiedcyrillic"] = 0x0468;
 
-  t["Z"] = 0x005a;
 
-  t["Zaarmenian"] = 0x0536;
 
-  t["Zacute"] = 0x0179;
 
-  t["Zcaron"] = 0x017d;
 
-  t["Zcaronsmall"] = 0xf6ff;
 
-  t["Zcircle"] = 0x24cf;
 
-  t["Zcircumflex"] = 0x1e90;
 
-  t["Zdot"] = 0x017b;
 
-  t["Zdotaccent"] = 0x017b;
 
-  t["Zdotbelow"] = 0x1e92;
 
-  t["Zecyrillic"] = 0x0417;
 
-  t["Zedescendercyrillic"] = 0x0498;
 
-  t["Zedieresiscyrillic"] = 0x04de;
 
-  t["Zeta"] = 0x0396;
 
-  t["Zhearmenian"] = 0x053a;
 
-  t["Zhebrevecyrillic"] = 0x04c1;
 
-  t["Zhecyrillic"] = 0x0416;
 
-  t["Zhedescendercyrillic"] = 0x0496;
 
-  t["Zhedieresiscyrillic"] = 0x04dc;
 
-  t["Zlinebelow"] = 0x1e94;
 
-  t["Zmonospace"] = 0xff3a;
 
-  t["Zsmall"] = 0xf77a;
 
-  t["Zstroke"] = 0x01b5;
 
-  t["a"] = 0x0061;
 
-  t["aabengali"] = 0x0986;
 
-  t["aacute"] = 0x00e1;
 
-  t["aadeva"] = 0x0906;
 
-  t["aagujarati"] = 0x0a86;
 
-  t["aagurmukhi"] = 0x0a06;
 
-  t["aamatragurmukhi"] = 0x0a3e;
 
-  t["aarusquare"] = 0x3303;
 
-  t["aavowelsignbengali"] = 0x09be;
 
-  t["aavowelsigndeva"] = 0x093e;
 
-  t["aavowelsigngujarati"] = 0x0abe;
 
-  t["abbreviationmarkarmenian"] = 0x055f;
 
-  t["abbreviationsigndeva"] = 0x0970;
 
-  t["abengali"] = 0x0985;
 
-  t["abopomofo"] = 0x311a;
 
-  t["abreve"] = 0x0103;
 
-  t["abreveacute"] = 0x1eaf;
 
-  t["abrevecyrillic"] = 0x04d1;
 
-  t["abrevedotbelow"] = 0x1eb7;
 
-  t["abrevegrave"] = 0x1eb1;
 
-  t["abrevehookabove"] = 0x1eb3;
 
-  t["abrevetilde"] = 0x1eb5;
 
-  t["acaron"] = 0x01ce;
 
-  t["acircle"] = 0x24d0;
 
-  t["acircumflex"] = 0x00e2;
 
-  t["acircumflexacute"] = 0x1ea5;
 
-  t["acircumflexdotbelow"] = 0x1ead;
 
-  t["acircumflexgrave"] = 0x1ea7;
 
-  t["acircumflexhookabove"] = 0x1ea9;
 
-  t["acircumflextilde"] = 0x1eab;
 
-  t["acute"] = 0x00b4;
 
-  t["acutebelowcmb"] = 0x0317;
 
-  t["acutecmb"] = 0x0301;
 
-  t["acutecomb"] = 0x0301;
 
-  t["acutedeva"] = 0x0954;
 
-  t["acutelowmod"] = 0x02cf;
 
-  t["acutetonecmb"] = 0x0341;
 
-  t["acyrillic"] = 0x0430;
 
-  t["adblgrave"] = 0x0201;
 
-  t["addakgurmukhi"] = 0x0a71;
 
-  t["adeva"] = 0x0905;
 
-  t["adieresis"] = 0x00e4;
 
-  t["adieresiscyrillic"] = 0x04d3;
 
-  t["adieresismacron"] = 0x01df;
 
-  t["adotbelow"] = 0x1ea1;
 
-  t["adotmacron"] = 0x01e1;
 
-  t["ae"] = 0x00e6;
 
-  t["aeacute"] = 0x01fd;
 
-  t["aekorean"] = 0x3150;
 
-  t["aemacron"] = 0x01e3;
 
-  t["afii00208"] = 0x2015;
 
-  t["afii08941"] = 0x20a4;
 
-  t["afii10017"] = 0x0410;
 
-  t["afii10018"] = 0x0411;
 
-  t["afii10019"] = 0x0412;
 
-  t["afii10020"] = 0x0413;
 
-  t["afii10021"] = 0x0414;
 
-  t["afii10022"] = 0x0415;
 
-  t["afii10023"] = 0x0401;
 
-  t["afii10024"] = 0x0416;
 
-  t["afii10025"] = 0x0417;
 
-  t["afii10026"] = 0x0418;
 
-  t["afii10027"] = 0x0419;
 
-  t["afii10028"] = 0x041a;
 
-  t["afii10029"] = 0x041b;
 
-  t["afii10030"] = 0x041c;
 
-  t["afii10031"] = 0x041d;
 
-  t["afii10032"] = 0x041e;
 
-  t["afii10033"] = 0x041f;
 
-  t["afii10034"] = 0x0420;
 
-  t["afii10035"] = 0x0421;
 
-  t["afii10036"] = 0x0422;
 
-  t["afii10037"] = 0x0423;
 
-  t["afii10038"] = 0x0424;
 
-  t["afii10039"] = 0x0425;
 
-  t["afii10040"] = 0x0426;
 
-  t["afii10041"] = 0x0427;
 
-  t["afii10042"] = 0x0428;
 
-  t["afii10043"] = 0x0429;
 
-  t["afii10044"] = 0x042a;
 
-  t["afii10045"] = 0x042b;
 
-  t["afii10046"] = 0x042c;
 
-  t["afii10047"] = 0x042d;
 
-  t["afii10048"] = 0x042e;
 
-  t["afii10049"] = 0x042f;
 
-  t["afii10050"] = 0x0490;
 
-  t["afii10051"] = 0x0402;
 
-  t["afii10052"] = 0x0403;
 
-  t["afii10053"] = 0x0404;
 
-  t["afii10054"] = 0x0405;
 
-  t["afii10055"] = 0x0406;
 
-  t["afii10056"] = 0x0407;
 
-  t["afii10057"] = 0x0408;
 
-  t["afii10058"] = 0x0409;
 
-  t["afii10059"] = 0x040a;
 
-  t["afii10060"] = 0x040b;
 
-  t["afii10061"] = 0x040c;
 
-  t["afii10062"] = 0x040e;
 
-  t["afii10063"] = 0xf6c4;
 
-  t["afii10064"] = 0xf6c5;
 
-  t["afii10065"] = 0x0430;
 
-  t["afii10066"] = 0x0431;
 
-  t["afii10067"] = 0x0432;
 
-  t["afii10068"] = 0x0433;
 
-  t["afii10069"] = 0x0434;
 
-  t["afii10070"] = 0x0435;
 
-  t["afii10071"] = 0x0451;
 
-  t["afii10072"] = 0x0436;
 
-  t["afii10073"] = 0x0437;
 
-  t["afii10074"] = 0x0438;
 
-  t["afii10075"] = 0x0439;
 
-  t["afii10076"] = 0x043a;
 
-  t["afii10077"] = 0x043b;
 
-  t["afii10078"] = 0x043c;
 
-  t["afii10079"] = 0x043d;
 
-  t["afii10080"] = 0x043e;
 
-  t["afii10081"] = 0x043f;
 
-  t["afii10082"] = 0x0440;
 
-  t["afii10083"] = 0x0441;
 
-  t["afii10084"] = 0x0442;
 
-  t["afii10085"] = 0x0443;
 
-  t["afii10086"] = 0x0444;
 
-  t["afii10087"] = 0x0445;
 
-  t["afii10088"] = 0x0446;
 
-  t["afii10089"] = 0x0447;
 
-  t["afii10090"] = 0x0448;
 
-  t["afii10091"] = 0x0449;
 
-  t["afii10092"] = 0x044a;
 
-  t["afii10093"] = 0x044b;
 
-  t["afii10094"] = 0x044c;
 
-  t["afii10095"] = 0x044d;
 
-  t["afii10096"] = 0x044e;
 
-  t["afii10097"] = 0x044f;
 
-  t["afii10098"] = 0x0491;
 
-  t["afii10099"] = 0x0452;
 
-  t["afii10100"] = 0x0453;
 
-  t["afii10101"] = 0x0454;
 
-  t["afii10102"] = 0x0455;
 
-  t["afii10103"] = 0x0456;
 
-  t["afii10104"] = 0x0457;
 
-  t["afii10105"] = 0x0458;
 
-  t["afii10106"] = 0x0459;
 
-  t["afii10107"] = 0x045a;
 
-  t["afii10108"] = 0x045b;
 
-  t["afii10109"] = 0x045c;
 
-  t["afii10110"] = 0x045e;
 
-  t["afii10145"] = 0x040f;
 
-  t["afii10146"] = 0x0462;
 
-  t["afii10147"] = 0x0472;
 
-  t["afii10148"] = 0x0474;
 
-  t["afii10192"] = 0xf6c6;
 
-  t["afii10193"] = 0x045f;
 
-  t["afii10194"] = 0x0463;
 
-  t["afii10195"] = 0x0473;
 
-  t["afii10196"] = 0x0475;
 
-  t["afii10831"] = 0xf6c7;
 
-  t["afii10832"] = 0xf6c8;
 
-  t["afii10846"] = 0x04d9;
 
-  t["afii299"] = 0x200e;
 
-  t["afii300"] = 0x200f;
 
-  t["afii301"] = 0x200d;
 
-  t["afii57381"] = 0x066a;
 
-  t["afii57388"] = 0x060c;
 
-  t["afii57392"] = 0x0660;
 
-  t["afii57393"] = 0x0661;
 
-  t["afii57394"] = 0x0662;
 
-  t["afii57395"] = 0x0663;
 
-  t["afii57396"] = 0x0664;
 
-  t["afii57397"] = 0x0665;
 
-  t["afii57398"] = 0x0666;
 
-  t["afii57399"] = 0x0667;
 
-  t["afii57400"] = 0x0668;
 
-  t["afii57401"] = 0x0669;
 
-  t["afii57403"] = 0x061b;
 
-  t["afii57407"] = 0x061f;
 
-  t["afii57409"] = 0x0621;
 
-  t["afii57410"] = 0x0622;
 
-  t["afii57411"] = 0x0623;
 
-  t["afii57412"] = 0x0624;
 
-  t["afii57413"] = 0x0625;
 
-  t["afii57414"] = 0x0626;
 
-  t["afii57415"] = 0x0627;
 
-  t["afii57416"] = 0x0628;
 
-  t["afii57417"] = 0x0629;
 
-  t["afii57418"] = 0x062a;
 
-  t["afii57419"] = 0x062b;
 
-  t["afii57420"] = 0x062c;
 
-  t["afii57421"] = 0x062d;
 
-  t["afii57422"] = 0x062e;
 
-  t["afii57423"] = 0x062f;
 
-  t["afii57424"] = 0x0630;
 
-  t["afii57425"] = 0x0631;
 
-  t["afii57426"] = 0x0632;
 
-  t["afii57427"] = 0x0633;
 
-  t["afii57428"] = 0x0634;
 
-  t["afii57429"] = 0x0635;
 
-  t["afii57430"] = 0x0636;
 
-  t["afii57431"] = 0x0637;
 
-  t["afii57432"] = 0x0638;
 
-  t["afii57433"] = 0x0639;
 
-  t["afii57434"] = 0x063a;
 
-  t["afii57440"] = 0x0640;
 
-  t["afii57441"] = 0x0641;
 
-  t["afii57442"] = 0x0642;
 
-  t["afii57443"] = 0x0643;
 
-  t["afii57444"] = 0x0644;
 
-  t["afii57445"] = 0x0645;
 
-  t["afii57446"] = 0x0646;
 
-  t["afii57448"] = 0x0648;
 
-  t["afii57449"] = 0x0649;
 
-  t["afii57450"] = 0x064a;
 
-  t["afii57451"] = 0x064b;
 
-  t["afii57452"] = 0x064c;
 
-  t["afii57453"] = 0x064d;
 
-  t["afii57454"] = 0x064e;
 
-  t["afii57455"] = 0x064f;
 
-  t["afii57456"] = 0x0650;
 
-  t["afii57457"] = 0x0651;
 
-  t["afii57458"] = 0x0652;
 
-  t["afii57470"] = 0x0647;
 
-  t["afii57505"] = 0x06a4;
 
-  t["afii57506"] = 0x067e;
 
-  t["afii57507"] = 0x0686;
 
-  t["afii57508"] = 0x0698;
 
-  t["afii57509"] = 0x06af;
 
-  t["afii57511"] = 0x0679;
 
-  t["afii57512"] = 0x0688;
 
-  t["afii57513"] = 0x0691;
 
-  t["afii57514"] = 0x06ba;
 
-  t["afii57519"] = 0x06d2;
 
-  t["afii57534"] = 0x06d5;
 
-  t["afii57636"] = 0x20aa;
 
-  t["afii57645"] = 0x05be;
 
-  t["afii57658"] = 0x05c3;
 
-  t["afii57664"] = 0x05d0;
 
-  t["afii57665"] = 0x05d1;
 
-  t["afii57666"] = 0x05d2;
 
-  t["afii57667"] = 0x05d3;
 
-  t["afii57668"] = 0x05d4;
 
-  t["afii57669"] = 0x05d5;
 
-  t["afii57670"] = 0x05d6;
 
-  t["afii57671"] = 0x05d7;
 
-  t["afii57672"] = 0x05d8;
 
-  t["afii57673"] = 0x05d9;
 
-  t["afii57674"] = 0x05da;
 
-  t["afii57675"] = 0x05db;
 
-  t["afii57676"] = 0x05dc;
 
-  t["afii57677"] = 0x05dd;
 
-  t["afii57678"] = 0x05de;
 
-  t["afii57679"] = 0x05df;
 
-  t["afii57680"] = 0x05e0;
 
-  t["afii57681"] = 0x05e1;
 
-  t["afii57682"] = 0x05e2;
 
-  t["afii57683"] = 0x05e3;
 
-  t["afii57684"] = 0x05e4;
 
-  t["afii57685"] = 0x05e5;
 
-  t["afii57686"] = 0x05e6;
 
-  t["afii57687"] = 0x05e7;
 
-  t["afii57688"] = 0x05e8;
 
-  t["afii57689"] = 0x05e9;
 
-  t["afii57690"] = 0x05ea;
 
-  t["afii57694"] = 0xfb2a;
 
-  t["afii57695"] = 0xfb2b;
 
-  t["afii57700"] = 0xfb4b;
 
-  t["afii57705"] = 0xfb1f;
 
-  t["afii57716"] = 0x05f0;
 
-  t["afii57717"] = 0x05f1;
 
-  t["afii57718"] = 0x05f2;
 
-  t["afii57723"] = 0xfb35;
 
-  t["afii57793"] = 0x05b4;
 
-  t["afii57794"] = 0x05b5;
 
-  t["afii57795"] = 0x05b6;
 
-  t["afii57796"] = 0x05bb;
 
-  t["afii57797"] = 0x05b8;
 
-  t["afii57798"] = 0x05b7;
 
-  t["afii57799"] = 0x05b0;
 
-  t["afii57800"] = 0x05b2;
 
-  t["afii57801"] = 0x05b1;
 
-  t["afii57802"] = 0x05b3;
 
-  t["afii57803"] = 0x05c2;
 
-  t["afii57804"] = 0x05c1;
 
-  t["afii57806"] = 0x05b9;
 
-  t["afii57807"] = 0x05bc;
 
-  t["afii57839"] = 0x05bd;
 
-  t["afii57841"] = 0x05bf;
 
-  t["afii57842"] = 0x05c0;
 
-  t["afii57929"] = 0x02bc;
 
-  t["afii61248"] = 0x2105;
 
-  t["afii61289"] = 0x2113;
 
-  t["afii61352"] = 0x2116;
 
-  t["afii61573"] = 0x202c;
 
-  t["afii61574"] = 0x202d;
 
-  t["afii61575"] = 0x202e;
 
-  t["afii61664"] = 0x200c;
 
-  t["afii63167"] = 0x066d;
 
-  t["afii64937"] = 0x02bd;
 
-  t["agrave"] = 0x00e0;
 
-  t["agujarati"] = 0x0a85;
 
-  t["agurmukhi"] = 0x0a05;
 
-  t["ahiragana"] = 0x3042;
 
-  t["ahookabove"] = 0x1ea3;
 
-  t["aibengali"] = 0x0990;
 
-  t["aibopomofo"] = 0x311e;
 
-  t["aideva"] = 0x0910;
 
-  t["aiecyrillic"] = 0x04d5;
 
-  t["aigujarati"] = 0x0a90;
 
-  t["aigurmukhi"] = 0x0a10;
 
-  t["aimatragurmukhi"] = 0x0a48;
 
-  t["ainarabic"] = 0x0639;
 
-  t["ainfinalarabic"] = 0xfeca;
 
-  t["aininitialarabic"] = 0xfecb;
 
-  t["ainmedialarabic"] = 0xfecc;
 
-  t["ainvertedbreve"] = 0x0203;
 
-  t["aivowelsignbengali"] = 0x09c8;
 
-  t["aivowelsigndeva"] = 0x0948;
 
-  t["aivowelsigngujarati"] = 0x0ac8;
 
-  t["akatakana"] = 0x30a2;
 
-  t["akatakanahalfwidth"] = 0xff71;
 
-  t["akorean"] = 0x314f;
 
-  t["alef"] = 0x05d0;
 
-  t["alefarabic"] = 0x0627;
 
-  t["alefdageshhebrew"] = 0xfb30;
 
-  t["aleffinalarabic"] = 0xfe8e;
 
-  t["alefhamzaabovearabic"] = 0x0623;
 
-  t["alefhamzaabovefinalarabic"] = 0xfe84;
 
-  t["alefhamzabelowarabic"] = 0x0625;
 
-  t["alefhamzabelowfinalarabic"] = 0xfe88;
 
-  t["alefhebrew"] = 0x05d0;
 
-  t["aleflamedhebrew"] = 0xfb4f;
 
-  t["alefmaddaabovearabic"] = 0x0622;
 
-  t["alefmaddaabovefinalarabic"] = 0xfe82;
 
-  t["alefmaksuraarabic"] = 0x0649;
 
-  t["alefmaksurafinalarabic"] = 0xfef0;
 
-  t["alefmaksurainitialarabic"] = 0xfef3;
 
-  t["alefmaksuramedialarabic"] = 0xfef4;
 
-  t["alefpatahhebrew"] = 0xfb2e;
 
-  t["alefqamatshebrew"] = 0xfb2f;
 
-  t["aleph"] = 0x2135;
 
-  t["allequal"] = 0x224c;
 
-  t["alpha"] = 0x03b1;
 
-  t["alphatonos"] = 0x03ac;
 
-  t["amacron"] = 0x0101;
 
-  t["amonospace"] = 0xff41;
 
-  t["ampersand"] = 0x0026;
 
-  t["ampersandmonospace"] = 0xff06;
 
-  t["ampersandsmall"] = 0xf726;
 
-  t["amsquare"] = 0x33c2;
 
-  t["anbopomofo"] = 0x3122;
 
-  t["angbopomofo"] = 0x3124;
 
-  t["angbracketleft"] = 0x3008;
 
-  t["angbracketright"] = 0x3009;
 
-  t["angkhankhuthai"] = 0x0e5a;
 
-  t["angle"] = 0x2220;
 
-  t["anglebracketleft"] = 0x3008;
 
-  t["anglebracketleftvertical"] = 0xfe3f;
 
-  t["anglebracketright"] = 0x3009;
 
-  t["anglebracketrightvertical"] = 0xfe40;
 
-  t["angleleft"] = 0x2329;
 
-  t["angleright"] = 0x232a;
 
-  t["angstrom"] = 0x212b;
 
-  t["anoteleia"] = 0x0387;
 
-  t["anudattadeva"] = 0x0952;
 
-  t["anusvarabengali"] = 0x0982;
 
-  t["anusvaradeva"] = 0x0902;
 
-  t["anusvaragujarati"] = 0x0a82;
 
-  t["aogonek"] = 0x0105;
 
-  t["apaatosquare"] = 0x3300;
 
-  t["aparen"] = 0x249c;
 
-  t["apostrophearmenian"] = 0x055a;
 
-  t["apostrophemod"] = 0x02bc;
 
-  t["apple"] = 0xf8ff;
 
-  t["approaches"] = 0x2250;
 
-  t["approxequal"] = 0x2248;
 
-  t["approxequalorimage"] = 0x2252;
 
-  t["approximatelyequal"] = 0x2245;
 
-  t["araeaekorean"] = 0x318e;
 
-  t["araeakorean"] = 0x318d;
 
-  t["arc"] = 0x2312;
 
-  t["arighthalfring"] = 0x1e9a;
 
-  t["aring"] = 0x00e5;
 
-  t["aringacute"] = 0x01fb;
 
-  t["aringbelow"] = 0x1e01;
 
-  t["arrowboth"] = 0x2194;
 
-  t["arrowdashdown"] = 0x21e3;
 
-  t["arrowdashleft"] = 0x21e0;
 
-  t["arrowdashright"] = 0x21e2;
 
-  t["arrowdashup"] = 0x21e1;
 
-  t["arrowdblboth"] = 0x21d4;
 
-  t["arrowdbldown"] = 0x21d3;
 
-  t["arrowdblleft"] = 0x21d0;
 
-  t["arrowdblright"] = 0x21d2;
 
-  t["arrowdblup"] = 0x21d1;
 
-  t["arrowdown"] = 0x2193;
 
-  t["arrowdownleft"] = 0x2199;
 
-  t["arrowdownright"] = 0x2198;
 
-  t["arrowdownwhite"] = 0x21e9;
 
-  t["arrowheaddownmod"] = 0x02c5;
 
-  t["arrowheadleftmod"] = 0x02c2;
 
-  t["arrowheadrightmod"] = 0x02c3;
 
-  t["arrowheadupmod"] = 0x02c4;
 
-  t["arrowhorizex"] = 0xf8e7;
 
-  t["arrowleft"] = 0x2190;
 
-  t["arrowleftdbl"] = 0x21d0;
 
-  t["arrowleftdblstroke"] = 0x21cd;
 
-  t["arrowleftoverright"] = 0x21c6;
 
-  t["arrowleftwhite"] = 0x21e6;
 
-  t["arrowright"] = 0x2192;
 
-  t["arrowrightdblstroke"] = 0x21cf;
 
-  t["arrowrightheavy"] = 0x279e;
 
-  t["arrowrightoverleft"] = 0x21c4;
 
-  t["arrowrightwhite"] = 0x21e8;
 
-  t["arrowtableft"] = 0x21e4;
 
-  t["arrowtabright"] = 0x21e5;
 
-  t["arrowup"] = 0x2191;
 
-  t["arrowupdn"] = 0x2195;
 
-  t["arrowupdnbse"] = 0x21a8;
 
-  t["arrowupdownbase"] = 0x21a8;
 
-  t["arrowupleft"] = 0x2196;
 
-  t["arrowupleftofdown"] = 0x21c5;
 
-  t["arrowupright"] = 0x2197;
 
-  t["arrowupwhite"] = 0x21e7;
 
-  t["arrowvertex"] = 0xf8e6;
 
-  t["asciicircum"] = 0x005e;
 
-  t["asciicircummonospace"] = 0xff3e;
 
-  t["asciitilde"] = 0x007e;
 
-  t["asciitildemonospace"] = 0xff5e;
 
-  t["ascript"] = 0x0251;
 
-  t["ascriptturned"] = 0x0252;
 
-  t["asmallhiragana"] = 0x3041;
 
-  t["asmallkatakana"] = 0x30a1;
 
-  t["asmallkatakanahalfwidth"] = 0xff67;
 
-  t["asterisk"] = 0x002a;
 
-  t["asteriskaltonearabic"] = 0x066d;
 
-  t["asteriskarabic"] = 0x066d;
 
-  t["asteriskmath"] = 0x2217;
 
-  t["asteriskmonospace"] = 0xff0a;
 
-  t["asterisksmall"] = 0xfe61;
 
-  t["asterism"] = 0x2042;
 
-  t["asuperior"] = 0xf6e9;
 
-  t["asymptoticallyequal"] = 0x2243;
 
-  t["at"] = 0x0040;
 
-  t["atilde"] = 0x00e3;
 
-  t["atmonospace"] = 0xff20;
 
-  t["atsmall"] = 0xfe6b;
 
-  t["aturned"] = 0x0250;
 
-  t["aubengali"] = 0x0994;
 
-  t["aubopomofo"] = 0x3120;
 
-  t["audeva"] = 0x0914;
 
-  t["augujarati"] = 0x0a94;
 
-  t["augurmukhi"] = 0x0a14;
 
-  t["aulengthmarkbengali"] = 0x09d7;
 
-  t["aumatragurmukhi"] = 0x0a4c;
 
-  t["auvowelsignbengali"] = 0x09cc;
 
-  t["auvowelsigndeva"] = 0x094c;
 
-  t["auvowelsigngujarati"] = 0x0acc;
 
-  t["avagrahadeva"] = 0x093d;
 
-  t["aybarmenian"] = 0x0561;
 
-  t["ayin"] = 0x05e2;
 
-  t["ayinaltonehebrew"] = 0xfb20;
 
-  t["ayinhebrew"] = 0x05e2;
 
-  t["b"] = 0x0062;
 
-  t["babengali"] = 0x09ac;
 
-  t["backslash"] = 0x005c;
 
-  t["backslashmonospace"] = 0xff3c;
 
-  t["badeva"] = 0x092c;
 
-  t["bagujarati"] = 0x0aac;
 
-  t["bagurmukhi"] = 0x0a2c;
 
-  t["bahiragana"] = 0x3070;
 
-  t["bahtthai"] = 0x0e3f;
 
-  t["bakatakana"] = 0x30d0;
 
-  t["bar"] = 0x007c;
 
-  t["barmonospace"] = 0xff5c;
 
-  t["bbopomofo"] = 0x3105;
 
-  t["bcircle"] = 0x24d1;
 
-  t["bdotaccent"] = 0x1e03;
 
-  t["bdotbelow"] = 0x1e05;
 
-  t["beamedsixteenthnotes"] = 0x266c;
 
-  t["because"] = 0x2235;
 
-  t["becyrillic"] = 0x0431;
 
-  t["beharabic"] = 0x0628;
 
-  t["behfinalarabic"] = 0xfe90;
 
-  t["behinitialarabic"] = 0xfe91;
 
-  t["behiragana"] = 0x3079;
 
-  t["behmedialarabic"] = 0xfe92;
 
-  t["behmeeminitialarabic"] = 0xfc9f;
 
-  t["behmeemisolatedarabic"] = 0xfc08;
 
-  t["behnoonfinalarabic"] = 0xfc6d;
 
-  t["bekatakana"] = 0x30d9;
 
-  t["benarmenian"] = 0x0562;
 
-  t["bet"] = 0x05d1;
 
-  t["beta"] = 0x03b2;
 
-  t["betasymbolgreek"] = 0x03d0;
 
-  t["betdagesh"] = 0xfb31;
 
-  t["betdageshhebrew"] = 0xfb31;
 
-  t["bethebrew"] = 0x05d1;
 
-  t["betrafehebrew"] = 0xfb4c;
 
-  t["bhabengali"] = 0x09ad;
 
-  t["bhadeva"] = 0x092d;
 
-  t["bhagujarati"] = 0x0aad;
 
-  t["bhagurmukhi"] = 0x0a2d;
 
-  t["bhook"] = 0x0253;
 
-  t["bihiragana"] = 0x3073;
 
-  t["bikatakana"] = 0x30d3;
 
-  t["bilabialclick"] = 0x0298;
 
-  t["bindigurmukhi"] = 0x0a02;
 
-  t["birusquare"] = 0x3331;
 
-  t["blackcircle"] = 0x25cf;
 
-  t["blackdiamond"] = 0x25c6;
 
-  t["blackdownpointingtriangle"] = 0x25bc;
 
-  t["blackleftpointingpointer"] = 0x25c4;
 
-  t["blackleftpointingtriangle"] = 0x25c0;
 
-  t["blacklenticularbracketleft"] = 0x3010;
 
-  t["blacklenticularbracketleftvertical"] = 0xfe3b;
 
-  t["blacklenticularbracketright"] = 0x3011;
 
-  t["blacklenticularbracketrightvertical"] = 0xfe3c;
 
-  t["blacklowerlefttriangle"] = 0x25e3;
 
-  t["blacklowerrighttriangle"] = 0x25e2;
 
-  t["blackrectangle"] = 0x25ac;
 
-  t["blackrightpointingpointer"] = 0x25ba;
 
-  t["blackrightpointingtriangle"] = 0x25b6;
 
-  t["blacksmallsquare"] = 0x25aa;
 
-  t["blacksmilingface"] = 0x263b;
 
-  t["blacksquare"] = 0x25a0;
 
-  t["blackstar"] = 0x2605;
 
-  t["blackupperlefttriangle"] = 0x25e4;
 
-  t["blackupperrighttriangle"] = 0x25e5;
 
-  t["blackuppointingsmalltriangle"] = 0x25b4;
 
-  t["blackuppointingtriangle"] = 0x25b2;
 
-  t["blank"] = 0x2423;
 
-  t["blinebelow"] = 0x1e07;
 
-  t["block"] = 0x2588;
 
-  t["bmonospace"] = 0xff42;
 
-  t["bobaimaithai"] = 0x0e1a;
 
-  t["bohiragana"] = 0x307c;
 
-  t["bokatakana"] = 0x30dc;
 
-  t["bparen"] = 0x249d;
 
-  t["bqsquare"] = 0x33c3;
 
-  t["braceex"] = 0xf8f4;
 
-  t["braceleft"] = 0x007b;
 
-  t["braceleftbt"] = 0xf8f3;
 
-  t["braceleftmid"] = 0xf8f2;
 
-  t["braceleftmonospace"] = 0xff5b;
 
-  t["braceleftsmall"] = 0xfe5b;
 
-  t["bracelefttp"] = 0xf8f1;
 
-  t["braceleftvertical"] = 0xfe37;
 
-  t["braceright"] = 0x007d;
 
-  t["bracerightbt"] = 0xf8fe;
 
-  t["bracerightmid"] = 0xf8fd;
 
-  t["bracerightmonospace"] = 0xff5d;
 
-  t["bracerightsmall"] = 0xfe5c;
 
-  t["bracerighttp"] = 0xf8fc;
 
-  t["bracerightvertical"] = 0xfe38;
 
-  t["bracketleft"] = 0x005b;
 
-  t["bracketleftbt"] = 0xf8f0;
 
-  t["bracketleftex"] = 0xf8ef;
 
-  t["bracketleftmonospace"] = 0xff3b;
 
-  t["bracketlefttp"] = 0xf8ee;
 
-  t["bracketright"] = 0x005d;
 
-  t["bracketrightbt"] = 0xf8fb;
 
-  t["bracketrightex"] = 0xf8fa;
 
-  t["bracketrightmonospace"] = 0xff3d;
 
-  t["bracketrighttp"] = 0xf8f9;
 
-  t["breve"] = 0x02d8;
 
-  t["brevebelowcmb"] = 0x032e;
 
-  t["brevecmb"] = 0x0306;
 
-  t["breveinvertedbelowcmb"] = 0x032f;
 
-  t["breveinvertedcmb"] = 0x0311;
 
-  t["breveinverteddoublecmb"] = 0x0361;
 
-  t["bridgebelowcmb"] = 0x032a;
 
-  t["bridgeinvertedbelowcmb"] = 0x033a;
 
-  t["brokenbar"] = 0x00a6;
 
-  t["bstroke"] = 0x0180;
 
-  t["bsuperior"] = 0xf6ea;
 
-  t["btopbar"] = 0x0183;
 
-  t["buhiragana"] = 0x3076;
 
-  t["bukatakana"] = 0x30d6;
 
-  t["bullet"] = 0x2022;
 
-  t["bulletinverse"] = 0x25d8;
 
-  t["bulletoperator"] = 0x2219;
 
-  t["bullseye"] = 0x25ce;
 
-  t["c"] = 0x0063;
 
-  t["caarmenian"] = 0x056e;
 
-  t["cabengali"] = 0x099a;
 
-  t["cacute"] = 0x0107;
 
-  t["cadeva"] = 0x091a;
 
-  t["cagujarati"] = 0x0a9a;
 
-  t["cagurmukhi"] = 0x0a1a;
 
-  t["calsquare"] = 0x3388;
 
-  t["candrabindubengali"] = 0x0981;
 
-  t["candrabinducmb"] = 0x0310;
 
-  t["candrabindudeva"] = 0x0901;
 
-  t["candrabindugujarati"] = 0x0a81;
 
-  t["capslock"] = 0x21ea;
 
-  t["careof"] = 0x2105;
 
-  t["caron"] = 0x02c7;
 
-  t["caronbelowcmb"] = 0x032c;
 
-  t["caroncmb"] = 0x030c;
 
-  t["carriagereturn"] = 0x21b5;
 
-  t["cbopomofo"] = 0x3118;
 
-  t["ccaron"] = 0x010d;
 
-  t["ccedilla"] = 0x00e7;
 
-  t["ccedillaacute"] = 0x1e09;
 
-  t["ccircle"] = 0x24d2;
 
-  t["ccircumflex"] = 0x0109;
 
-  t["ccurl"] = 0x0255;
 
-  t["cdot"] = 0x010b;
 
-  t["cdotaccent"] = 0x010b;
 
-  t["cdsquare"] = 0x33c5;
 
-  t["cedilla"] = 0x00b8;
 
-  t["cedillacmb"] = 0x0327;
 
-  t["cent"] = 0x00a2;
 
-  t["centigrade"] = 0x2103;
 
-  t["centinferior"] = 0xf6df;
 
-  t["centmonospace"] = 0xffe0;
 
-  t["centoldstyle"] = 0xf7a2;
 
-  t["centsuperior"] = 0xf6e0;
 
-  t["chaarmenian"] = 0x0579;
 
-  t["chabengali"] = 0x099b;
 
-  t["chadeva"] = 0x091b;
 
-  t["chagujarati"] = 0x0a9b;
 
-  t["chagurmukhi"] = 0x0a1b;
 
-  t["chbopomofo"] = 0x3114;
 
-  t["cheabkhasiancyrillic"] = 0x04bd;
 
-  t["checkmark"] = 0x2713;
 
-  t["checyrillic"] = 0x0447;
 
-  t["chedescenderabkhasiancyrillic"] = 0x04bf;
 
-  t["chedescendercyrillic"] = 0x04b7;
 
-  t["chedieresiscyrillic"] = 0x04f5;
 
-  t["cheharmenian"] = 0x0573;
 
-  t["chekhakassiancyrillic"] = 0x04cc;
 
-  t["cheverticalstrokecyrillic"] = 0x04b9;
 
-  t["chi"] = 0x03c7;
 
-  t["chieuchacirclekorean"] = 0x3277;
 
-  t["chieuchaparenkorean"] = 0x3217;
 
-  t["chieuchcirclekorean"] = 0x3269;
 
-  t["chieuchkorean"] = 0x314a;
 
-  t["chieuchparenkorean"] = 0x3209;
 
-  t["chochangthai"] = 0x0e0a;
 
-  t["chochanthai"] = 0x0e08;
 
-  t["chochingthai"] = 0x0e09;
 
-  t["chochoethai"] = 0x0e0c;
 
-  t["chook"] = 0x0188;
 
-  t["cieucacirclekorean"] = 0x3276;
 
-  t["cieucaparenkorean"] = 0x3216;
 
-  t["cieuccirclekorean"] = 0x3268;
 
-  t["cieuckorean"] = 0x3148;
 
-  t["cieucparenkorean"] = 0x3208;
 
-  t["cieucuparenkorean"] = 0x321c;
 
-  t["circle"] = 0x25cb;
 
-  t["circlecopyrt"] = 0x00a9;
 
-  t["circlemultiply"] = 0x2297;
 
-  t["circleot"] = 0x2299;
 
-  t["circleplus"] = 0x2295;
 
-  t["circlepostalmark"] = 0x3036;
 
-  t["circlewithlefthalfblack"] = 0x25d0;
 
-  t["circlewithrighthalfblack"] = 0x25d1;
 
-  t["circumflex"] = 0x02c6;
 
-  t["circumflexbelowcmb"] = 0x032d;
 
-  t["circumflexcmb"] = 0x0302;
 
-  t["clear"] = 0x2327;
 
-  t["clickalveolar"] = 0x01c2;
 
-  t["clickdental"] = 0x01c0;
 
-  t["clicklateral"] = 0x01c1;
 
-  t["clickretroflex"] = 0x01c3;
 
-  t["club"] = 0x2663;
 
-  t["clubsuitblack"] = 0x2663;
 
-  t["clubsuitwhite"] = 0x2667;
 
-  t["cmcubedsquare"] = 0x33a4;
 
-  t["cmonospace"] = 0xff43;
 
-  t["cmsquaredsquare"] = 0x33a0;
 
-  t["coarmenian"] = 0x0581;
 
-  t["colon"] = 0x003a;
 
-  t["colonmonetary"] = 0x20a1;
 
-  t["colonmonospace"] = 0xff1a;
 
-  t["colonsign"] = 0x20a1;
 
-  t["colonsmall"] = 0xfe55;
 
-  t["colontriangularhalfmod"] = 0x02d1;
 
-  t["colontriangularmod"] = 0x02d0;
 
-  t["comma"] = 0x002c;
 
-  t["commaabovecmb"] = 0x0313;
 
-  t["commaaboverightcmb"] = 0x0315;
 
-  t["commaaccent"] = 0xf6c3;
 
-  t["commaarabic"] = 0x060c;
 
-  t["commaarmenian"] = 0x055d;
 
-  t["commainferior"] = 0xf6e1;
 
-  t["commamonospace"] = 0xff0c;
 
-  t["commareversedabovecmb"] = 0x0314;
 
-  t["commareversedmod"] = 0x02bd;
 
-  t["commasmall"] = 0xfe50;
 
-  t["commasuperior"] = 0xf6e2;
 
-  t["commaturnedabovecmb"] = 0x0312;
 
-  t["commaturnedmod"] = 0x02bb;
 
-  t["compass"] = 0x263c;
 
-  t["congruent"] = 0x2245;
 
-  t["contourintegral"] = 0x222e;
 
-  t["control"] = 0x2303;
 
-  t["controlACK"] = 0x0006;
 
-  t["controlBEL"] = 0x0007;
 
-  t["controlBS"] = 0x0008;
 
-  t["controlCAN"] = 0x0018;
 
-  t["controlCR"] = 0x000d;
 
-  t["controlDC1"] = 0x0011;
 
-  t["controlDC2"] = 0x0012;
 
-  t["controlDC3"] = 0x0013;
 
-  t["controlDC4"] = 0x0014;
 
-  t["controlDEL"] = 0x007f;
 
-  t["controlDLE"] = 0x0010;
 
-  t["controlEM"] = 0x0019;
 
-  t["controlENQ"] = 0x0005;
 
-  t["controlEOT"] = 0x0004;
 
-  t["controlESC"] = 0x001b;
 
-  t["controlETB"] = 0x0017;
 
-  t["controlETX"] = 0x0003;
 
-  t["controlFF"] = 0x000c;
 
-  t["controlFS"] = 0x001c;
 
-  t["controlGS"] = 0x001d;
 
-  t["controlHT"] = 0x0009;
 
-  t["controlLF"] = 0x000a;
 
-  t["controlNAK"] = 0x0015;
 
-  t["controlNULL"] = 0x0000;
 
-  t["controlRS"] = 0x001e;
 
-  t["controlSI"] = 0x000f;
 
-  t["controlSO"] = 0x000e;
 
-  t["controlSOT"] = 0x0002;
 
-  t["controlSTX"] = 0x0001;
 
-  t["controlSUB"] = 0x001a;
 
-  t["controlSYN"] = 0x0016;
 
-  t["controlUS"] = 0x001f;
 
-  t["controlVT"] = 0x000b;
 
-  t["copyright"] = 0x00a9;
 
-  t["copyrightsans"] = 0xf8e9;
 
-  t["copyrightserif"] = 0xf6d9;
 
-  t["cornerbracketleft"] = 0x300c;
 
-  t["cornerbracketlefthalfwidth"] = 0xff62;
 
-  t["cornerbracketleftvertical"] = 0xfe41;
 
-  t["cornerbracketright"] = 0x300d;
 
-  t["cornerbracketrighthalfwidth"] = 0xff63;
 
-  t["cornerbracketrightvertical"] = 0xfe42;
 
-  t["corporationsquare"] = 0x337f;
 
-  t["cosquare"] = 0x33c7;
 
-  t["coverkgsquare"] = 0x33c6;
 
-  t["cparen"] = 0x249e;
 
-  t["cruzeiro"] = 0x20a2;
 
-  t["cstretched"] = 0x0297;
 
-  t["curlyand"] = 0x22cf;
 
-  t["curlyor"] = 0x22ce;
 
-  t["currency"] = 0x00a4;
 
-  t["cyrBreve"] = 0xf6d1;
 
-  t["cyrFlex"] = 0xf6d2;
 
-  t["cyrbreve"] = 0xf6d4;
 
-  t["cyrflex"] = 0xf6d5;
 
-  t["d"] = 0x0064;
 
-  t["daarmenian"] = 0x0564;
 
-  t["dabengali"] = 0x09a6;
 
-  t["dadarabic"] = 0x0636;
 
-  t["dadeva"] = 0x0926;
 
-  t["dadfinalarabic"] = 0xfebe;
 
-  t["dadinitialarabic"] = 0xfebf;
 
-  t["dadmedialarabic"] = 0xfec0;
 
-  t["dagesh"] = 0x05bc;
 
-  t["dageshhebrew"] = 0x05bc;
 
-  t["dagger"] = 0x2020;
 
-  t["daggerdbl"] = 0x2021;
 
-  t["dagujarati"] = 0x0aa6;
 
-  t["dagurmukhi"] = 0x0a26;
 
-  t["dahiragana"] = 0x3060;
 
-  t["dakatakana"] = 0x30c0;
 
-  t["dalarabic"] = 0x062f;
 
-  t["dalet"] = 0x05d3;
 
-  t["daletdagesh"] = 0xfb33;
 
-  t["daletdageshhebrew"] = 0xfb33;
 
-  t["dalethebrew"] = 0x05d3;
 
-  t["dalfinalarabic"] = 0xfeaa;
 
-  t["dammaarabic"] = 0x064f;
 
-  t["dammalowarabic"] = 0x064f;
 
-  t["dammatanaltonearabic"] = 0x064c;
 
-  t["dammatanarabic"] = 0x064c;
 
-  t["danda"] = 0x0964;
 
-  t["dargahebrew"] = 0x05a7;
 
-  t["dargalefthebrew"] = 0x05a7;
 
-  t["dasiapneumatacyrilliccmb"] = 0x0485;
 
-  t["dblGrave"] = 0xf6d3;
 
-  t["dblanglebracketleft"] = 0x300a;
 
-  t["dblanglebracketleftvertical"] = 0xfe3d;
 
-  t["dblanglebracketright"] = 0x300b;
 
-  t["dblanglebracketrightvertical"] = 0xfe3e;
 
-  t["dblarchinvertedbelowcmb"] = 0x032b;
 
-  t["dblarrowleft"] = 0x21d4;
 
-  t["dblarrowright"] = 0x21d2;
 
-  t["dbldanda"] = 0x0965;
 
-  t["dblgrave"] = 0xf6d6;
 
-  t["dblgravecmb"] = 0x030f;
 
-  t["dblintegral"] = 0x222c;
 
-  t["dbllowline"] = 0x2017;
 
-  t["dbllowlinecmb"] = 0x0333;
 
-  t["dbloverlinecmb"] = 0x033f;
 
-  t["dblprimemod"] = 0x02ba;
 
-  t["dblverticalbar"] = 0x2016;
 
-  t["dblverticallineabovecmb"] = 0x030e;
 
-  t["dbopomofo"] = 0x3109;
 
-  t["dbsquare"] = 0x33c8;
 
-  t["dcaron"] = 0x010f;
 
-  t["dcedilla"] = 0x1e11;
 
-  t["dcircle"] = 0x24d3;
 
-  t["dcircumflexbelow"] = 0x1e13;
 
-  t["dcroat"] = 0x0111;
 
-  t["ddabengali"] = 0x09a1;
 
-  t["ddadeva"] = 0x0921;
 
-  t["ddagujarati"] = 0x0aa1;
 
-  t["ddagurmukhi"] = 0x0a21;
 
-  t["ddalarabic"] = 0x0688;
 
-  t["ddalfinalarabic"] = 0xfb89;
 
-  t["dddhadeva"] = 0x095c;
 
-  t["ddhabengali"] = 0x09a2;
 
-  t["ddhadeva"] = 0x0922;
 
-  t["ddhagujarati"] = 0x0aa2;
 
-  t["ddhagurmukhi"] = 0x0a22;
 
-  t["ddotaccent"] = 0x1e0b;
 
-  t["ddotbelow"] = 0x1e0d;
 
-  t["decimalseparatorarabic"] = 0x066b;
 
-  t["decimalseparatorpersian"] = 0x066b;
 
-  t["decyrillic"] = 0x0434;
 
-  t["degree"] = 0x00b0;
 
-  t["dehihebrew"] = 0x05ad;
 
-  t["dehiragana"] = 0x3067;
 
-  t["deicoptic"] = 0x03ef;
 
-  t["dekatakana"] = 0x30c7;
 
-  t["deleteleft"] = 0x232b;
 
-  t["deleteright"] = 0x2326;
 
-  t["delta"] = 0x03b4;
 
-  t["deltaturned"] = 0x018d;
 
-  t["denominatorminusonenumeratorbengali"] = 0x09f8;
 
-  t["dezh"] = 0x02a4;
 
-  t["dhabengali"] = 0x09a7;
 
-  t["dhadeva"] = 0x0927;
 
-  t["dhagujarati"] = 0x0aa7;
 
-  t["dhagurmukhi"] = 0x0a27;
 
-  t["dhook"] = 0x0257;
 
-  t["dialytikatonos"] = 0x0385;
 
-  t["dialytikatonoscmb"] = 0x0344;
 
-  t["diamond"] = 0x2666;
 
-  t["diamondsuitwhite"] = 0x2662;
 
-  t["dieresis"] = 0x00a8;
 
-  t["dieresisacute"] = 0xf6d7;
 
-  t["dieresisbelowcmb"] = 0x0324;
 
-  t["dieresiscmb"] = 0x0308;
 
-  t["dieresisgrave"] = 0xf6d8;
 
-  t["dieresistonos"] = 0x0385;
 
-  t["dihiragana"] = 0x3062;
 
-  t["dikatakana"] = 0x30c2;
 
-  t["dittomark"] = 0x3003;
 
-  t["divide"] = 0x00f7;
 
-  t["divides"] = 0x2223;
 
-  t["divisionslash"] = 0x2215;
 
-  t["djecyrillic"] = 0x0452;
 
-  t["dkshade"] = 0x2593;
 
-  t["dlinebelow"] = 0x1e0f;
 
-  t["dlsquare"] = 0x3397;
 
-  t["dmacron"] = 0x0111;
 
-  t["dmonospace"] = 0xff44;
 
-  t["dnblock"] = 0x2584;
 
-  t["dochadathai"] = 0x0e0e;
 
-  t["dodekthai"] = 0x0e14;
 
-  t["dohiragana"] = 0x3069;
 
-  t["dokatakana"] = 0x30c9;
 
-  t["dollar"] = 0x0024;
 
-  t["dollarinferior"] = 0xf6e3;
 
-  t["dollarmonospace"] = 0xff04;
 
-  t["dollaroldstyle"] = 0xf724;
 
-  t["dollarsmall"] = 0xfe69;
 
-  t["dollarsuperior"] = 0xf6e4;
 
-  t["dong"] = 0x20ab;
 
-  t["dorusquare"] = 0x3326;
 
-  t["dotaccent"] = 0x02d9;
 
-  t["dotaccentcmb"] = 0x0307;
 
-  t["dotbelowcmb"] = 0x0323;
 
-  t["dotbelowcomb"] = 0x0323;
 
-  t["dotkatakana"] = 0x30fb;
 
-  t["dotlessi"] = 0x0131;
 
-  t["dotlessj"] = 0xf6be;
 
-  t["dotlessjstrokehook"] = 0x0284;
 
-  t["dotmath"] = 0x22c5;
 
-  t["dottedcircle"] = 0x25cc;
 
-  t["doubleyodpatah"] = 0xfb1f;
 
-  t["doubleyodpatahhebrew"] = 0xfb1f;
 
-  t["downtackbelowcmb"] = 0x031e;
 
-  t["downtackmod"] = 0x02d5;
 
-  t["dparen"] = 0x249f;
 
-  t["dsuperior"] = 0xf6eb;
 
-  t["dtail"] = 0x0256;
 
-  t["dtopbar"] = 0x018c;
 
-  t["duhiragana"] = 0x3065;
 
-  t["dukatakana"] = 0x30c5;
 
-  t["dz"] = 0x01f3;
 
-  t["dzaltone"] = 0x02a3;
 
-  t["dzcaron"] = 0x01c6;
 
-  t["dzcurl"] = 0x02a5;
 
-  t["dzeabkhasiancyrillic"] = 0x04e1;
 
-  t["dzecyrillic"] = 0x0455;
 
-  t["dzhecyrillic"] = 0x045f;
 
-  t["e"] = 0x0065;
 
-  t["eacute"] = 0x00e9;
 
-  t["earth"] = 0x2641;
 
-  t["ebengali"] = 0x098f;
 
-  t["ebopomofo"] = 0x311c;
 
-  t["ebreve"] = 0x0115;
 
-  t["ecandradeva"] = 0x090d;
 
-  t["ecandragujarati"] = 0x0a8d;
 
-  t["ecandravowelsigndeva"] = 0x0945;
 
-  t["ecandravowelsigngujarati"] = 0x0ac5;
 
-  t["ecaron"] = 0x011b;
 
-  t["ecedillabreve"] = 0x1e1d;
 
-  t["echarmenian"] = 0x0565;
 
-  t["echyiwnarmenian"] = 0x0587;
 
-  t["ecircle"] = 0x24d4;
 
-  t["ecircumflex"] = 0x00ea;
 
-  t["ecircumflexacute"] = 0x1ebf;
 
-  t["ecircumflexbelow"] = 0x1e19;
 
-  t["ecircumflexdotbelow"] = 0x1ec7;
 
-  t["ecircumflexgrave"] = 0x1ec1;
 
-  t["ecircumflexhookabove"] = 0x1ec3;
 
-  t["ecircumflextilde"] = 0x1ec5;
 
-  t["ecyrillic"] = 0x0454;
 
-  t["edblgrave"] = 0x0205;
 
-  t["edeva"] = 0x090f;
 
-  t["edieresis"] = 0x00eb;
 
-  t["edot"] = 0x0117;
 
-  t["edotaccent"] = 0x0117;
 
-  t["edotbelow"] = 0x1eb9;
 
-  t["eegurmukhi"] = 0x0a0f;
 
-  t["eematragurmukhi"] = 0x0a47;
 
-  t["efcyrillic"] = 0x0444;
 
-  t["egrave"] = 0x00e8;
 
-  t["egujarati"] = 0x0a8f;
 
-  t["eharmenian"] = 0x0567;
 
-  t["ehbopomofo"] = 0x311d;
 
-  t["ehiragana"] = 0x3048;
 
-  t["ehookabove"] = 0x1ebb;
 
-  t["eibopomofo"] = 0x311f;
 
-  t["eight"] = 0x0038;
 
-  t["eightarabic"] = 0x0668;
 
-  t["eightbengali"] = 0x09ee;
 
-  t["eightcircle"] = 0x2467;
 
-  t["eightcircleinversesansserif"] = 0x2791;
 
-  t["eightdeva"] = 0x096e;
 
-  t["eighteencircle"] = 0x2471;
 
-  t["eighteenparen"] = 0x2485;
 
-  t["eighteenperiod"] = 0x2499;
 
-  t["eightgujarati"] = 0x0aee;
 
-  t["eightgurmukhi"] = 0x0a6e;
 
-  t["eighthackarabic"] = 0x0668;
 
-  t["eighthangzhou"] = 0x3028;
 
-  t["eighthnotebeamed"] = 0x266b;
 
-  t["eightideographicparen"] = 0x3227;
 
-  t["eightinferior"] = 0x2088;
 
-  t["eightmonospace"] = 0xff18;
 
-  t["eightoldstyle"] = 0xf738;
 
-  t["eightparen"] = 0x247b;
 
-  t["eightperiod"] = 0x248f;
 
-  t["eightpersian"] = 0x06f8;
 
-  t["eightroman"] = 0x2177;
 
-  t["eightsuperior"] = 0x2078;
 
-  t["eightthai"] = 0x0e58;
 
-  t["einvertedbreve"] = 0x0207;
 
-  t["eiotifiedcyrillic"] = 0x0465;
 
-  t["ekatakana"] = 0x30a8;
 
-  t["ekatakanahalfwidth"] = 0xff74;
 
-  t["ekonkargurmukhi"] = 0x0a74;
 
-  t["ekorean"] = 0x3154;
 
-  t["elcyrillic"] = 0x043b;
 
-  t["element"] = 0x2208;
 
-  t["elevencircle"] = 0x246a;
 
-  t["elevenparen"] = 0x247e;
 
-  t["elevenperiod"] = 0x2492;
 
-  t["elevenroman"] = 0x217a;
 
-  t["ellipsis"] = 0x2026;
 
-  t["ellipsisvertical"] = 0x22ee;
 
-  t["emacron"] = 0x0113;
 
-  t["emacronacute"] = 0x1e17;
 
-  t["emacrongrave"] = 0x1e15;
 
-  t["emcyrillic"] = 0x043c;
 
-  t["emdash"] = 0x2014;
 
-  t["emdashvertical"] = 0xfe31;
 
-  t["emonospace"] = 0xff45;
 
-  t["emphasismarkarmenian"] = 0x055b;
 
-  t["emptyset"] = 0x2205;
 
-  t["enbopomofo"] = 0x3123;
 
-  t["encyrillic"] = 0x043d;
 
-  t["endash"] = 0x2013;
 
-  t["endashvertical"] = 0xfe32;
 
-  t["endescendercyrillic"] = 0x04a3;
 
-  t["eng"] = 0x014b;
 
-  t["engbopomofo"] = 0x3125;
 
-  t["enghecyrillic"] = 0x04a5;
 
-  t["enhookcyrillic"] = 0x04c8;
 
-  t["enspace"] = 0x2002;
 
-  t["eogonek"] = 0x0119;
 
-  t["eokorean"] = 0x3153;
 
-  t["eopen"] = 0x025b;
 
-  t["eopenclosed"] = 0x029a;
 
-  t["eopenreversed"] = 0x025c;
 
-  t["eopenreversedclosed"] = 0x025e;
 
-  t["eopenreversedhook"] = 0x025d;
 
-  t["eparen"] = 0x24a0;
 
-  t["epsilon"] = 0x03b5;
 
-  t["epsilontonos"] = 0x03ad;
 
-  t["equal"] = 0x003d;
 
-  t["equalmonospace"] = 0xff1d;
 
-  t["equalsmall"] = 0xfe66;
 
-  t["equalsuperior"] = 0x207c;
 
-  t["equivalence"] = 0x2261;
 
-  t["erbopomofo"] = 0x3126;
 
-  t["ercyrillic"] = 0x0440;
 
-  t["ereversed"] = 0x0258;
 
-  t["ereversedcyrillic"] = 0x044d;
 
-  t["escyrillic"] = 0x0441;
 
-  t["esdescendercyrillic"] = 0x04ab;
 
-  t["esh"] = 0x0283;
 
-  t["eshcurl"] = 0x0286;
 
-  t["eshortdeva"] = 0x090e;
 
-  t["eshortvowelsigndeva"] = 0x0946;
 
-  t["eshreversedloop"] = 0x01aa;
 
-  t["eshsquatreversed"] = 0x0285;
 
-  t["esmallhiragana"] = 0x3047;
 
-  t["esmallkatakana"] = 0x30a7;
 
-  t["esmallkatakanahalfwidth"] = 0xff6a;
 
-  t["estimated"] = 0x212e;
 
-  t["esuperior"] = 0xf6ec;
 
-  t["eta"] = 0x03b7;
 
-  t["etarmenian"] = 0x0568;
 
-  t["etatonos"] = 0x03ae;
 
-  t["eth"] = 0x00f0;
 
-  t["etilde"] = 0x1ebd;
 
-  t["etildebelow"] = 0x1e1b;
 
-  t["etnahtafoukhhebrew"] = 0x0591;
 
-  t["etnahtafoukhlefthebrew"] = 0x0591;
 
-  t["etnahtahebrew"] = 0x0591;
 
-  t["etnahtalefthebrew"] = 0x0591;
 
-  t["eturned"] = 0x01dd;
 
-  t["eukorean"] = 0x3161;
 
-  t["euro"] = 0x20ac;
 
-  t["evowelsignbengali"] = 0x09c7;
 
-  t["evowelsigndeva"] = 0x0947;
 
-  t["evowelsigngujarati"] = 0x0ac7;
 
-  t["exclam"] = 0x0021;
 
-  t["exclamarmenian"] = 0x055c;
 
-  t["exclamdbl"] = 0x203c;
 
-  t["exclamdown"] = 0x00a1;
 
-  t["exclamdownsmall"] = 0xf7a1;
 
-  t["exclammonospace"] = 0xff01;
 
-  t["exclamsmall"] = 0xf721;
 
-  t["existential"] = 0x2203;
 
-  t["ezh"] = 0x0292;
 
-  t["ezhcaron"] = 0x01ef;
 
-  t["ezhcurl"] = 0x0293;
 
-  t["ezhreversed"] = 0x01b9;
 
-  t["ezhtail"] = 0x01ba;
 
-  t["f"] = 0x0066;
 
-  t["fadeva"] = 0x095e;
 
-  t["fagurmukhi"] = 0x0a5e;
 
-  t["fahrenheit"] = 0x2109;
 
-  t["fathaarabic"] = 0x064e;
 
-  t["fathalowarabic"] = 0x064e;
 
-  t["fathatanarabic"] = 0x064b;
 
-  t["fbopomofo"] = 0x3108;
 
-  t["fcircle"] = 0x24d5;
 
-  t["fdotaccent"] = 0x1e1f;
 
-  t["feharabic"] = 0x0641;
 
-  t["feharmenian"] = 0x0586;
 
-  t["fehfinalarabic"] = 0xfed2;
 
-  t["fehinitialarabic"] = 0xfed3;
 
-  t["fehmedialarabic"] = 0xfed4;
 
-  t["feicoptic"] = 0x03e5;
 
-  t["female"] = 0x2640;
 
-  t["ff"] = 0xfb00;
 
-  t["f_f"] = 0xfb00;
 
-  t["ffi"] = 0xfb03;
 
-  t["ffl"] = 0xfb04;
 
-  t["fi"] = 0xfb01;
 
-  t["fifteencircle"] = 0x246e;
 
-  t["fifteenparen"] = 0x2482;
 
-  t["fifteenperiod"] = 0x2496;
 
-  t["figuredash"] = 0x2012;
 
-  t["filledbox"] = 0x25a0;
 
-  t["filledrect"] = 0x25ac;
 
-  t["finalkaf"] = 0x05da;
 
-  t["finalkafdagesh"] = 0xfb3a;
 
-  t["finalkafdageshhebrew"] = 0xfb3a;
 
-  t["finalkafhebrew"] = 0x05da;
 
-  t["finalmem"] = 0x05dd;
 
-  t["finalmemhebrew"] = 0x05dd;
 
-  t["finalnun"] = 0x05df;
 
-  t["finalnunhebrew"] = 0x05df;
 
-  t["finalpe"] = 0x05e3;
 
-  t["finalpehebrew"] = 0x05e3;
 
-  t["finaltsadi"] = 0x05e5;
 
-  t["finaltsadihebrew"] = 0x05e5;
 
-  t["firsttonechinese"] = 0x02c9;
 
-  t["fisheye"] = 0x25c9;
 
-  t["fitacyrillic"] = 0x0473;
 
-  t["five"] = 0x0035;
 
-  t["fivearabic"] = 0x0665;
 
-  t["fivebengali"] = 0x09eb;
 
-  t["fivecircle"] = 0x2464;
 
-  t["fivecircleinversesansserif"] = 0x278e;
 
-  t["fivedeva"] = 0x096b;
 
-  t["fiveeighths"] = 0x215d;
 
-  t["fivegujarati"] = 0x0aeb;
 
-  t["fivegurmukhi"] = 0x0a6b;
 
-  t["fivehackarabic"] = 0x0665;
 
-  t["fivehangzhou"] = 0x3025;
 
-  t["fiveideographicparen"] = 0x3224;
 
-  t["fiveinferior"] = 0x2085;
 
-  t["fivemonospace"] = 0xff15;
 
-  t["fiveoldstyle"] = 0xf735;
 
-  t["fiveparen"] = 0x2478;
 
-  t["fiveperiod"] = 0x248c;
 
-  t["fivepersian"] = 0x06f5;
 
-  t["fiveroman"] = 0x2174;
 
-  t["fivesuperior"] = 0x2075;
 
-  t["fivethai"] = 0x0e55;
 
-  t["fl"] = 0xfb02;
 
-  t["florin"] = 0x0192;
 
-  t["fmonospace"] = 0xff46;
 
-  t["fmsquare"] = 0x3399;
 
-  t["fofanthai"] = 0x0e1f;
 
-  t["fofathai"] = 0x0e1d;
 
-  t["fongmanthai"] = 0x0e4f;
 
-  t["forall"] = 0x2200;
 
-  t["four"] = 0x0034;
 
-  t["fourarabic"] = 0x0664;
 
-  t["fourbengali"] = 0x09ea;
 
-  t["fourcircle"] = 0x2463;
 
-  t["fourcircleinversesansserif"] = 0x278d;
 
-  t["fourdeva"] = 0x096a;
 
-  t["fourgujarati"] = 0x0aea;
 
-  t["fourgurmukhi"] = 0x0a6a;
 
-  t["fourhackarabic"] = 0x0664;
 
-  t["fourhangzhou"] = 0x3024;
 
-  t["fourideographicparen"] = 0x3223;
 
-  t["fourinferior"] = 0x2084;
 
-  t["fourmonospace"] = 0xff14;
 
-  t["fournumeratorbengali"] = 0x09f7;
 
-  t["fouroldstyle"] = 0xf734;
 
-  t["fourparen"] = 0x2477;
 
-  t["fourperiod"] = 0x248b;
 
-  t["fourpersian"] = 0x06f4;
 
-  t["fourroman"] = 0x2173;
 
-  t["foursuperior"] = 0x2074;
 
-  t["fourteencircle"] = 0x246d;
 
-  t["fourteenparen"] = 0x2481;
 
-  t["fourteenperiod"] = 0x2495;
 
-  t["fourthai"] = 0x0e54;
 
-  t["fourthtonechinese"] = 0x02cb;
 
-  t["fparen"] = 0x24a1;
 
-  t["fraction"] = 0x2044;
 
-  t["franc"] = 0x20a3;
 
-  t["g"] = 0x0067;
 
-  t["gabengali"] = 0x0997;
 
-  t["gacute"] = 0x01f5;
 
-  t["gadeva"] = 0x0917;
 
-  t["gafarabic"] = 0x06af;
 
-  t["gaffinalarabic"] = 0xfb93;
 
-  t["gafinitialarabic"] = 0xfb94;
 
-  t["gafmedialarabic"] = 0xfb95;
 
-  t["gagujarati"] = 0x0a97;
 
-  t["gagurmukhi"] = 0x0a17;
 
-  t["gahiragana"] = 0x304c;
 
-  t["gakatakana"] = 0x30ac;
 
-  t["gamma"] = 0x03b3;
 
-  t["gammalatinsmall"] = 0x0263;
 
-  t["gammasuperior"] = 0x02e0;
 
-  t["gangiacoptic"] = 0x03eb;
 
-  t["gbopomofo"] = 0x310d;
 
-  t["gbreve"] = 0x011f;
 
-  t["gcaron"] = 0x01e7;
 
-  t["gcedilla"] = 0x0123;
 
-  t["gcircle"] = 0x24d6;
 
-  t["gcircumflex"] = 0x011d;
 
-  t["gcommaaccent"] = 0x0123;
 
-  t["gdot"] = 0x0121;
 
-  t["gdotaccent"] = 0x0121;
 
-  t["gecyrillic"] = 0x0433;
 
-  t["gehiragana"] = 0x3052;
 
-  t["gekatakana"] = 0x30b2;
 
-  t["geometricallyequal"] = 0x2251;
 
-  t["gereshaccenthebrew"] = 0x059c;
 
-  t["gereshhebrew"] = 0x05f3;
 
-  t["gereshmuqdamhebrew"] = 0x059d;
 
-  t["germandbls"] = 0x00df;
 
-  t["gershayimaccenthebrew"] = 0x059e;
 
-  t["gershayimhebrew"] = 0x05f4;
 
-  t["getamark"] = 0x3013;
 
-  t["ghabengali"] = 0x0998;
 
-  t["ghadarmenian"] = 0x0572;
 
-  t["ghadeva"] = 0x0918;
 
-  t["ghagujarati"] = 0x0a98;
 
-  t["ghagurmukhi"] = 0x0a18;
 
-  t["ghainarabic"] = 0x063a;
 
-  t["ghainfinalarabic"] = 0xfece;
 
-  t["ghaininitialarabic"] = 0xfecf;
 
-  t["ghainmedialarabic"] = 0xfed0;
 
-  t["ghemiddlehookcyrillic"] = 0x0495;
 
-  t["ghestrokecyrillic"] = 0x0493;
 
-  t["gheupturncyrillic"] = 0x0491;
 
-  t["ghhadeva"] = 0x095a;
 
-  t["ghhagurmukhi"] = 0x0a5a;
 
-  t["ghook"] = 0x0260;
 
-  t["ghzsquare"] = 0x3393;
 
-  t["gihiragana"] = 0x304e;
 
-  t["gikatakana"] = 0x30ae;
 
-  t["gimarmenian"] = 0x0563;
 
-  t["gimel"] = 0x05d2;
 
-  t["gimeldagesh"] = 0xfb32;
 
-  t["gimeldageshhebrew"] = 0xfb32;
 
-  t["gimelhebrew"] = 0x05d2;
 
-  t["gjecyrillic"] = 0x0453;
 
-  t["glottalinvertedstroke"] = 0x01be;
 
-  t["glottalstop"] = 0x0294;
 
-  t["glottalstopinverted"] = 0x0296;
 
-  t["glottalstopmod"] = 0x02c0;
 
-  t["glottalstopreversed"] = 0x0295;
 
-  t["glottalstopreversedmod"] = 0x02c1;
 
-  t["glottalstopreversedsuperior"] = 0x02e4;
 
-  t["glottalstopstroke"] = 0x02a1;
 
-  t["glottalstopstrokereversed"] = 0x02a2;
 
-  t["gmacron"] = 0x1e21;
 
-  t["gmonospace"] = 0xff47;
 
-  t["gohiragana"] = 0x3054;
 
-  t["gokatakana"] = 0x30b4;
 
-  t["gparen"] = 0x24a2;
 
-  t["gpasquare"] = 0x33ac;
 
-  t["gradient"] = 0x2207;
 
-  t["grave"] = 0x0060;
 
-  t["gravebelowcmb"] = 0x0316;
 
-  t["gravecmb"] = 0x0300;
 
-  t["gravecomb"] = 0x0300;
 
-  t["gravedeva"] = 0x0953;
 
-  t["gravelowmod"] = 0x02ce;
 
-  t["gravemonospace"] = 0xff40;
 
-  t["gravetonecmb"] = 0x0340;
 
-  t["greater"] = 0x003e;
 
-  t["greaterequal"] = 0x2265;
 
-  t["greaterequalorless"] = 0x22db;
 
-  t["greatermonospace"] = 0xff1e;
 
-  t["greaterorequivalent"] = 0x2273;
 
-  t["greaterorless"] = 0x2277;
 
-  t["greateroverequal"] = 0x2267;
 
-  t["greatersmall"] = 0xfe65;
 
-  t["gscript"] = 0x0261;
 
-  t["gstroke"] = 0x01e5;
 
-  t["guhiragana"] = 0x3050;
 
-  t["guillemotleft"] = 0x00ab;
 
-  t["guillemotright"] = 0x00bb;
 
-  t["guilsinglleft"] = 0x2039;
 
-  t["guilsinglright"] = 0x203a;
 
-  t["gukatakana"] = 0x30b0;
 
-  t["guramusquare"] = 0x3318;
 
-  t["gysquare"] = 0x33c9;
 
-  t["h"] = 0x0068;
 
-  t["haabkhasiancyrillic"] = 0x04a9;
 
-  t["haaltonearabic"] = 0x06c1;
 
-  t["habengali"] = 0x09b9;
 
-  t["hadescendercyrillic"] = 0x04b3;
 
-  t["hadeva"] = 0x0939;
 
-  t["hagujarati"] = 0x0ab9;
 
-  t["hagurmukhi"] = 0x0a39;
 
-  t["haharabic"] = 0x062d;
 
-  t["hahfinalarabic"] = 0xfea2;
 
-  t["hahinitialarabic"] = 0xfea3;
 
-  t["hahiragana"] = 0x306f;
 
-  t["hahmedialarabic"] = 0xfea4;
 
-  t["haitusquare"] = 0x332a;
 
-  t["hakatakana"] = 0x30cf;
 
-  t["hakatakanahalfwidth"] = 0xff8a;
 
-  t["halantgurmukhi"] = 0x0a4d;
 
-  t["hamzaarabic"] = 0x0621;
 
-  t["hamzalowarabic"] = 0x0621;
 
-  t["hangulfiller"] = 0x3164;
 
-  t["hardsigncyrillic"] = 0x044a;
 
-  t["harpoonleftbarbup"] = 0x21bc;
 
-  t["harpoonrightbarbup"] = 0x21c0;
 
-  t["hasquare"] = 0x33ca;
 
-  t["hatafpatah"] = 0x05b2;
 
-  t["hatafpatah16"] = 0x05b2;
 
-  t["hatafpatah23"] = 0x05b2;
 
-  t["hatafpatah2f"] = 0x05b2;
 
-  t["hatafpatahhebrew"] = 0x05b2;
 
-  t["hatafpatahnarrowhebrew"] = 0x05b2;
 
-  t["hatafpatahquarterhebrew"] = 0x05b2;
 
-  t["hatafpatahwidehebrew"] = 0x05b2;
 
-  t["hatafqamats"] = 0x05b3;
 
-  t["hatafqamats1b"] = 0x05b3;
 
-  t["hatafqamats28"] = 0x05b3;
 
-  t["hatafqamats34"] = 0x05b3;
 
-  t["hatafqamatshebrew"] = 0x05b3;
 
-  t["hatafqamatsnarrowhebrew"] = 0x05b3;
 
-  t["hatafqamatsquarterhebrew"] = 0x05b3;
 
-  t["hatafqamatswidehebrew"] = 0x05b3;
 
-  t["hatafsegol"] = 0x05b1;
 
-  t["hatafsegol17"] = 0x05b1;
 
-  t["hatafsegol24"] = 0x05b1;
 
-  t["hatafsegol30"] = 0x05b1;
 
-  t["hatafsegolhebrew"] = 0x05b1;
 
-  t["hatafsegolnarrowhebrew"] = 0x05b1;
 
-  t["hatafsegolquarterhebrew"] = 0x05b1;
 
-  t["hatafsegolwidehebrew"] = 0x05b1;
 
-  t["hbar"] = 0x0127;
 
-  t["hbopomofo"] = 0x310f;
 
-  t["hbrevebelow"] = 0x1e2b;
 
-  t["hcedilla"] = 0x1e29;
 
-  t["hcircle"] = 0x24d7;
 
-  t["hcircumflex"] = 0x0125;
 
-  t["hdieresis"] = 0x1e27;
 
-  t["hdotaccent"] = 0x1e23;
 
-  t["hdotbelow"] = 0x1e25;
 
-  t["he"] = 0x05d4;
 
-  t["heart"] = 0x2665;
 
-  t["heartsuitblack"] = 0x2665;
 
-  t["heartsuitwhite"] = 0x2661;
 
-  t["hedagesh"] = 0xfb34;
 
-  t["hedageshhebrew"] = 0xfb34;
 
-  t["hehaltonearabic"] = 0x06c1;
 
-  t["heharabic"] = 0x0647;
 
-  t["hehebrew"] = 0x05d4;
 
-  t["hehfinalaltonearabic"] = 0xfba7;
 
-  t["hehfinalalttwoarabic"] = 0xfeea;
 
-  t["hehfinalarabic"] = 0xfeea;
 
-  t["hehhamzaabovefinalarabic"] = 0xfba5;
 
-  t["hehhamzaaboveisolatedarabic"] = 0xfba4;
 
-  t["hehinitialaltonearabic"] = 0xfba8;
 
-  t["hehinitialarabic"] = 0xfeeb;
 
-  t["hehiragana"] = 0x3078;
 
-  t["hehmedialaltonearabic"] = 0xfba9;
 
-  t["hehmedialarabic"] = 0xfeec;
 
-  t["heiseierasquare"] = 0x337b;
 
-  t["hekatakana"] = 0x30d8;
 
-  t["hekatakanahalfwidth"] = 0xff8d;
 
-  t["hekutaarusquare"] = 0x3336;
 
-  t["henghook"] = 0x0267;
 
-  t["herutusquare"] = 0x3339;
 
-  t["het"] = 0x05d7;
 
-  t["hethebrew"] = 0x05d7;
 
-  t["hhook"] = 0x0266;
 
-  t["hhooksuperior"] = 0x02b1;
 
-  t["hieuhacirclekorean"] = 0x327b;
 
-  t["hieuhaparenkorean"] = 0x321b;
 
-  t["hieuhcirclekorean"] = 0x326d;
 
-  t["hieuhkorean"] = 0x314e;
 
-  t["hieuhparenkorean"] = 0x320d;
 
-  t["hihiragana"] = 0x3072;
 
-  t["hikatakana"] = 0x30d2;
 
-  t["hikatakanahalfwidth"] = 0xff8b;
 
-  t["hiriq"] = 0x05b4;
 
-  t["hiriq14"] = 0x05b4;
 
-  t["hiriq21"] = 0x05b4;
 
-  t["hiriq2d"] = 0x05b4;
 
-  t["hiriqhebrew"] = 0x05b4;
 
-  t["hiriqnarrowhebrew"] = 0x05b4;
 
-  t["hiriqquarterhebrew"] = 0x05b4;
 
-  t["hiriqwidehebrew"] = 0x05b4;
 
-  t["hlinebelow"] = 0x1e96;
 
-  t["hmonospace"] = 0xff48;
 
-  t["hoarmenian"] = 0x0570;
 
-  t["hohipthai"] = 0x0e2b;
 
-  t["hohiragana"] = 0x307b;
 
-  t["hokatakana"] = 0x30db;
 
-  t["hokatakanahalfwidth"] = 0xff8e;
 
-  t["holam"] = 0x05b9;
 
-  t["holam19"] = 0x05b9;
 
-  t["holam26"] = 0x05b9;
 
-  t["holam32"] = 0x05b9;
 
-  t["holamhebrew"] = 0x05b9;
 
-  t["holamnarrowhebrew"] = 0x05b9;
 
-  t["holamquarterhebrew"] = 0x05b9;
 
-  t["holamwidehebrew"] = 0x05b9;
 
-  t["honokhukthai"] = 0x0e2e;
 
-  t["hookabovecomb"] = 0x0309;
 
-  t["hookcmb"] = 0x0309;
 
-  t["hookpalatalizedbelowcmb"] = 0x0321;
 
-  t["hookretroflexbelowcmb"] = 0x0322;
 
-  t["hoonsquare"] = 0x3342;
 
-  t["horicoptic"] = 0x03e9;
 
-  t["horizontalbar"] = 0x2015;
 
-  t["horncmb"] = 0x031b;
 
-  t["hotsprings"] = 0x2668;
 
-  t["house"] = 0x2302;
 
-  t["hparen"] = 0x24a3;
 
-  t["hsuperior"] = 0x02b0;
 
-  t["hturned"] = 0x0265;
 
-  t["huhiragana"] = 0x3075;
 
-  t["huiitosquare"] = 0x3333;
 
-  t["hukatakana"] = 0x30d5;
 
-  t["hukatakanahalfwidth"] = 0xff8c;
 
-  t["hungarumlaut"] = 0x02dd;
 
-  t["hungarumlautcmb"] = 0x030b;
 
-  t["hv"] = 0x0195;
 
-  t["hyphen"] = 0x002d;
 
-  t["hypheninferior"] = 0xf6e5;
 
-  t["hyphenmonospace"] = 0xff0d;
 
-  t["hyphensmall"] = 0xfe63;
 
-  t["hyphensuperior"] = 0xf6e6;
 
-  t["hyphentwo"] = 0x2010;
 
-  t["i"] = 0x0069;
 
-  t["iacute"] = 0x00ed;
 
-  t["iacyrillic"] = 0x044f;
 
-  t["ibengali"] = 0x0987;
 
-  t["ibopomofo"] = 0x3127;
 
-  t["ibreve"] = 0x012d;
 
-  t["icaron"] = 0x01d0;
 
-  t["icircle"] = 0x24d8;
 
-  t["icircumflex"] = 0x00ee;
 
-  t["icyrillic"] = 0x0456;
 
-  t["idblgrave"] = 0x0209;
 
-  t["ideographearthcircle"] = 0x328f;
 
-  t["ideographfirecircle"] = 0x328b;
 
-  t["ideographicallianceparen"] = 0x323f;
 
-  t["ideographiccallparen"] = 0x323a;
 
-  t["ideographiccentrecircle"] = 0x32a5;
 
-  t["ideographicclose"] = 0x3006;
 
-  t["ideographiccomma"] = 0x3001;
 
-  t["ideographiccommaleft"] = 0xff64;
 
-  t["ideographiccongratulationparen"] = 0x3237;
 
-  t["ideographiccorrectcircle"] = 0x32a3;
 
-  t["ideographicearthparen"] = 0x322f;
 
-  t["ideographicenterpriseparen"] = 0x323d;
 
-  t["ideographicexcellentcircle"] = 0x329d;
 
-  t["ideographicfestivalparen"] = 0x3240;
 
-  t["ideographicfinancialcircle"] = 0x3296;
 
-  t["ideographicfinancialparen"] = 0x3236;
 
-  t["ideographicfireparen"] = 0x322b;
 
-  t["ideographichaveparen"] = 0x3232;
 
-  t["ideographichighcircle"] = 0x32a4;
 
-  t["ideographiciterationmark"] = 0x3005;
 
-  t["ideographiclaborcircle"] = 0x3298;
 
-  t["ideographiclaborparen"] = 0x3238;
 
-  t["ideographicleftcircle"] = 0x32a7;
 
-  t["ideographiclowcircle"] = 0x32a6;
 
-  t["ideographicmedicinecircle"] = 0x32a9;
 
-  t["ideographicmetalparen"] = 0x322e;
 
-  t["ideographicmoonparen"] = 0x322a;
 
-  t["ideographicnameparen"] = 0x3234;
 
-  t["ideographicperiod"] = 0x3002;
 
-  t["ideographicprintcircle"] = 0x329e;
 
-  t["ideographicreachparen"] = 0x3243;
 
-  t["ideographicrepresentparen"] = 0x3239;
 
-  t["ideographicresourceparen"] = 0x323e;
 
-  t["ideographicrightcircle"] = 0x32a8;
 
-  t["ideographicsecretcircle"] = 0x3299;
 
-  t["ideographicselfparen"] = 0x3242;
 
-  t["ideographicsocietyparen"] = 0x3233;
 
-  t["ideographicspace"] = 0x3000;
 
-  t["ideographicspecialparen"] = 0x3235;
 
-  t["ideographicstockparen"] = 0x3231;
 
-  t["ideographicstudyparen"] = 0x323b;
 
-  t["ideographicsunparen"] = 0x3230;
 
-  t["ideographicsuperviseparen"] = 0x323c;
 
-  t["ideographicwaterparen"] = 0x322c;
 
-  t["ideographicwoodparen"] = 0x322d;
 
-  t["ideographiczero"] = 0x3007;
 
-  t["ideographmetalcircle"] = 0x328e;
 
-  t["ideographmooncircle"] = 0x328a;
 
-  t["ideographnamecircle"] = 0x3294;
 
-  t["ideographsuncircle"] = 0x3290;
 
-  t["ideographwatercircle"] = 0x328c;
 
-  t["ideographwoodcircle"] = 0x328d;
 
-  t["ideva"] = 0x0907;
 
-  t["idieresis"] = 0x00ef;
 
-  t["idieresisacute"] = 0x1e2f;
 
-  t["idieresiscyrillic"] = 0x04e5;
 
-  t["idotbelow"] = 0x1ecb;
 
-  t["iebrevecyrillic"] = 0x04d7;
 
-  t["iecyrillic"] = 0x0435;
 
-  t["ieungacirclekorean"] = 0x3275;
 
-  t["ieungaparenkorean"] = 0x3215;
 
-  t["ieungcirclekorean"] = 0x3267;
 
-  t["ieungkorean"] = 0x3147;
 
-  t["ieungparenkorean"] = 0x3207;
 
-  t["igrave"] = 0x00ec;
 
-  t["igujarati"] = 0x0a87;
 
-  t["igurmukhi"] = 0x0a07;
 
-  t["ihiragana"] = 0x3044;
 
-  t["ihookabove"] = 0x1ec9;
 
-  t["iibengali"] = 0x0988;
 
-  t["iicyrillic"] = 0x0438;
 
-  t["iideva"] = 0x0908;
 
-  t["iigujarati"] = 0x0a88;
 
-  t["iigurmukhi"] = 0x0a08;
 
-  t["iimatragurmukhi"] = 0x0a40;
 
-  t["iinvertedbreve"] = 0x020b;
 
-  t["iishortcyrillic"] = 0x0439;
 
-  t["iivowelsignbengali"] = 0x09c0;
 
-  t["iivowelsigndeva"] = 0x0940;
 
-  t["iivowelsigngujarati"] = 0x0ac0;
 
-  t["ij"] = 0x0133;
 
-  t["ikatakana"] = 0x30a4;
 
-  t["ikatakanahalfwidth"] = 0xff72;
 
-  t["ikorean"] = 0x3163;
 
-  t["ilde"] = 0x02dc;
 
-  t["iluyhebrew"] = 0x05ac;
 
-  t["imacron"] = 0x012b;
 
-  t["imacroncyrillic"] = 0x04e3;
 
-  t["imageorapproximatelyequal"] = 0x2253;
 
-  t["imatragurmukhi"] = 0x0a3f;
 
-  t["imonospace"] = 0xff49;
 
-  t["increment"] = 0x2206;
 
-  t["infinity"] = 0x221e;
 
-  t["iniarmenian"] = 0x056b;
 
-  t["integral"] = 0x222b;
 
-  t["integralbottom"] = 0x2321;
 
-  t["integralbt"] = 0x2321;
 
-  t["integralex"] = 0xf8f5;
 
-  t["integraltop"] = 0x2320;
 
-  t["integraltp"] = 0x2320;
 
-  t["intersection"] = 0x2229;
 
-  t["intisquare"] = 0x3305;
 
-  t["invbullet"] = 0x25d8;
 
-  t["invcircle"] = 0x25d9;
 
-  t["invsmileface"] = 0x263b;
 
-  t["iocyrillic"] = 0x0451;
 
-  t["iogonek"] = 0x012f;
 
-  t["iota"] = 0x03b9;
 
-  t["iotadieresis"] = 0x03ca;
 
-  t["iotadieresistonos"] = 0x0390;
 
-  t["iotalatin"] = 0x0269;
 
-  t["iotatonos"] = 0x03af;
 
-  t["iparen"] = 0x24a4;
 
-  t["irigurmukhi"] = 0x0a72;
 
-  t["ismallhiragana"] = 0x3043;
 
-  t["ismallkatakana"] = 0x30a3;
 
-  t["ismallkatakanahalfwidth"] = 0xff68;
 
-  t["issharbengali"] = 0x09fa;
 
-  t["istroke"] = 0x0268;
 
-  t["isuperior"] = 0xf6ed;
 
-  t["iterationhiragana"] = 0x309d;
 
-  t["iterationkatakana"] = 0x30fd;
 
-  t["itilde"] = 0x0129;
 
-  t["itildebelow"] = 0x1e2d;
 
-  t["iubopomofo"] = 0x3129;
 
-  t["iucyrillic"] = 0x044e;
 
-  t["ivowelsignbengali"] = 0x09bf;
 
-  t["ivowelsigndeva"] = 0x093f;
 
-  t["ivowelsigngujarati"] = 0x0abf;
 
-  t["izhitsacyrillic"] = 0x0475;
 
-  t["izhitsadblgravecyrillic"] = 0x0477;
 
-  t["j"] = 0x006a;
 
-  t["jaarmenian"] = 0x0571;
 
-  t["jabengali"] = 0x099c;
 
-  t["jadeva"] = 0x091c;
 
-  t["jagujarati"] = 0x0a9c;
 
-  t["jagurmukhi"] = 0x0a1c;
 
-  t["jbopomofo"] = 0x3110;
 
-  t["jcaron"] = 0x01f0;
 
-  t["jcircle"] = 0x24d9;
 
-  t["jcircumflex"] = 0x0135;
 
-  t["jcrossedtail"] = 0x029d;
 
-  t["jdotlessstroke"] = 0x025f;
 
-  t["jecyrillic"] = 0x0458;
 
-  t["jeemarabic"] = 0x062c;
 
-  t["jeemfinalarabic"] = 0xfe9e;
 
-  t["jeeminitialarabic"] = 0xfe9f;
 
-  t["jeemmedialarabic"] = 0xfea0;
 
-  t["jeharabic"] = 0x0698;
 
-  t["jehfinalarabic"] = 0xfb8b;
 
-  t["jhabengali"] = 0x099d;
 
-  t["jhadeva"] = 0x091d;
 
-  t["jhagujarati"] = 0x0a9d;
 
-  t["jhagurmukhi"] = 0x0a1d;
 
-  t["jheharmenian"] = 0x057b;
 
-  t["jis"] = 0x3004;
 
-  t["jmonospace"] = 0xff4a;
 
-  t["jparen"] = 0x24a5;
 
-  t["jsuperior"] = 0x02b2;
 
-  t["k"] = 0x006b;
 
-  t["kabashkircyrillic"] = 0x04a1;
 
-  t["kabengali"] = 0x0995;
 
-  t["kacute"] = 0x1e31;
 
-  t["kacyrillic"] = 0x043a;
 
-  t["kadescendercyrillic"] = 0x049b;
 
-  t["kadeva"] = 0x0915;
 
-  t["kaf"] = 0x05db;
 
-  t["kafarabic"] = 0x0643;
 
-  t["kafdagesh"] = 0xfb3b;
 
-  t["kafdageshhebrew"] = 0xfb3b;
 
-  t["kaffinalarabic"] = 0xfeda;
 
-  t["kafhebrew"] = 0x05db;
 
-  t["kafinitialarabic"] = 0xfedb;
 
-  t["kafmedialarabic"] = 0xfedc;
 
-  t["kafrafehebrew"] = 0xfb4d;
 
-  t["kagujarati"] = 0x0a95;
 
-  t["kagurmukhi"] = 0x0a15;
 
-  t["kahiragana"] = 0x304b;
 
-  t["kahookcyrillic"] = 0x04c4;
 
-  t["kakatakana"] = 0x30ab;
 
-  t["kakatakanahalfwidth"] = 0xff76;
 
-  t["kappa"] = 0x03ba;
 
-  t["kappasymbolgreek"] = 0x03f0;
 
-  t["kapyeounmieumkorean"] = 0x3171;
 
-  t["kapyeounphieuphkorean"] = 0x3184;
 
-  t["kapyeounpieupkorean"] = 0x3178;
 
-  t["kapyeounssangpieupkorean"] = 0x3179;
 
-  t["karoriisquare"] = 0x330d;
 
-  t["kashidaautoarabic"] = 0x0640;
 
-  t["kashidaautonosidebearingarabic"] = 0x0640;
 
-  t["kasmallkatakana"] = 0x30f5;
 
-  t["kasquare"] = 0x3384;
 
-  t["kasraarabic"] = 0x0650;
 
-  t["kasratanarabic"] = 0x064d;
 
-  t["kastrokecyrillic"] = 0x049f;
 
-  t["katahiraprolongmarkhalfwidth"] = 0xff70;
 
-  t["kaverticalstrokecyrillic"] = 0x049d;
 
-  t["kbopomofo"] = 0x310e;
 
-  t["kcalsquare"] = 0x3389;
 
-  t["kcaron"] = 0x01e9;
 
-  t["kcedilla"] = 0x0137;
 
-  t["kcircle"] = 0x24da;
 
-  t["kcommaaccent"] = 0x0137;
 
-  t["kdotbelow"] = 0x1e33;
 
-  t["keharmenian"] = 0x0584;
 
-  t["kehiragana"] = 0x3051;
 
-  t["kekatakana"] = 0x30b1;
 
-  t["kekatakanahalfwidth"] = 0xff79;
 
-  t["kenarmenian"] = 0x056f;
 
-  t["kesmallkatakana"] = 0x30f6;
 
-  t["kgreenlandic"] = 0x0138;
 
-  t["khabengali"] = 0x0996;
 
-  t["khacyrillic"] = 0x0445;
 
-  t["khadeva"] = 0x0916;
 
-  t["khagujarati"] = 0x0a96;
 
-  t["khagurmukhi"] = 0x0a16;
 
-  t["khaharabic"] = 0x062e;
 
-  t["khahfinalarabic"] = 0xfea6;
 
-  t["khahinitialarabic"] = 0xfea7;
 
-  t["khahmedialarabic"] = 0xfea8;
 
-  t["kheicoptic"] = 0x03e7;
 
-  t["khhadeva"] = 0x0959;
 
-  t["khhagurmukhi"] = 0x0a59;
 
-  t["khieukhacirclekorean"] = 0x3278;
 
-  t["khieukhaparenkorean"] = 0x3218;
 
-  t["khieukhcirclekorean"] = 0x326a;
 
-  t["khieukhkorean"] = 0x314b;
 
-  t["khieukhparenkorean"] = 0x320a;
 
-  t["khokhaithai"] = 0x0e02;
 
-  t["khokhonthai"] = 0x0e05;
 
-  t["khokhuatthai"] = 0x0e03;
 
-  t["khokhwaithai"] = 0x0e04;
 
-  t["khomutthai"] = 0x0e5b;
 
-  t["khook"] = 0x0199;
 
-  t["khorakhangthai"] = 0x0e06;
 
-  t["khzsquare"] = 0x3391;
 
-  t["kihiragana"] = 0x304d;
 
-  t["kikatakana"] = 0x30ad;
 
-  t["kikatakanahalfwidth"] = 0xff77;
 
-  t["kiroguramusquare"] = 0x3315;
 
-  t["kiromeetorusquare"] = 0x3316;
 
-  t["kirosquare"] = 0x3314;
 
-  t["kiyeokacirclekorean"] = 0x326e;
 
-  t["kiyeokaparenkorean"] = 0x320e;
 
-  t["kiyeokcirclekorean"] = 0x3260;
 
-  t["kiyeokkorean"] = 0x3131;
 
-  t["kiyeokparenkorean"] = 0x3200;
 
-  t["kiyeoksioskorean"] = 0x3133;
 
-  t["kjecyrillic"] = 0x045c;
 
-  t["klinebelow"] = 0x1e35;
 
-  t["klsquare"] = 0x3398;
 
-  t["kmcubedsquare"] = 0x33a6;
 
-  t["kmonospace"] = 0xff4b;
 
-  t["kmsquaredsquare"] = 0x33a2;
 
-  t["kohiragana"] = 0x3053;
 
-  t["kohmsquare"] = 0x33c0;
 
-  t["kokaithai"] = 0x0e01;
 
-  t["kokatakana"] = 0x30b3;
 
-  t["kokatakanahalfwidth"] = 0xff7a;
 
-  t["kooposquare"] = 0x331e;
 
-  t["koppacyrillic"] = 0x0481;
 
-  t["koreanstandardsymbol"] = 0x327f;
 
-  t["koroniscmb"] = 0x0343;
 
-  t["kparen"] = 0x24a6;
 
-  t["kpasquare"] = 0x33aa;
 
-  t["ksicyrillic"] = 0x046f;
 
-  t["ktsquare"] = 0x33cf;
 
-  t["kturned"] = 0x029e;
 
-  t["kuhiragana"] = 0x304f;
 
-  t["kukatakana"] = 0x30af;
 
-  t["kukatakanahalfwidth"] = 0xff78;
 
-  t["kvsquare"] = 0x33b8;
 
-  t["kwsquare"] = 0x33be;
 
-  t["l"] = 0x006c;
 
-  t["labengali"] = 0x09b2;
 
-  t["lacute"] = 0x013a;
 
-  t["ladeva"] = 0x0932;
 
-  t["lagujarati"] = 0x0ab2;
 
-  t["lagurmukhi"] = 0x0a32;
 
-  t["lakkhangyaothai"] = 0x0e45;
 
-  t["lamaleffinalarabic"] = 0xfefc;
 
-  t["lamalefhamzaabovefinalarabic"] = 0xfef8;
 
-  t["lamalefhamzaaboveisolatedarabic"] = 0xfef7;
 
-  t["lamalefhamzabelowfinalarabic"] = 0xfefa;
 
-  t["lamalefhamzabelowisolatedarabic"] = 0xfef9;
 
-  t["lamalefisolatedarabic"] = 0xfefb;
 
-  t["lamalefmaddaabovefinalarabic"] = 0xfef6;
 
-  t["lamalefmaddaaboveisolatedarabic"] = 0xfef5;
 
-  t["lamarabic"] = 0x0644;
 
-  t["lambda"] = 0x03bb;
 
-  t["lambdastroke"] = 0x019b;
 
-  t["lamed"] = 0x05dc;
 
-  t["lameddagesh"] = 0xfb3c;
 
-  t["lameddageshhebrew"] = 0xfb3c;
 
-  t["lamedhebrew"] = 0x05dc;
 
-  t["lamfinalarabic"] = 0xfede;
 
-  t["lamhahinitialarabic"] = 0xfcca;
 
-  t["laminitialarabic"] = 0xfedf;
 
-  t["lamjeeminitialarabic"] = 0xfcc9;
 
-  t["lamkhahinitialarabic"] = 0xfccb;
 
-  t["lamlamhehisolatedarabic"] = 0xfdf2;
 
-  t["lammedialarabic"] = 0xfee0;
 
-  t["lammeemhahinitialarabic"] = 0xfd88;
 
-  t["lammeeminitialarabic"] = 0xfccc;
 
-  t["largecircle"] = 0x25ef;
 
-  t["lbar"] = 0x019a;
 
-  t["lbelt"] = 0x026c;
 
-  t["lbopomofo"] = 0x310c;
 
-  t["lcaron"] = 0x013e;
 
-  t["lcedilla"] = 0x013c;
 
-  t["lcircle"] = 0x24db;
 
-  t["lcircumflexbelow"] = 0x1e3d;
 
-  t["lcommaaccent"] = 0x013c;
 
-  t["ldot"] = 0x0140;
 
-  t["ldotaccent"] = 0x0140;
 
-  t["ldotbelow"] = 0x1e37;
 
-  t["ldotbelowmacron"] = 0x1e39;
 
-  t["leftangleabovecmb"] = 0x031a;
 
-  t["lefttackbelowcmb"] = 0x0318;
 
-  t["less"] = 0x003c;
 
-  t["lessequal"] = 0x2264;
 
-  t["lessequalorgreater"] = 0x22da;
 
-  t["lessmonospace"] = 0xff1c;
 
-  t["lessorequivalent"] = 0x2272;
 
-  t["lessorgreater"] = 0x2276;
 
-  t["lessoverequal"] = 0x2266;
 
-  t["lesssmall"] = 0xfe64;
 
-  t["lezh"] = 0x026e;
 
-  t["lfblock"] = 0x258c;
 
-  t["lhookretroflex"] = 0x026d;
 
-  t["lira"] = 0x20a4;
 
-  t["liwnarmenian"] = 0x056c;
 
-  t["lj"] = 0x01c9;
 
-  t["ljecyrillic"] = 0x0459;
 
-  t["ll"] = 0xf6c0;
 
-  t["lladeva"] = 0x0933;
 
-  t["llagujarati"] = 0x0ab3;
 
-  t["llinebelow"] = 0x1e3b;
 
-  t["llladeva"] = 0x0934;
 
-  t["llvocalicbengali"] = 0x09e1;
 
-  t["llvocalicdeva"] = 0x0961;
 
-  t["llvocalicvowelsignbengali"] = 0x09e3;
 
-  t["llvocalicvowelsigndeva"] = 0x0963;
 
-  t["lmiddletilde"] = 0x026b;
 
-  t["lmonospace"] = 0xff4c;
 
-  t["lmsquare"] = 0x33d0;
 
-  t["lochulathai"] = 0x0e2c;
 
-  t["logicaland"] = 0x2227;
 
-  t["logicalnot"] = 0x00ac;
 
-  t["logicalnotreversed"] = 0x2310;
 
-  t["logicalor"] = 0x2228;
 
-  t["lolingthai"] = 0x0e25;
 
-  t["longs"] = 0x017f;
 
-  t["lowlinecenterline"] = 0xfe4e;
 
-  t["lowlinecmb"] = 0x0332;
 
-  t["lowlinedashed"] = 0xfe4d;
 
-  t["lozenge"] = 0x25ca;
 
-  t["lparen"] = 0x24a7;
 
-  t["lslash"] = 0x0142;
 
-  t["lsquare"] = 0x2113;
 
-  t["lsuperior"] = 0xf6ee;
 
-  t["ltshade"] = 0x2591;
 
-  t["luthai"] = 0x0e26;
 
-  t["lvocalicbengali"] = 0x098c;
 
-  t["lvocalicdeva"] = 0x090c;
 
-  t["lvocalicvowelsignbengali"] = 0x09e2;
 
-  t["lvocalicvowelsigndeva"] = 0x0962;
 
-  t["lxsquare"] = 0x33d3;
 
-  t["m"] = 0x006d;
 
-  t["mabengali"] = 0x09ae;
 
-  t["macron"] = 0x00af;
 
-  t["macronbelowcmb"] = 0x0331;
 
-  t["macroncmb"] = 0x0304;
 
-  t["macronlowmod"] = 0x02cd;
 
-  t["macronmonospace"] = 0xffe3;
 
-  t["macute"] = 0x1e3f;
 
-  t["madeva"] = 0x092e;
 
-  t["magujarati"] = 0x0aae;
 
-  t["magurmukhi"] = 0x0a2e;
 
-  t["mahapakhhebrew"] = 0x05a4;
 
-  t["mahapakhlefthebrew"] = 0x05a4;
 
-  t["mahiragana"] = 0x307e;
 
-  t["maichattawalowleftthai"] = 0xf895;
 
-  t["maichattawalowrightthai"] = 0xf894;
 
-  t["maichattawathai"] = 0x0e4b;
 
-  t["maichattawaupperleftthai"] = 0xf893;
 
-  t["maieklowleftthai"] = 0xf88c;
 
-  t["maieklowrightthai"] = 0xf88b;
 
-  t["maiekthai"] = 0x0e48;
 
-  t["maiekupperleftthai"] = 0xf88a;
 
-  t["maihanakatleftthai"] = 0xf884;
 
-  t["maihanakatthai"] = 0x0e31;
 
-  t["maitaikhuleftthai"] = 0xf889;
 
-  t["maitaikhuthai"] = 0x0e47;
 
-  t["maitholowleftthai"] = 0xf88f;
 
-  t["maitholowrightthai"] = 0xf88e;
 
-  t["maithothai"] = 0x0e49;
 
-  t["maithoupperleftthai"] = 0xf88d;
 
-  t["maitrilowleftthai"] = 0xf892;
 
-  t["maitrilowrightthai"] = 0xf891;
 
-  t["maitrithai"] = 0x0e4a;
 
-  t["maitriupperleftthai"] = 0xf890;
 
-  t["maiyamokthai"] = 0x0e46;
 
-  t["makatakana"] = 0x30de;
 
-  t["makatakanahalfwidth"] = 0xff8f;
 
-  t["male"] = 0x2642;
 
-  t["mansyonsquare"] = 0x3347;
 
-  t["maqafhebrew"] = 0x05be;
 
-  t["mars"] = 0x2642;
 
-  t["masoracirclehebrew"] = 0x05af;
 
-  t["masquare"] = 0x3383;
 
-  t["mbopomofo"] = 0x3107;
 
-  t["mbsquare"] = 0x33d4;
 
-  t["mcircle"] = 0x24dc;
 
-  t["mcubedsquare"] = 0x33a5;
 
-  t["mdotaccent"] = 0x1e41;
 
-  t["mdotbelow"] = 0x1e43;
 
-  t["meemarabic"] = 0x0645;
 
-  t["meemfinalarabic"] = 0xfee2;
 
-  t["meeminitialarabic"] = 0xfee3;
 
-  t["meemmedialarabic"] = 0xfee4;
 
-  t["meemmeeminitialarabic"] = 0xfcd1;
 
-  t["meemmeemisolatedarabic"] = 0xfc48;
 
-  t["meetorusquare"] = 0x334d;
 
-  t["mehiragana"] = 0x3081;
 
-  t["meizierasquare"] = 0x337e;
 
-  t["mekatakana"] = 0x30e1;
 
-  t["mekatakanahalfwidth"] = 0xff92;
 
-  t["mem"] = 0x05de;
 
-  t["memdagesh"] = 0xfb3e;
 
-  t["memdageshhebrew"] = 0xfb3e;
 
-  t["memhebrew"] = 0x05de;
 
-  t["menarmenian"] = 0x0574;
 
-  t["merkhahebrew"] = 0x05a5;
 
-  t["merkhakefulahebrew"] = 0x05a6;
 
-  t["merkhakefulalefthebrew"] = 0x05a6;
 
-  t["merkhalefthebrew"] = 0x05a5;
 
-  t["mhook"] = 0x0271;
 
-  t["mhzsquare"] = 0x3392;
 
-  t["middledotkatakanahalfwidth"] = 0xff65;
 
-  t["middot"] = 0x00b7;
 
-  t["mieumacirclekorean"] = 0x3272;
 
-  t["mieumaparenkorean"] = 0x3212;
 
-  t["mieumcirclekorean"] = 0x3264;
 
-  t["mieumkorean"] = 0x3141;
 
-  t["mieumpansioskorean"] = 0x3170;
 
-  t["mieumparenkorean"] = 0x3204;
 
-  t["mieumpieupkorean"] = 0x316e;
 
-  t["mieumsioskorean"] = 0x316f;
 
-  t["mihiragana"] = 0x307f;
 
-  t["mikatakana"] = 0x30df;
 
-  t["mikatakanahalfwidth"] = 0xff90;
 
-  t["minus"] = 0x2212;
 
-  t["minusbelowcmb"] = 0x0320;
 
-  t["minuscircle"] = 0x2296;
 
-  t["minusmod"] = 0x02d7;
 
-  t["minusplus"] = 0x2213;
 
-  t["minute"] = 0x2032;
 
-  t["miribaarusquare"] = 0x334a;
 
-  t["mirisquare"] = 0x3349;
 
-  t["mlonglegturned"] = 0x0270;
 
-  t["mlsquare"] = 0x3396;
 
-  t["mmcubedsquare"] = 0x33a3;
 
-  t["mmonospace"] = 0xff4d;
 
-  t["mmsquaredsquare"] = 0x339f;
 
-  t["mohiragana"] = 0x3082;
 
-  t["mohmsquare"] = 0x33c1;
 
-  t["mokatakana"] = 0x30e2;
 
-  t["mokatakanahalfwidth"] = 0xff93;
 
-  t["molsquare"] = 0x33d6;
 
-  t["momathai"] = 0x0e21;
 
-  t["moverssquare"] = 0x33a7;
 
-  t["moverssquaredsquare"] = 0x33a8;
 
-  t["mparen"] = 0x24a8;
 
-  t["mpasquare"] = 0x33ab;
 
-  t["mssquare"] = 0x33b3;
 
-  t["msuperior"] = 0xf6ef;
 
-  t["mturned"] = 0x026f;
 
-  t["mu"] = 0x00b5;
 
-  t["mu1"] = 0x00b5;
 
-  t["muasquare"] = 0x3382;
 
-  t["muchgreater"] = 0x226b;
 
-  t["muchless"] = 0x226a;
 
-  t["mufsquare"] = 0x338c;
 
-  t["mugreek"] = 0x03bc;
 
-  t["mugsquare"] = 0x338d;
 
-  t["muhiragana"] = 0x3080;
 
-  t["mukatakana"] = 0x30e0;
 
-  t["mukatakanahalfwidth"] = 0xff91;
 
-  t["mulsquare"] = 0x3395;
 
-  t["multiply"] = 0x00d7;
 
-  t["mumsquare"] = 0x339b;
 
-  t["munahhebrew"] = 0x05a3;
 
-  t["munahlefthebrew"] = 0x05a3;
 
-  t["musicalnote"] = 0x266a;
 
-  t["musicalnotedbl"] = 0x266b;
 
-  t["musicflatsign"] = 0x266d;
 
-  t["musicsharpsign"] = 0x266f;
 
-  t["mussquare"] = 0x33b2;
 
-  t["muvsquare"] = 0x33b6;
 
-  t["muwsquare"] = 0x33bc;
 
-  t["mvmegasquare"] = 0x33b9;
 
-  t["mvsquare"] = 0x33b7;
 
-  t["mwmegasquare"] = 0x33bf;
 
-  t["mwsquare"] = 0x33bd;
 
-  t["n"] = 0x006e;
 
-  t["nabengali"] = 0x09a8;
 
-  t["nabla"] = 0x2207;
 
-  t["nacute"] = 0x0144;
 
-  t["nadeva"] = 0x0928;
 
-  t["nagujarati"] = 0x0aa8;
 
-  t["nagurmukhi"] = 0x0a28;
 
-  t["nahiragana"] = 0x306a;
 
-  t["nakatakana"] = 0x30ca;
 
-  t["nakatakanahalfwidth"] = 0xff85;
 
-  t["napostrophe"] = 0x0149;
 
-  t["nasquare"] = 0x3381;
 
-  t["nbopomofo"] = 0x310b;
 
-  t["nbspace"] = 0x00a0;
 
-  t["ncaron"] = 0x0148;
 
-  t["ncedilla"] = 0x0146;
 
-  t["ncircle"] = 0x24dd;
 
-  t["ncircumflexbelow"] = 0x1e4b;
 
-  t["ncommaaccent"] = 0x0146;
 
-  t["ndotaccent"] = 0x1e45;
 
-  t["ndotbelow"] = 0x1e47;
 
-  t["nehiragana"] = 0x306d;
 
-  t["nekatakana"] = 0x30cd;
 
-  t["nekatakanahalfwidth"] = 0xff88;
 
-  t["newsheqelsign"] = 0x20aa;
 
-  t["nfsquare"] = 0x338b;
 
-  t["ngabengali"] = 0x0999;
 
-  t["ngadeva"] = 0x0919;
 
-  t["ngagujarati"] = 0x0a99;
 
-  t["ngagurmukhi"] = 0x0a19;
 
-  t["ngonguthai"] = 0x0e07;
 
-  t["nhiragana"] = 0x3093;
 
-  t["nhookleft"] = 0x0272;
 
-  t["nhookretroflex"] = 0x0273;
 
-  t["nieunacirclekorean"] = 0x326f;
 
-  t["nieunaparenkorean"] = 0x320f;
 
-  t["nieuncieuckorean"] = 0x3135;
 
-  t["nieuncirclekorean"] = 0x3261;
 
-  t["nieunhieuhkorean"] = 0x3136;
 
-  t["nieunkorean"] = 0x3134;
 
-  t["nieunpansioskorean"] = 0x3168;
 
-  t["nieunparenkorean"] = 0x3201;
 
-  t["nieunsioskorean"] = 0x3167;
 
-  t["nieuntikeutkorean"] = 0x3166;
 
-  t["nihiragana"] = 0x306b;
 
-  t["nikatakana"] = 0x30cb;
 
-  t["nikatakanahalfwidth"] = 0xff86;
 
-  t["nikhahitleftthai"] = 0xf899;
 
-  t["nikhahitthai"] = 0x0e4d;
 
-  t["nine"] = 0x0039;
 
-  t["ninearabic"] = 0x0669;
 
-  t["ninebengali"] = 0x09ef;
 
-  t["ninecircle"] = 0x2468;
 
-  t["ninecircleinversesansserif"] = 0x2792;
 
-  t["ninedeva"] = 0x096f;
 
-  t["ninegujarati"] = 0x0aef;
 
-  t["ninegurmukhi"] = 0x0a6f;
 
-  t["ninehackarabic"] = 0x0669;
 
-  t["ninehangzhou"] = 0x3029;
 
-  t["nineideographicparen"] = 0x3228;
 
-  t["nineinferior"] = 0x2089;
 
-  t["ninemonospace"] = 0xff19;
 
-  t["nineoldstyle"] = 0xf739;
 
-  t["nineparen"] = 0x247c;
 
-  t["nineperiod"] = 0x2490;
 
-  t["ninepersian"] = 0x06f9;
 
-  t["nineroman"] = 0x2178;
 
-  t["ninesuperior"] = 0x2079;
 
-  t["nineteencircle"] = 0x2472;
 
-  t["nineteenparen"] = 0x2486;
 
-  t["nineteenperiod"] = 0x249a;
 
-  t["ninethai"] = 0x0e59;
 
-  t["nj"] = 0x01cc;
 
-  t["njecyrillic"] = 0x045a;
 
-  t["nkatakana"] = 0x30f3;
 
-  t["nkatakanahalfwidth"] = 0xff9d;
 
-  t["nlegrightlong"] = 0x019e;
 
-  t["nlinebelow"] = 0x1e49;
 
-  t["nmonospace"] = 0xff4e;
 
-  t["nmsquare"] = 0x339a;
 
-  t["nnabengali"] = 0x09a3;
 
-  t["nnadeva"] = 0x0923;
 
-  t["nnagujarati"] = 0x0aa3;
 
-  t["nnagurmukhi"] = 0x0a23;
 
-  t["nnnadeva"] = 0x0929;
 
-  t["nohiragana"] = 0x306e;
 
-  t["nokatakana"] = 0x30ce;
 
-  t["nokatakanahalfwidth"] = 0xff89;
 
-  t["nonbreakingspace"] = 0x00a0;
 
-  t["nonenthai"] = 0x0e13;
 
-  t["nonuthai"] = 0x0e19;
 
-  t["noonarabic"] = 0x0646;
 
-  t["noonfinalarabic"] = 0xfee6;
 
-  t["noonghunnaarabic"] = 0x06ba;
 
-  t["noonghunnafinalarabic"] = 0xfb9f;
 
-  t["nooninitialarabic"] = 0xfee7;
 
-  t["noonjeeminitialarabic"] = 0xfcd2;
 
-  t["noonjeemisolatedarabic"] = 0xfc4b;
 
-  t["noonmedialarabic"] = 0xfee8;
 
-  t["noonmeeminitialarabic"] = 0xfcd5;
 
-  t["noonmeemisolatedarabic"] = 0xfc4e;
 
-  t["noonnoonfinalarabic"] = 0xfc8d;
 
-  t["notcontains"] = 0x220c;
 
-  t["notelement"] = 0x2209;
 
-  t["notelementof"] = 0x2209;
 
-  t["notequal"] = 0x2260;
 
-  t["notgreater"] = 0x226f;
 
-  t["notgreaternorequal"] = 0x2271;
 
-  t["notgreaternorless"] = 0x2279;
 
-  t["notidentical"] = 0x2262;
 
-  t["notless"] = 0x226e;
 
-  t["notlessnorequal"] = 0x2270;
 
-  t["notparallel"] = 0x2226;
 
-  t["notprecedes"] = 0x2280;
 
-  t["notsubset"] = 0x2284;
 
-  t["notsucceeds"] = 0x2281;
 
-  t["notsuperset"] = 0x2285;
 
-  t["nowarmenian"] = 0x0576;
 
-  t["nparen"] = 0x24a9;
 
-  t["nssquare"] = 0x33b1;
 
-  t["nsuperior"] = 0x207f;
 
-  t["ntilde"] = 0x00f1;
 
-  t["nu"] = 0x03bd;
 
-  t["nuhiragana"] = 0x306c;
 
-  t["nukatakana"] = 0x30cc;
 
-  t["nukatakanahalfwidth"] = 0xff87;
 
-  t["nuktabengali"] = 0x09bc;
 
-  t["nuktadeva"] = 0x093c;
 
-  t["nuktagujarati"] = 0x0abc;
 
-  t["nuktagurmukhi"] = 0x0a3c;
 
-  t["numbersign"] = 0x0023;
 
-  t["numbersignmonospace"] = 0xff03;
 
-  t["numbersignsmall"] = 0xfe5f;
 
-  t["numeralsigngreek"] = 0x0374;
 
-  t["numeralsignlowergreek"] = 0x0375;
 
-  t["numero"] = 0x2116;
 
-  t["nun"] = 0x05e0;
 
-  t["nundagesh"] = 0xfb40;
 
-  t["nundageshhebrew"] = 0xfb40;
 
-  t["nunhebrew"] = 0x05e0;
 
-  t["nvsquare"] = 0x33b5;
 
-  t["nwsquare"] = 0x33bb;
 
-  t["nyabengali"] = 0x099e;
 
-  t["nyadeva"] = 0x091e;
 
-  t["nyagujarati"] = 0x0a9e;
 
-  t["nyagurmukhi"] = 0x0a1e;
 
-  t["o"] = 0x006f;
 
-  t["oacute"] = 0x00f3;
 
-  t["oangthai"] = 0x0e2d;
 
-  t["obarred"] = 0x0275;
 
-  t["obarredcyrillic"] = 0x04e9;
 
-  t["obarreddieresiscyrillic"] = 0x04eb;
 
-  t["obengali"] = 0x0993;
 
-  t["obopomofo"] = 0x311b;
 
-  t["obreve"] = 0x014f;
 
-  t["ocandradeva"] = 0x0911;
 
-  t["ocandragujarati"] = 0x0a91;
 
-  t["ocandravowelsigndeva"] = 0x0949;
 
-  t["ocandravowelsigngujarati"] = 0x0ac9;
 
-  t["ocaron"] = 0x01d2;
 
-  t["ocircle"] = 0x24de;
 
-  t["ocircumflex"] = 0x00f4;
 
-  t["ocircumflexacute"] = 0x1ed1;
 
-  t["ocircumflexdotbelow"] = 0x1ed9;
 
-  t["ocircumflexgrave"] = 0x1ed3;
 
-  t["ocircumflexhookabove"] = 0x1ed5;
 
-  t["ocircumflextilde"] = 0x1ed7;
 
-  t["ocyrillic"] = 0x043e;
 
-  t["odblacute"] = 0x0151;
 
-  t["odblgrave"] = 0x020d;
 
-  t["odeva"] = 0x0913;
 
-  t["odieresis"] = 0x00f6;
 
-  t["odieresiscyrillic"] = 0x04e7;
 
-  t["odotbelow"] = 0x1ecd;
 
-  t["oe"] = 0x0153;
 
-  t["oekorean"] = 0x315a;
 
-  t["ogonek"] = 0x02db;
 
-  t["ogonekcmb"] = 0x0328;
 
-  t["ograve"] = 0x00f2;
 
-  t["ogujarati"] = 0x0a93;
 
-  t["oharmenian"] = 0x0585;
 
-  t["ohiragana"] = 0x304a;
 
-  t["ohookabove"] = 0x1ecf;
 
-  t["ohorn"] = 0x01a1;
 
-  t["ohornacute"] = 0x1edb;
 
-  t["ohorndotbelow"] = 0x1ee3;
 
-  t["ohorngrave"] = 0x1edd;
 
-  t["ohornhookabove"] = 0x1edf;
 
-  t["ohorntilde"] = 0x1ee1;
 
-  t["ohungarumlaut"] = 0x0151;
 
-  t["oi"] = 0x01a3;
 
-  t["oinvertedbreve"] = 0x020f;
 
-  t["okatakana"] = 0x30aa;
 
-  t["okatakanahalfwidth"] = 0xff75;
 
-  t["okorean"] = 0x3157;
 
-  t["olehebrew"] = 0x05ab;
 
-  t["omacron"] = 0x014d;
 
-  t["omacronacute"] = 0x1e53;
 
-  t["omacrongrave"] = 0x1e51;
 
-  t["omdeva"] = 0x0950;
 
-  t["omega"] = 0x03c9;
 
-  t["omega1"] = 0x03d6;
 
-  t["omegacyrillic"] = 0x0461;
 
-  t["omegalatinclosed"] = 0x0277;
 
-  t["omegaroundcyrillic"] = 0x047b;
 
-  t["omegatitlocyrillic"] = 0x047d;
 
-  t["omegatonos"] = 0x03ce;
 
-  t["omgujarati"] = 0x0ad0;
 
-  t["omicron"] = 0x03bf;
 
-  t["omicrontonos"] = 0x03cc;
 
-  t["omonospace"] = 0xff4f;
 
-  t["one"] = 0x0031;
 
-  t["onearabic"] = 0x0661;
 
-  t["onebengali"] = 0x09e7;
 
-  t["onecircle"] = 0x2460;
 
-  t["onecircleinversesansserif"] = 0x278a;
 
-  t["onedeva"] = 0x0967;
 
-  t["onedotenleader"] = 0x2024;
 
-  t["oneeighth"] = 0x215b;
 
-  t["onefitted"] = 0xf6dc;
 
-  t["onegujarati"] = 0x0ae7;
 
-  t["onegurmukhi"] = 0x0a67;
 
-  t["onehackarabic"] = 0x0661;
 
-  t["onehalf"] = 0x00bd;
 
-  t["onehangzhou"] = 0x3021;
 
-  t["oneideographicparen"] = 0x3220;
 
-  t["oneinferior"] = 0x2081;
 
-  t["onemonospace"] = 0xff11;
 
-  t["onenumeratorbengali"] = 0x09f4;
 
-  t["oneoldstyle"] = 0xf731;
 
-  t["oneparen"] = 0x2474;
 
-  t["oneperiod"] = 0x2488;
 
-  t["onepersian"] = 0x06f1;
 
-  t["onequarter"] = 0x00bc;
 
-  t["oneroman"] = 0x2170;
 
-  t["onesuperior"] = 0x00b9;
 
-  t["onethai"] = 0x0e51;
 
-  t["onethird"] = 0x2153;
 
-  t["oogonek"] = 0x01eb;
 
-  t["oogonekmacron"] = 0x01ed;
 
-  t["oogurmukhi"] = 0x0a13;
 
-  t["oomatragurmukhi"] = 0x0a4b;
 
-  t["oopen"] = 0x0254;
 
-  t["oparen"] = 0x24aa;
 
-  t["openbullet"] = 0x25e6;
 
-  t["option"] = 0x2325;
 
-  t["ordfeminine"] = 0x00aa;
 
-  t["ordmasculine"] = 0x00ba;
 
-  t["orthogonal"] = 0x221f;
 
-  t["oshortdeva"] = 0x0912;
 
-  t["oshortvowelsigndeva"] = 0x094a;
 
-  t["oslash"] = 0x00f8;
 
-  t["oslashacute"] = 0x01ff;
 
-  t["osmallhiragana"] = 0x3049;
 
-  t["osmallkatakana"] = 0x30a9;
 
-  t["osmallkatakanahalfwidth"] = 0xff6b;
 
-  t["ostrokeacute"] = 0x01ff;
 
-  t["osuperior"] = 0xf6f0;
 
-  t["otcyrillic"] = 0x047f;
 
-  t["otilde"] = 0x00f5;
 
-  t["otildeacute"] = 0x1e4d;
 
-  t["otildedieresis"] = 0x1e4f;
 
-  t["oubopomofo"] = 0x3121;
 
-  t["overline"] = 0x203e;
 
-  t["overlinecenterline"] = 0xfe4a;
 
-  t["overlinecmb"] = 0x0305;
 
-  t["overlinedashed"] = 0xfe49;
 
-  t["overlinedblwavy"] = 0xfe4c;
 
-  t["overlinewavy"] = 0xfe4b;
 
-  t["overscore"] = 0x00af;
 
-  t["ovowelsignbengali"] = 0x09cb;
 
-  t["ovowelsigndeva"] = 0x094b;
 
-  t["ovowelsigngujarati"] = 0x0acb;
 
-  t["p"] = 0x0070;
 
-  t["paampssquare"] = 0x3380;
 
-  t["paasentosquare"] = 0x332b;
 
-  t["pabengali"] = 0x09aa;
 
-  t["pacute"] = 0x1e55;
 
-  t["padeva"] = 0x092a;
 
-  t["pagedown"] = 0x21df;
 
-  t["pageup"] = 0x21de;
 
-  t["pagujarati"] = 0x0aaa;
 
-  t["pagurmukhi"] = 0x0a2a;
 
-  t["pahiragana"] = 0x3071;
 
-  t["paiyannoithai"] = 0x0e2f;
 
-  t["pakatakana"] = 0x30d1;
 
-  t["palatalizationcyrilliccmb"] = 0x0484;
 
-  t["palochkacyrillic"] = 0x04c0;
 
-  t["pansioskorean"] = 0x317f;
 
-  t["paragraph"] = 0x00b6;
 
-  t["parallel"] = 0x2225;
 
-  t["parenleft"] = 0x0028;
 
-  t["parenleftaltonearabic"] = 0xfd3e;
 
-  t["parenleftbt"] = 0xf8ed;
 
-  t["parenleftex"] = 0xf8ec;
 
-  t["parenleftinferior"] = 0x208d;
 
-  t["parenleftmonospace"] = 0xff08;
 
-  t["parenleftsmall"] = 0xfe59;
 
-  t["parenleftsuperior"] = 0x207d;
 
-  t["parenlefttp"] = 0xf8eb;
 
-  t["parenleftvertical"] = 0xfe35;
 
-  t["parenright"] = 0x0029;
 
-  t["parenrightaltonearabic"] = 0xfd3f;
 
-  t["parenrightbt"] = 0xf8f8;
 
-  t["parenrightex"] = 0xf8f7;
 
-  t["parenrightinferior"] = 0x208e;
 
-  t["parenrightmonospace"] = 0xff09;
 
-  t["parenrightsmall"] = 0xfe5a;
 
-  t["parenrightsuperior"] = 0x207e;
 
-  t["parenrighttp"] = 0xf8f6;
 
-  t["parenrightvertical"] = 0xfe36;
 
-  t["partialdiff"] = 0x2202;
 
-  t["paseqhebrew"] = 0x05c0;
 
-  t["pashtahebrew"] = 0x0599;
 
-  t["pasquare"] = 0x33a9;
 
-  t["patah"] = 0x05b7;
 
-  t["patah11"] = 0x05b7;
 
-  t["patah1d"] = 0x05b7;
 
-  t["patah2a"] = 0x05b7;
 
-  t["patahhebrew"] = 0x05b7;
 
-  t["patahnarrowhebrew"] = 0x05b7;
 
-  t["patahquarterhebrew"] = 0x05b7;
 
-  t["patahwidehebrew"] = 0x05b7;
 
-  t["pazerhebrew"] = 0x05a1;
 
-  t["pbopomofo"] = 0x3106;
 
-  t["pcircle"] = 0x24df;
 
-  t["pdotaccent"] = 0x1e57;
 
-  t["pe"] = 0x05e4;
 
-  t["pecyrillic"] = 0x043f;
 
-  t["pedagesh"] = 0xfb44;
 
-  t["pedageshhebrew"] = 0xfb44;
 
-  t["peezisquare"] = 0x333b;
 
-  t["pefinaldageshhebrew"] = 0xfb43;
 
-  t["peharabic"] = 0x067e;
 
-  t["peharmenian"] = 0x057a;
 
-  t["pehebrew"] = 0x05e4;
 
-  t["pehfinalarabic"] = 0xfb57;
 
-  t["pehinitialarabic"] = 0xfb58;
 
-  t["pehiragana"] = 0x307a;
 
-  t["pehmedialarabic"] = 0xfb59;
 
-  t["pekatakana"] = 0x30da;
 
-  t["pemiddlehookcyrillic"] = 0x04a7;
 
-  t["perafehebrew"] = 0xfb4e;
 
-  t["percent"] = 0x0025;
 
-  t["percentarabic"] = 0x066a;
 
-  t["percentmonospace"] = 0xff05;
 
-  t["percentsmall"] = 0xfe6a;
 
-  t["period"] = 0x002e;
 
-  t["periodarmenian"] = 0x0589;
 
-  t["periodcentered"] = 0x00b7;
 
-  t["periodhalfwidth"] = 0xff61;
 
-  t["periodinferior"] = 0xf6e7;
 
-  t["periodmonospace"] = 0xff0e;
 
-  t["periodsmall"] = 0xfe52;
 
-  t["periodsuperior"] = 0xf6e8;
 
-  t["perispomenigreekcmb"] = 0x0342;
 
-  t["perpendicular"] = 0x22a5;
 
-  t["perthousand"] = 0x2030;
 
-  t["peseta"] = 0x20a7;
 
-  t["pfsquare"] = 0x338a;
 
-  t["phabengali"] = 0x09ab;
 
-  t["phadeva"] = 0x092b;
 
-  t["phagujarati"] = 0x0aab;
 
-  t["phagurmukhi"] = 0x0a2b;
 
-  t["phi"] = 0x03c6;
 
-  t["phi1"] = 0x03d5;
 
-  t["phieuphacirclekorean"] = 0x327a;
 
-  t["phieuphaparenkorean"] = 0x321a;
 
-  t["phieuphcirclekorean"] = 0x326c;
 
-  t["phieuphkorean"] = 0x314d;
 
-  t["phieuphparenkorean"] = 0x320c;
 
-  t["philatin"] = 0x0278;
 
-  t["phinthuthai"] = 0x0e3a;
 
-  t["phisymbolgreek"] = 0x03d5;
 
-  t["phook"] = 0x01a5;
 
-  t["phophanthai"] = 0x0e1e;
 
-  t["phophungthai"] = 0x0e1c;
 
-  t["phosamphaothai"] = 0x0e20;
 
-  t["pi"] = 0x03c0;
 
-  t["pieupacirclekorean"] = 0x3273;
 
-  t["pieupaparenkorean"] = 0x3213;
 
-  t["pieupcieuckorean"] = 0x3176;
 
-  t["pieupcirclekorean"] = 0x3265;
 
-  t["pieupkiyeokkorean"] = 0x3172;
 
-  t["pieupkorean"] = 0x3142;
 
-  t["pieupparenkorean"] = 0x3205;
 
-  t["pieupsioskiyeokkorean"] = 0x3174;
 
-  t["pieupsioskorean"] = 0x3144;
 
-  t["pieupsiostikeutkorean"] = 0x3175;
 
-  t["pieupthieuthkorean"] = 0x3177;
 
-  t["pieuptikeutkorean"] = 0x3173;
 
-  t["pihiragana"] = 0x3074;
 
-  t["pikatakana"] = 0x30d4;
 
-  t["pisymbolgreek"] = 0x03d6;
 
-  t["piwrarmenian"] = 0x0583;
 
-  t["plus"] = 0x002b;
 
-  t["plusbelowcmb"] = 0x031f;
 
-  t["pluscircle"] = 0x2295;
 
-  t["plusminus"] = 0x00b1;
 
-  t["plusmod"] = 0x02d6;
 
-  t["plusmonospace"] = 0xff0b;
 
-  t["plussmall"] = 0xfe62;
 
-  t["plussuperior"] = 0x207a;
 
-  t["pmonospace"] = 0xff50;
 
-  t["pmsquare"] = 0x33d8;
 
-  t["pohiragana"] = 0x307d;
 
-  t["pointingindexdownwhite"] = 0x261f;
 
-  t["pointingindexleftwhite"] = 0x261c;
 
-  t["pointingindexrightwhite"] = 0x261e;
 
-  t["pointingindexupwhite"] = 0x261d;
 
-  t["pokatakana"] = 0x30dd;
 
-  t["poplathai"] = 0x0e1b;
 
-  t["postalmark"] = 0x3012;
 
-  t["postalmarkface"] = 0x3020;
 
-  t["pparen"] = 0x24ab;
 
-  t["precedes"] = 0x227a;
 
-  t["prescription"] = 0x211e;
 
-  t["primemod"] = 0x02b9;
 
-  t["primereversed"] = 0x2035;
 
-  t["product"] = 0x220f;
 
-  t["projective"] = 0x2305;
 
-  t["prolongedkana"] = 0x30fc;
 
-  t["propellor"] = 0x2318;
 
-  t["propersubset"] = 0x2282;
 
-  t["propersuperset"] = 0x2283;
 
-  t["proportion"] = 0x2237;
 
-  t["proportional"] = 0x221d;
 
-  t["psi"] = 0x03c8;
 
-  t["psicyrillic"] = 0x0471;
 
-  t["psilipneumatacyrilliccmb"] = 0x0486;
 
-  t["pssquare"] = 0x33b0;
 
-  t["puhiragana"] = 0x3077;
 
-  t["pukatakana"] = 0x30d7;
 
-  t["pvsquare"] = 0x33b4;
 
-  t["pwsquare"] = 0x33ba;
 
-  t["q"] = 0x0071;
 
-  t["qadeva"] = 0x0958;
 
-  t["qadmahebrew"] = 0x05a8;
 
-  t["qafarabic"] = 0x0642;
 
-  t["qaffinalarabic"] = 0xfed6;
 
-  t["qafinitialarabic"] = 0xfed7;
 
-  t["qafmedialarabic"] = 0xfed8;
 
-  t["qamats"] = 0x05b8;
 
-  t["qamats10"] = 0x05b8;
 
-  t["qamats1a"] = 0x05b8;
 
-  t["qamats1c"] = 0x05b8;
 
-  t["qamats27"] = 0x05b8;
 
-  t["qamats29"] = 0x05b8;
 
-  t["qamats33"] = 0x05b8;
 
-  t["qamatsde"] = 0x05b8;
 
-  t["qamatshebrew"] = 0x05b8;
 
-  t["qamatsnarrowhebrew"] = 0x05b8;
 
-  t["qamatsqatanhebrew"] = 0x05b8;
 
-  t["qamatsqatannarrowhebrew"] = 0x05b8;
 
-  t["qamatsqatanquarterhebrew"] = 0x05b8;
 
-  t["qamatsqatanwidehebrew"] = 0x05b8;
 
-  t["qamatsquarterhebrew"] = 0x05b8;
 
-  t["qamatswidehebrew"] = 0x05b8;
 
-  t["qarneyparahebrew"] = 0x059f;
 
-  t["qbopomofo"] = 0x3111;
 
-  t["qcircle"] = 0x24e0;
 
-  t["qhook"] = 0x02a0;
 
-  t["qmonospace"] = 0xff51;
 
-  t["qof"] = 0x05e7;
 
-  t["qofdagesh"] = 0xfb47;
 
-  t["qofdageshhebrew"] = 0xfb47;
 
-  t["qofhebrew"] = 0x05e7;
 
-  t["qparen"] = 0x24ac;
 
-  t["quarternote"] = 0x2669;
 
-  t["qubuts"] = 0x05bb;
 
-  t["qubuts18"] = 0x05bb;
 
-  t["qubuts25"] = 0x05bb;
 
-  t["qubuts31"] = 0x05bb;
 
-  t["qubutshebrew"] = 0x05bb;
 
-  t["qubutsnarrowhebrew"] = 0x05bb;
 
-  t["qubutsquarterhebrew"] = 0x05bb;
 
-  t["qubutswidehebrew"] = 0x05bb;
 
-  t["question"] = 0x003f;
 
-  t["questionarabic"] = 0x061f;
 
-  t["questionarmenian"] = 0x055e;
 
-  t["questiondown"] = 0x00bf;
 
-  t["questiondownsmall"] = 0xf7bf;
 
-  t["questiongreek"] = 0x037e;
 
-  t["questionmonospace"] = 0xff1f;
 
-  t["questionsmall"] = 0xf73f;
 
-  t["quotedbl"] = 0x0022;
 
-  t["quotedblbase"] = 0x201e;
 
-  t["quotedblleft"] = 0x201c;
 
-  t["quotedblmonospace"] = 0xff02;
 
-  t["quotedblprime"] = 0x301e;
 
-  t["quotedblprimereversed"] = 0x301d;
 
-  t["quotedblright"] = 0x201d;
 
-  t["quoteleft"] = 0x2018;
 
-  t["quoteleftreversed"] = 0x201b;
 
-  t["quotereversed"] = 0x201b;
 
-  t["quoteright"] = 0x2019;
 
-  t["quoterightn"] = 0x0149;
 
-  t["quotesinglbase"] = 0x201a;
 
-  t["quotesingle"] = 0x0027;
 
-  t["quotesinglemonospace"] = 0xff07;
 
-  t["r"] = 0x0072;
 
-  t["raarmenian"] = 0x057c;
 
-  t["rabengali"] = 0x09b0;
 
-  t["racute"] = 0x0155;
 
-  t["radeva"] = 0x0930;
 
-  t["radical"] = 0x221a;
 
-  t["radicalex"] = 0xf8e5;
 
-  t["radoverssquare"] = 0x33ae;
 
-  t["radoverssquaredsquare"] = 0x33af;
 
-  t["radsquare"] = 0x33ad;
 
-  t["rafe"] = 0x05bf;
 
-  t["rafehebrew"] = 0x05bf;
 
-  t["ragujarati"] = 0x0ab0;
 
-  t["ragurmukhi"] = 0x0a30;
 
-  t["rahiragana"] = 0x3089;
 
-  t["rakatakana"] = 0x30e9;
 
-  t["rakatakanahalfwidth"] = 0xff97;
 
-  t["ralowerdiagonalbengali"] = 0x09f1;
 
-  t["ramiddlediagonalbengali"] = 0x09f0;
 
-  t["ramshorn"] = 0x0264;
 
-  t["ratio"] = 0x2236;
 
-  t["rbopomofo"] = 0x3116;
 
-  t["rcaron"] = 0x0159;
 
-  t["rcedilla"] = 0x0157;
 
-  t["rcircle"] = 0x24e1;
 
-  t["rcommaaccent"] = 0x0157;
 
-  t["rdblgrave"] = 0x0211;
 
-  t["rdotaccent"] = 0x1e59;
 
-  t["rdotbelow"] = 0x1e5b;
 
-  t["rdotbelowmacron"] = 0x1e5d;
 
-  t["referencemark"] = 0x203b;
 
-  t["reflexsubset"] = 0x2286;
 
-  t["reflexsuperset"] = 0x2287;
 
-  t["registered"] = 0x00ae;
 
-  t["registersans"] = 0xf8e8;
 
-  t["registerserif"] = 0xf6da;
 
-  t["reharabic"] = 0x0631;
 
-  t["reharmenian"] = 0x0580;
 
-  t["rehfinalarabic"] = 0xfeae;
 
-  t["rehiragana"] = 0x308c;
 
-  t["rekatakana"] = 0x30ec;
 
-  t["rekatakanahalfwidth"] = 0xff9a;
 
-  t["resh"] = 0x05e8;
 
-  t["reshdageshhebrew"] = 0xfb48;
 
-  t["reshhebrew"] = 0x05e8;
 
-  t["reversedtilde"] = 0x223d;
 
-  t["reviahebrew"] = 0x0597;
 
-  t["reviamugrashhebrew"] = 0x0597;
 
-  t["revlogicalnot"] = 0x2310;
 
-  t["rfishhook"] = 0x027e;
 
-  t["rfishhookreversed"] = 0x027f;
 
-  t["rhabengali"] = 0x09dd;
 
-  t["rhadeva"] = 0x095d;
 
-  t["rho"] = 0x03c1;
 
-  t["rhook"] = 0x027d;
 
-  t["rhookturned"] = 0x027b;
 
-  t["rhookturnedsuperior"] = 0x02b5;
 
-  t["rhosymbolgreek"] = 0x03f1;
 
-  t["rhotichookmod"] = 0x02de;
 
-  t["rieulacirclekorean"] = 0x3271;
 
-  t["rieulaparenkorean"] = 0x3211;
 
-  t["rieulcirclekorean"] = 0x3263;
 
-  t["rieulhieuhkorean"] = 0x3140;
 
-  t["rieulkiyeokkorean"] = 0x313a;
 
-  t["rieulkiyeoksioskorean"] = 0x3169;
 
-  t["rieulkorean"] = 0x3139;
 
-  t["rieulmieumkorean"] = 0x313b;
 
-  t["rieulpansioskorean"] = 0x316c;
 
-  t["rieulparenkorean"] = 0x3203;
 
-  t["rieulphieuphkorean"] = 0x313f;
 
-  t["rieulpieupkorean"] = 0x313c;
 
-  t["rieulpieupsioskorean"] = 0x316b;
 
-  t["rieulsioskorean"] = 0x313d;
 
-  t["rieulthieuthkorean"] = 0x313e;
 
-  t["rieultikeutkorean"] = 0x316a;
 
-  t["rieulyeorinhieuhkorean"] = 0x316d;
 
-  t["rightangle"] = 0x221f;
 
-  t["righttackbelowcmb"] = 0x0319;
 
-  t["righttriangle"] = 0x22bf;
 
-  t["rihiragana"] = 0x308a;
 
-  t["rikatakana"] = 0x30ea;
 
-  t["rikatakanahalfwidth"] = 0xff98;
 
-  t["ring"] = 0x02da;
 
-  t["ringbelowcmb"] = 0x0325;
 
-  t["ringcmb"] = 0x030a;
 
-  t["ringhalfleft"] = 0x02bf;
 
-  t["ringhalfleftarmenian"] = 0x0559;
 
-  t["ringhalfleftbelowcmb"] = 0x031c;
 
-  t["ringhalfleftcentered"] = 0x02d3;
 
-  t["ringhalfright"] = 0x02be;
 
-  t["ringhalfrightbelowcmb"] = 0x0339;
 
-  t["ringhalfrightcentered"] = 0x02d2;
 
-  t["rinvertedbreve"] = 0x0213;
 
-  t["rittorusquare"] = 0x3351;
 
-  t["rlinebelow"] = 0x1e5f;
 
-  t["rlongleg"] = 0x027c;
 
-  t["rlonglegturned"] = 0x027a;
 
-  t["rmonospace"] = 0xff52;
 
-  t["rohiragana"] = 0x308d;
 
-  t["rokatakana"] = 0x30ed;
 
-  t["rokatakanahalfwidth"] = 0xff9b;
 
-  t["roruathai"] = 0x0e23;
 
-  t["rparen"] = 0x24ad;
 
-  t["rrabengali"] = 0x09dc;
 
-  t["rradeva"] = 0x0931;
 
-  t["rragurmukhi"] = 0x0a5c;
 
-  t["rreharabic"] = 0x0691;
 
-  t["rrehfinalarabic"] = 0xfb8d;
 
-  t["rrvocalicbengali"] = 0x09e0;
 
-  t["rrvocalicdeva"] = 0x0960;
 
-  t["rrvocalicgujarati"] = 0x0ae0;
 
-  t["rrvocalicvowelsignbengali"] = 0x09c4;
 
-  t["rrvocalicvowelsigndeva"] = 0x0944;
 
-  t["rrvocalicvowelsigngujarati"] = 0x0ac4;
 
-  t["rsuperior"] = 0xf6f1;
 
-  t["rtblock"] = 0x2590;
 
-  t["rturned"] = 0x0279;
 
-  t["rturnedsuperior"] = 0x02b4;
 
-  t["ruhiragana"] = 0x308b;
 
-  t["rukatakana"] = 0x30eb;
 
-  t["rukatakanahalfwidth"] = 0xff99;
 
-  t["rupeemarkbengali"] = 0x09f2;
 
-  t["rupeesignbengali"] = 0x09f3;
 
-  t["rupiah"] = 0xf6dd;
 
-  t["ruthai"] = 0x0e24;
 
-  t["rvocalicbengali"] = 0x098b;
 
-  t["rvocalicdeva"] = 0x090b;
 
-  t["rvocalicgujarati"] = 0x0a8b;
 
-  t["rvocalicvowelsignbengali"] = 0x09c3;
 
-  t["rvocalicvowelsigndeva"] = 0x0943;
 
-  t["rvocalicvowelsigngujarati"] = 0x0ac3;
 
-  t["s"] = 0x0073;
 
-  t["sabengali"] = 0x09b8;
 
-  t["sacute"] = 0x015b;
 
-  t["sacutedotaccent"] = 0x1e65;
 
-  t["sadarabic"] = 0x0635;
 
-  t["sadeva"] = 0x0938;
 
-  t["sadfinalarabic"] = 0xfeba;
 
-  t["sadinitialarabic"] = 0xfebb;
 
-  t["sadmedialarabic"] = 0xfebc;
 
-  t["sagujarati"] = 0x0ab8;
 
-  t["sagurmukhi"] = 0x0a38;
 
-  t["sahiragana"] = 0x3055;
 
-  t["sakatakana"] = 0x30b5;
 
-  t["sakatakanahalfwidth"] = 0xff7b;
 
-  t["sallallahoualayhewasallamarabic"] = 0xfdfa;
 
-  t["samekh"] = 0x05e1;
 
-  t["samekhdagesh"] = 0xfb41;
 
-  t["samekhdageshhebrew"] = 0xfb41;
 
-  t["samekhhebrew"] = 0x05e1;
 
-  t["saraaathai"] = 0x0e32;
 
-  t["saraaethai"] = 0x0e41;
 
-  t["saraaimaimalaithai"] = 0x0e44;
 
-  t["saraaimaimuanthai"] = 0x0e43;
 
-  t["saraamthai"] = 0x0e33;
 
-  t["saraathai"] = 0x0e30;
 
-  t["saraethai"] = 0x0e40;
 
-  t["saraiileftthai"] = 0xf886;
 
-  t["saraiithai"] = 0x0e35;
 
-  t["saraileftthai"] = 0xf885;
 
-  t["saraithai"] = 0x0e34;
 
-  t["saraothai"] = 0x0e42;
 
-  t["saraueeleftthai"] = 0xf888;
 
-  t["saraueethai"] = 0x0e37;
 
-  t["saraueleftthai"] = 0xf887;
 
-  t["sarauethai"] = 0x0e36;
 
-  t["sarauthai"] = 0x0e38;
 
-  t["sarauuthai"] = 0x0e39;
 
-  t["sbopomofo"] = 0x3119;
 
-  t["scaron"] = 0x0161;
 
-  t["scarondotaccent"] = 0x1e67;
 
-  t["scedilla"] = 0x015f;
 
-  t["schwa"] = 0x0259;
 
-  t["schwacyrillic"] = 0x04d9;
 
-  t["schwadieresiscyrillic"] = 0x04db;
 
-  t["schwahook"] = 0x025a;
 
-  t["scircle"] = 0x24e2;
 
-  t["scircumflex"] = 0x015d;
 
-  t["scommaaccent"] = 0x0219;
 
-  t["sdotaccent"] = 0x1e61;
 
-  t["sdotbelow"] = 0x1e63;
 
-  t["sdotbelowdotaccent"] = 0x1e69;
 
-  t["seagullbelowcmb"] = 0x033c;
 
-  t["second"] = 0x2033;
 
-  t["secondtonechinese"] = 0x02ca;
 
-  t["section"] = 0x00a7;
 
-  t["seenarabic"] = 0x0633;
 
-  t["seenfinalarabic"] = 0xfeb2;
 
-  t["seeninitialarabic"] = 0xfeb3;
 
-  t["seenmedialarabic"] = 0xfeb4;
 
-  t["segol"] = 0x05b6;
 
-  t["segol13"] = 0x05b6;
 
-  t["segol1f"] = 0x05b6;
 
-  t["segol2c"] = 0x05b6;
 
-  t["segolhebrew"] = 0x05b6;
 
-  t["segolnarrowhebrew"] = 0x05b6;
 
-  t["segolquarterhebrew"] = 0x05b6;
 
-  t["segoltahebrew"] = 0x0592;
 
-  t["segolwidehebrew"] = 0x05b6;
 
-  t["seharmenian"] = 0x057d;
 
-  t["sehiragana"] = 0x305b;
 
-  t["sekatakana"] = 0x30bb;
 
-  t["sekatakanahalfwidth"] = 0xff7e;
 
-  t["semicolon"] = 0x003b;
 
-  t["semicolonarabic"] = 0x061b;
 
-  t["semicolonmonospace"] = 0xff1b;
 
-  t["semicolonsmall"] = 0xfe54;
 
-  t["semivoicedmarkkana"] = 0x309c;
 
-  t["semivoicedmarkkanahalfwidth"] = 0xff9f;
 
-  t["sentisquare"] = 0x3322;
 
-  t["sentosquare"] = 0x3323;
 
-  t["seven"] = 0x0037;
 
-  t["sevenarabic"] = 0x0667;
 
-  t["sevenbengali"] = 0x09ed;
 
-  t["sevencircle"] = 0x2466;
 
-  t["sevencircleinversesansserif"] = 0x2790;
 
-  t["sevendeva"] = 0x096d;
 
-  t["seveneighths"] = 0x215e;
 
-  t["sevengujarati"] = 0x0aed;
 
-  t["sevengurmukhi"] = 0x0a6d;
 
-  t["sevenhackarabic"] = 0x0667;
 
-  t["sevenhangzhou"] = 0x3027;
 
-  t["sevenideographicparen"] = 0x3226;
 
-  t["seveninferior"] = 0x2087;
 
-  t["sevenmonospace"] = 0xff17;
 
-  t["sevenoldstyle"] = 0xf737;
 
-  t["sevenparen"] = 0x247a;
 
-  t["sevenperiod"] = 0x248e;
 
-  t["sevenpersian"] = 0x06f7;
 
-  t["sevenroman"] = 0x2176;
 
-  t["sevensuperior"] = 0x2077;
 
-  t["seventeencircle"] = 0x2470;
 
-  t["seventeenparen"] = 0x2484;
 
-  t["seventeenperiod"] = 0x2498;
 
-  t["seventhai"] = 0x0e57;
 
-  t["sfthyphen"] = 0x00ad;
 
-  t["shaarmenian"] = 0x0577;
 
-  t["shabengali"] = 0x09b6;
 
-  t["shacyrillic"] = 0x0448;
 
-  t["shaddaarabic"] = 0x0651;
 
-  t["shaddadammaarabic"] = 0xfc61;
 
-  t["shaddadammatanarabic"] = 0xfc5e;
 
-  t["shaddafathaarabic"] = 0xfc60;
 
-  t["shaddakasraarabic"] = 0xfc62;
 
-  t["shaddakasratanarabic"] = 0xfc5f;
 
-  t["shade"] = 0x2592;
 
-  t["shadedark"] = 0x2593;
 
-  t["shadelight"] = 0x2591;
 
-  t["shademedium"] = 0x2592;
 
-  t["shadeva"] = 0x0936;
 
-  t["shagujarati"] = 0x0ab6;
 
-  t["shagurmukhi"] = 0x0a36;
 
-  t["shalshelethebrew"] = 0x0593;
 
-  t["shbopomofo"] = 0x3115;
 
-  t["shchacyrillic"] = 0x0449;
 
-  t["sheenarabic"] = 0x0634;
 
-  t["sheenfinalarabic"] = 0xfeb6;
 
-  t["sheeninitialarabic"] = 0xfeb7;
 
-  t["sheenmedialarabic"] = 0xfeb8;
 
-  t["sheicoptic"] = 0x03e3;
 
-  t["sheqel"] = 0x20aa;
 
-  t["sheqelhebrew"] = 0x20aa;
 
-  t["sheva"] = 0x05b0;
 
-  t["sheva115"] = 0x05b0;
 
-  t["sheva15"] = 0x05b0;
 
-  t["sheva22"] = 0x05b0;
 
-  t["sheva2e"] = 0x05b0;
 
-  t["shevahebrew"] = 0x05b0;
 
-  t["shevanarrowhebrew"] = 0x05b0;
 
-  t["shevaquarterhebrew"] = 0x05b0;
 
-  t["shevawidehebrew"] = 0x05b0;
 
-  t["shhacyrillic"] = 0x04bb;
 
-  t["shimacoptic"] = 0x03ed;
 
-  t["shin"] = 0x05e9;
 
-  t["shindagesh"] = 0xfb49;
 
-  t["shindageshhebrew"] = 0xfb49;
 
-  t["shindageshshindot"] = 0xfb2c;
 
-  t["shindageshshindothebrew"] = 0xfb2c;
 
-  t["shindageshsindot"] = 0xfb2d;
 
-  t["shindageshsindothebrew"] = 0xfb2d;
 
-  t["shindothebrew"] = 0x05c1;
 
-  t["shinhebrew"] = 0x05e9;
 
-  t["shinshindot"] = 0xfb2a;
 
-  t["shinshindothebrew"] = 0xfb2a;
 
-  t["shinsindot"] = 0xfb2b;
 
-  t["shinsindothebrew"] = 0xfb2b;
 
-  t["shook"] = 0x0282;
 
-  t["sigma"] = 0x03c3;
 
-  t["sigma1"] = 0x03c2;
 
-  t["sigmafinal"] = 0x03c2;
 
-  t["sigmalunatesymbolgreek"] = 0x03f2;
 
-  t["sihiragana"] = 0x3057;
 
-  t["sikatakana"] = 0x30b7;
 
-  t["sikatakanahalfwidth"] = 0xff7c;
 
-  t["siluqhebrew"] = 0x05bd;
 
-  t["siluqlefthebrew"] = 0x05bd;
 
-  t["similar"] = 0x223c;
 
-  t["sindothebrew"] = 0x05c2;
 
-  t["siosacirclekorean"] = 0x3274;
 
-  t["siosaparenkorean"] = 0x3214;
 
-  t["sioscieuckorean"] = 0x317e;
 
-  t["sioscirclekorean"] = 0x3266;
 
-  t["sioskiyeokkorean"] = 0x317a;
 
-  t["sioskorean"] = 0x3145;
 
-  t["siosnieunkorean"] = 0x317b;
 
-  t["siosparenkorean"] = 0x3206;
 
-  t["siospieupkorean"] = 0x317d;
 
-  t["siostikeutkorean"] = 0x317c;
 
-  t["six"] = 0x0036;
 
-  t["sixarabic"] = 0x0666;
 
-  t["sixbengali"] = 0x09ec;
 
-  t["sixcircle"] = 0x2465;
 
-  t["sixcircleinversesansserif"] = 0x278f;
 
-  t["sixdeva"] = 0x096c;
 
-  t["sixgujarati"] = 0x0aec;
 
-  t["sixgurmukhi"] = 0x0a6c;
 
-  t["sixhackarabic"] = 0x0666;
 
-  t["sixhangzhou"] = 0x3026;
 
-  t["sixideographicparen"] = 0x3225;
 
-  t["sixinferior"] = 0x2086;
 
-  t["sixmonospace"] = 0xff16;
 
-  t["sixoldstyle"] = 0xf736;
 
-  t["sixparen"] = 0x2479;
 
-  t["sixperiod"] = 0x248d;
 
-  t["sixpersian"] = 0x06f6;
 
-  t["sixroman"] = 0x2175;
 
-  t["sixsuperior"] = 0x2076;
 
-  t["sixteencircle"] = 0x246f;
 
-  t["sixteencurrencydenominatorbengali"] = 0x09f9;
 
-  t["sixteenparen"] = 0x2483;
 
-  t["sixteenperiod"] = 0x2497;
 
-  t["sixthai"] = 0x0e56;
 
-  t["slash"] = 0x002f;
 
-  t["slashmonospace"] = 0xff0f;
 
-  t["slong"] = 0x017f;
 
-  t["slongdotaccent"] = 0x1e9b;
 
-  t["smileface"] = 0x263a;
 
-  t["smonospace"] = 0xff53;
 
-  t["sofpasuqhebrew"] = 0x05c3;
 
-  t["softhyphen"] = 0x00ad;
 
-  t["softsigncyrillic"] = 0x044c;
 
-  t["sohiragana"] = 0x305d;
 
-  t["sokatakana"] = 0x30bd;
 
-  t["sokatakanahalfwidth"] = 0xff7f;
 
-  t["soliduslongoverlaycmb"] = 0x0338;
 
-  t["solidusshortoverlaycmb"] = 0x0337;
 
-  t["sorusithai"] = 0x0e29;
 
-  t["sosalathai"] = 0x0e28;
 
-  t["sosothai"] = 0x0e0b;
 
-  t["sosuathai"] = 0x0e2a;
 
-  t["space"] = 0x0020;
 
-  t["spacehackarabic"] = 0x0020;
 
-  t["spade"] = 0x2660;
 
-  t["spadesuitblack"] = 0x2660;
 
-  t["spadesuitwhite"] = 0x2664;
 
-  t["sparen"] = 0x24ae;
 
-  t["squarebelowcmb"] = 0x033b;
 
-  t["squarecc"] = 0x33c4;
 
-  t["squarecm"] = 0x339d;
 
-  t["squarediagonalcrosshatchfill"] = 0x25a9;
 
-  t["squarehorizontalfill"] = 0x25a4;
 
-  t["squarekg"] = 0x338f;
 
-  t["squarekm"] = 0x339e;
 
-  t["squarekmcapital"] = 0x33ce;
 
-  t["squareln"] = 0x33d1;
 
-  t["squarelog"] = 0x33d2;
 
-  t["squaremg"] = 0x338e;
 
-  t["squaremil"] = 0x33d5;
 
-  t["squaremm"] = 0x339c;
 
-  t["squaremsquared"] = 0x33a1;
 
-  t["squareorthogonalcrosshatchfill"] = 0x25a6;
 
-  t["squareupperlefttolowerrightfill"] = 0x25a7;
 
-  t["squareupperrighttolowerleftfill"] = 0x25a8;
 
-  t["squareverticalfill"] = 0x25a5;
 
-  t["squarewhitewithsmallblack"] = 0x25a3;
 
-  t["srsquare"] = 0x33db;
 
-  t["ssabengali"] = 0x09b7;
 
-  t["ssadeva"] = 0x0937;
 
-  t["ssagujarati"] = 0x0ab7;
 
-  t["ssangcieuckorean"] = 0x3149;
 
-  t["ssanghieuhkorean"] = 0x3185;
 
-  t["ssangieungkorean"] = 0x3180;
 
-  t["ssangkiyeokkorean"] = 0x3132;
 
-  t["ssangnieunkorean"] = 0x3165;
 
-  t["ssangpieupkorean"] = 0x3143;
 
-  t["ssangsioskorean"] = 0x3146;
 
-  t["ssangtikeutkorean"] = 0x3138;
 
-  t["ssuperior"] = 0xf6f2;
 
-  t["sterling"] = 0x00a3;
 
-  t["sterlingmonospace"] = 0xffe1;
 
-  t["strokelongoverlaycmb"] = 0x0336;
 
-  t["strokeshortoverlaycmb"] = 0x0335;
 
-  t["subset"] = 0x2282;
 
-  t["subsetnotequal"] = 0x228a;
 
-  t["subsetorequal"] = 0x2286;
 
-  t["succeeds"] = 0x227b;
 
-  t["suchthat"] = 0x220b;
 
-  t["suhiragana"] = 0x3059;
 
-  t["sukatakana"] = 0x30b9;
 
-  t["sukatakanahalfwidth"] = 0xff7d;
 
-  t["sukunarabic"] = 0x0652;
 
-  t["summation"] = 0x2211;
 
-  t["sun"] = 0x263c;
 
-  t["superset"] = 0x2283;
 
-  t["supersetnotequal"] = 0x228b;
 
-  t["supersetorequal"] = 0x2287;
 
-  t["svsquare"] = 0x33dc;
 
-  t["syouwaerasquare"] = 0x337c;
 
-  t["t"] = 0x0074;
 
-  t["tabengali"] = 0x09a4;
 
-  t["tackdown"] = 0x22a4;
 
-  t["tackleft"] = 0x22a3;
 
-  t["tadeva"] = 0x0924;
 
-  t["tagujarati"] = 0x0aa4;
 
-  t["tagurmukhi"] = 0x0a24;
 
-  t["taharabic"] = 0x0637;
 
-  t["tahfinalarabic"] = 0xfec2;
 
-  t["tahinitialarabic"] = 0xfec3;
 
-  t["tahiragana"] = 0x305f;
 
-  t["tahmedialarabic"] = 0xfec4;
 
-  t["taisyouerasquare"] = 0x337d;
 
-  t["takatakana"] = 0x30bf;
 
-  t["takatakanahalfwidth"] = 0xff80;
 
-  t["tatweelarabic"] = 0x0640;
 
-  t["tau"] = 0x03c4;
 
-  t["tav"] = 0x05ea;
 
-  t["tavdages"] = 0xfb4a;
 
-  t["tavdagesh"] = 0xfb4a;
 
-  t["tavdageshhebrew"] = 0xfb4a;
 
-  t["tavhebrew"] = 0x05ea;
 
-  t["tbar"] = 0x0167;
 
-  t["tbopomofo"] = 0x310a;
 
-  t["tcaron"] = 0x0165;
 
-  t["tccurl"] = 0x02a8;
 
-  t["tcedilla"] = 0x0163;
 
-  t["tcheharabic"] = 0x0686;
 
-  t["tchehfinalarabic"] = 0xfb7b;
 
-  t["tchehinitialarabic"] = 0xfb7c;
 
-  t["tchehmedialarabic"] = 0xfb7d;
 
-  t["tcircle"] = 0x24e3;
 
-  t["tcircumflexbelow"] = 0x1e71;
 
-  t["tcommaaccent"] = 0x0163;
 
-  t["tdieresis"] = 0x1e97;
 
-  t["tdotaccent"] = 0x1e6b;
 
-  t["tdotbelow"] = 0x1e6d;
 
-  t["tecyrillic"] = 0x0442;
 
-  t["tedescendercyrillic"] = 0x04ad;
 
-  t["teharabic"] = 0x062a;
 
-  t["tehfinalarabic"] = 0xfe96;
 
-  t["tehhahinitialarabic"] = 0xfca2;
 
-  t["tehhahisolatedarabic"] = 0xfc0c;
 
-  t["tehinitialarabic"] = 0xfe97;
 
-  t["tehiragana"] = 0x3066;
 
-  t["tehjeeminitialarabic"] = 0xfca1;
 
-  t["tehjeemisolatedarabic"] = 0xfc0b;
 
-  t["tehmarbutaarabic"] = 0x0629;
 
-  t["tehmarbutafinalarabic"] = 0xfe94;
 
-  t["tehmedialarabic"] = 0xfe98;
 
-  t["tehmeeminitialarabic"] = 0xfca4;
 
-  t["tehmeemisolatedarabic"] = 0xfc0e;
 
-  t["tehnoonfinalarabic"] = 0xfc73;
 
-  t["tekatakana"] = 0x30c6;
 
-  t["tekatakanahalfwidth"] = 0xff83;
 
-  t["telephone"] = 0x2121;
 
-  t["telephoneblack"] = 0x260e;
 
-  t["telishagedolahebrew"] = 0x05a0;
 
-  t["telishaqetanahebrew"] = 0x05a9;
 
-  t["tencircle"] = 0x2469;
 
-  t["tenideographicparen"] = 0x3229;
 
-  t["tenparen"] = 0x247d;
 
-  t["tenperiod"] = 0x2491;
 
-  t["tenroman"] = 0x2179;
 
-  t["tesh"] = 0x02a7;
 
-  t["tet"] = 0x05d8;
 
-  t["tetdagesh"] = 0xfb38;
 
-  t["tetdageshhebrew"] = 0xfb38;
 
-  t["tethebrew"] = 0x05d8;
 
-  t["tetsecyrillic"] = 0x04b5;
 
-  t["tevirhebrew"] = 0x059b;
 
-  t["tevirlefthebrew"] = 0x059b;
 
-  t["thabengali"] = 0x09a5;
 
-  t["thadeva"] = 0x0925;
 
-  t["thagujarati"] = 0x0aa5;
 
-  t["thagurmukhi"] = 0x0a25;
 
-  t["thalarabic"] = 0x0630;
 
-  t["thalfinalarabic"] = 0xfeac;
 
-  t["thanthakhatlowleftthai"] = 0xf898;
 
-  t["thanthakhatlowrightthai"] = 0xf897;
 
-  t["thanthakhatthai"] = 0x0e4c;
 
-  t["thanthakhatupperleftthai"] = 0xf896;
 
-  t["theharabic"] = 0x062b;
 
-  t["thehfinalarabic"] = 0xfe9a;
 
-  t["thehinitialarabic"] = 0xfe9b;
 
-  t["thehmedialarabic"] = 0xfe9c;
 
-  t["thereexists"] = 0x2203;
 
-  t["therefore"] = 0x2234;
 
-  t["theta"] = 0x03b8;
 
-  t["theta1"] = 0x03d1;
 
-  t["thetasymbolgreek"] = 0x03d1;
 
-  t["thieuthacirclekorean"] = 0x3279;
 
-  t["thieuthaparenkorean"] = 0x3219;
 
-  t["thieuthcirclekorean"] = 0x326b;
 
-  t["thieuthkorean"] = 0x314c;
 
-  t["thieuthparenkorean"] = 0x320b;
 
-  t["thirteencircle"] = 0x246c;
 
-  t["thirteenparen"] = 0x2480;
 
-  t["thirteenperiod"] = 0x2494;
 
-  t["thonangmonthothai"] = 0x0e11;
 
-  t["thook"] = 0x01ad;
 
-  t["thophuthaothai"] = 0x0e12;
 
-  t["thorn"] = 0x00fe;
 
-  t["thothahanthai"] = 0x0e17;
 
-  t["thothanthai"] = 0x0e10;
 
-  t["thothongthai"] = 0x0e18;
 
-  t["thothungthai"] = 0x0e16;
 
-  t["thousandcyrillic"] = 0x0482;
 
-  t["thousandsseparatorarabic"] = 0x066c;
 
-  t["thousandsseparatorpersian"] = 0x066c;
 
-  t["three"] = 0x0033;
 
-  t["threearabic"] = 0x0663;
 
-  t["threebengali"] = 0x09e9;
 
-  t["threecircle"] = 0x2462;
 
-  t["threecircleinversesansserif"] = 0x278c;
 
-  t["threedeva"] = 0x0969;
 
-  t["threeeighths"] = 0x215c;
 
-  t["threegujarati"] = 0x0ae9;
 
-  t["threegurmukhi"] = 0x0a69;
 
-  t["threehackarabic"] = 0x0663;
 
-  t["threehangzhou"] = 0x3023;
 
-  t["threeideographicparen"] = 0x3222;
 
-  t["threeinferior"] = 0x2083;
 
-  t["threemonospace"] = 0xff13;
 
-  t["threenumeratorbengali"] = 0x09f6;
 
-  t["threeoldstyle"] = 0xf733;
 
-  t["threeparen"] = 0x2476;
 
-  t["threeperiod"] = 0x248a;
 
-  t["threepersian"] = 0x06f3;
 
-  t["threequarters"] = 0x00be;
 
-  t["threequartersemdash"] = 0xf6de;
 
-  t["threeroman"] = 0x2172;
 
-  t["threesuperior"] = 0x00b3;
 
-  t["threethai"] = 0x0e53;
 
-  t["thzsquare"] = 0x3394;
 
-  t["tihiragana"] = 0x3061;
 
-  t["tikatakana"] = 0x30c1;
 
-  t["tikatakanahalfwidth"] = 0xff81;
 
-  t["tikeutacirclekorean"] = 0x3270;
 
-  t["tikeutaparenkorean"] = 0x3210;
 
-  t["tikeutcirclekorean"] = 0x3262;
 
-  t["tikeutkorean"] = 0x3137;
 
-  t["tikeutparenkorean"] = 0x3202;
 
-  t["tilde"] = 0x02dc;
 
-  t["tildebelowcmb"] = 0x0330;
 
-  t["tildecmb"] = 0x0303;
 
-  t["tildecomb"] = 0x0303;
 
-  t["tildedoublecmb"] = 0x0360;
 
-  t["tildeoperator"] = 0x223c;
 
-  t["tildeoverlaycmb"] = 0x0334;
 
-  t["tildeverticalcmb"] = 0x033e;
 
-  t["timescircle"] = 0x2297;
 
-  t["tipehahebrew"] = 0x0596;
 
-  t["tipehalefthebrew"] = 0x0596;
 
-  t["tippigurmukhi"] = 0x0a70;
 
-  t["titlocyrilliccmb"] = 0x0483;
 
-  t["tiwnarmenian"] = 0x057f;
 
-  t["tlinebelow"] = 0x1e6f;
 
-  t["tmonospace"] = 0xff54;
 
-  t["toarmenian"] = 0x0569;
 
-  t["tohiragana"] = 0x3068;
 
-  t["tokatakana"] = 0x30c8;
 
-  t["tokatakanahalfwidth"] = 0xff84;
 
-  t["tonebarextrahighmod"] = 0x02e5;
 
-  t["tonebarextralowmod"] = 0x02e9;
 
-  t["tonebarhighmod"] = 0x02e6;
 
-  t["tonebarlowmod"] = 0x02e8;
 
-  t["tonebarmidmod"] = 0x02e7;
 
-  t["tonefive"] = 0x01bd;
 
-  t["tonesix"] = 0x0185;
 
-  t["tonetwo"] = 0x01a8;
 
-  t["tonos"] = 0x0384;
 
-  t["tonsquare"] = 0x3327;
 
-  t["topatakthai"] = 0x0e0f;
 
-  t["tortoiseshellbracketleft"] = 0x3014;
 
-  t["tortoiseshellbracketleftsmall"] = 0xfe5d;
 
-  t["tortoiseshellbracketleftvertical"] = 0xfe39;
 
-  t["tortoiseshellbracketright"] = 0x3015;
 
-  t["tortoiseshellbracketrightsmall"] = 0xfe5e;
 
-  t["tortoiseshellbracketrightvertical"] = 0xfe3a;
 
-  t["totaothai"] = 0x0e15;
 
-  t["tpalatalhook"] = 0x01ab;
 
-  t["tparen"] = 0x24af;
 
-  t["trademark"] = 0x2122;
 
-  t["trademarksans"] = 0xf8ea;
 
-  t["trademarkserif"] = 0xf6db;
 
-  t["tretroflexhook"] = 0x0288;
 
-  t["triagdn"] = 0x25bc;
 
-  t["triaglf"] = 0x25c4;
 
-  t["triagrt"] = 0x25ba;
 
-  t["triagup"] = 0x25b2;
 
-  t["ts"] = 0x02a6;
 
-  t["tsadi"] = 0x05e6;
 
-  t["tsadidagesh"] = 0xfb46;
 
-  t["tsadidageshhebrew"] = 0xfb46;
 
-  t["tsadihebrew"] = 0x05e6;
 
-  t["tsecyrillic"] = 0x0446;
 
-  t["tsere"] = 0x05b5;
 
-  t["tsere12"] = 0x05b5;
 
-  t["tsere1e"] = 0x05b5;
 
-  t["tsere2b"] = 0x05b5;
 
-  t["tserehebrew"] = 0x05b5;
 
-  t["tserenarrowhebrew"] = 0x05b5;
 
-  t["tserequarterhebrew"] = 0x05b5;
 
-  t["tserewidehebrew"] = 0x05b5;
 
-  t["tshecyrillic"] = 0x045b;
 
-  t["tsuperior"] = 0xf6f3;
 
-  t["ttabengali"] = 0x099f;
 
-  t["ttadeva"] = 0x091f;
 
-  t["ttagujarati"] = 0x0a9f;
 
-  t["ttagurmukhi"] = 0x0a1f;
 
-  t["tteharabic"] = 0x0679;
 
-  t["ttehfinalarabic"] = 0xfb67;
 
-  t["ttehinitialarabic"] = 0xfb68;
 
-  t["ttehmedialarabic"] = 0xfb69;
 
-  t["tthabengali"] = 0x09a0;
 
-  t["tthadeva"] = 0x0920;
 
-  t["tthagujarati"] = 0x0aa0;
 
-  t["tthagurmukhi"] = 0x0a20;
 
-  t["tturned"] = 0x0287;
 
-  t["tuhiragana"] = 0x3064;
 
-  t["tukatakana"] = 0x30c4;
 
-  t["tukatakanahalfwidth"] = 0xff82;
 
-  t["tusmallhiragana"] = 0x3063;
 
-  t["tusmallkatakana"] = 0x30c3;
 
-  t["tusmallkatakanahalfwidth"] = 0xff6f;
 
-  t["twelvecircle"] = 0x246b;
 
-  t["twelveparen"] = 0x247f;
 
-  t["twelveperiod"] = 0x2493;
 
-  t["twelveroman"] = 0x217b;
 
-  t["twentycircle"] = 0x2473;
 
-  t["twentyhangzhou"] = 0x5344;
 
-  t["twentyparen"] = 0x2487;
 
-  t["twentyperiod"] = 0x249b;
 
-  t["two"] = 0x0032;
 
-  t["twoarabic"] = 0x0662;
 
-  t["twobengali"] = 0x09e8;
 
-  t["twocircle"] = 0x2461;
 
-  t["twocircleinversesansserif"] = 0x278b;
 
-  t["twodeva"] = 0x0968;
 
-  t["twodotenleader"] = 0x2025;
 
-  t["twodotleader"] = 0x2025;
 
-  t["twodotleadervertical"] = 0xfe30;
 
-  t["twogujarati"] = 0x0ae8;
 
-  t["twogurmukhi"] = 0x0a68;
 
-  t["twohackarabic"] = 0x0662;
 
-  t["twohangzhou"] = 0x3022;
 
-  t["twoideographicparen"] = 0x3221;
 
-  t["twoinferior"] = 0x2082;
 
-  t["twomonospace"] = 0xff12;
 
-  t["twonumeratorbengali"] = 0x09f5;
 
-  t["twooldstyle"] = 0xf732;
 
-  t["twoparen"] = 0x2475;
 
-  t["twoperiod"] = 0x2489;
 
-  t["twopersian"] = 0x06f2;
 
-  t["tworoman"] = 0x2171;
 
-  t["twostroke"] = 0x01bb;
 
-  t["twosuperior"] = 0x00b2;
 
-  t["twothai"] = 0x0e52;
 
-  t["twothirds"] = 0x2154;
 
-  t["u"] = 0x0075;
 
-  t["uacute"] = 0x00fa;
 
-  t["ubar"] = 0x0289;
 
-  t["ubengali"] = 0x0989;
 
-  t["ubopomofo"] = 0x3128;
 
-  t["ubreve"] = 0x016d;
 
-  t["ucaron"] = 0x01d4;
 
-  t["ucircle"] = 0x24e4;
 
-  t["ucircumflex"] = 0x00fb;
 
-  t["ucircumflexbelow"] = 0x1e77;
 
-  t["ucyrillic"] = 0x0443;
 
-  t["udattadeva"] = 0x0951;
 
-  t["udblacute"] = 0x0171;
 
-  t["udblgrave"] = 0x0215;
 
-  t["udeva"] = 0x0909;
 
-  t["udieresis"] = 0x00fc;
 
-  t["udieresisacute"] = 0x01d8;
 
-  t["udieresisbelow"] = 0x1e73;
 
-  t["udieresiscaron"] = 0x01da;
 
-  t["udieresiscyrillic"] = 0x04f1;
 
-  t["udieresisgrave"] = 0x01dc;
 
-  t["udieresismacron"] = 0x01d6;
 
-  t["udotbelow"] = 0x1ee5;
 
-  t["ugrave"] = 0x00f9;
 
-  t["ugujarati"] = 0x0a89;
 
-  t["ugurmukhi"] = 0x0a09;
 
-  t["uhiragana"] = 0x3046;
 
-  t["uhookabove"] = 0x1ee7;
 
-  t["uhorn"] = 0x01b0;
 
-  t["uhornacute"] = 0x1ee9;
 
-  t["uhorndotbelow"] = 0x1ef1;
 
-  t["uhorngrave"] = 0x1eeb;
 
-  t["uhornhookabove"] = 0x1eed;
 
-  t["uhorntilde"] = 0x1eef;
 
-  t["uhungarumlaut"] = 0x0171;
 
-  t["uhungarumlautcyrillic"] = 0x04f3;
 
-  t["uinvertedbreve"] = 0x0217;
 
-  t["ukatakana"] = 0x30a6;
 
-  t["ukatakanahalfwidth"] = 0xff73;
 
-  t["ukcyrillic"] = 0x0479;
 
-  t["ukorean"] = 0x315c;
 
-  t["umacron"] = 0x016b;
 
-  t["umacroncyrillic"] = 0x04ef;
 
-  t["umacrondieresis"] = 0x1e7b;
 
-  t["umatragurmukhi"] = 0x0a41;
 
-  t["umonospace"] = 0xff55;
 
-  t["underscore"] = 0x005f;
 
-  t["underscoredbl"] = 0x2017;
 
-  t["underscoremonospace"] = 0xff3f;
 
-  t["underscorevertical"] = 0xfe33;
 
-  t["underscorewavy"] = 0xfe4f;
 
-  t["union"] = 0x222a;
 
-  t["universal"] = 0x2200;
 
-  t["uogonek"] = 0x0173;
 
-  t["uparen"] = 0x24b0;
 
-  t["upblock"] = 0x2580;
 
-  t["upperdothebrew"] = 0x05c4;
 
-  t["upsilon"] = 0x03c5;
 
-  t["upsilondieresis"] = 0x03cb;
 
-  t["upsilondieresistonos"] = 0x03b0;
 
-  t["upsilonlatin"] = 0x028a;
 
-  t["upsilontonos"] = 0x03cd;
 
-  t["uptackbelowcmb"] = 0x031d;
 
-  t["uptackmod"] = 0x02d4;
 
-  t["uragurmukhi"] = 0x0a73;
 
-  t["uring"] = 0x016f;
 
-  t["ushortcyrillic"] = 0x045e;
 
-  t["usmallhiragana"] = 0x3045;
 
-  t["usmallkatakana"] = 0x30a5;
 
-  t["usmallkatakanahalfwidth"] = 0xff69;
 
-  t["ustraightcyrillic"] = 0x04af;
 
-  t["ustraightstrokecyrillic"] = 0x04b1;
 
-  t["utilde"] = 0x0169;
 
-  t["utildeacute"] = 0x1e79;
 
-  t["utildebelow"] = 0x1e75;
 
-  t["uubengali"] = 0x098a;
 
-  t["uudeva"] = 0x090a;
 
-  t["uugujarati"] = 0x0a8a;
 
-  t["uugurmukhi"] = 0x0a0a;
 
-  t["uumatragurmukhi"] = 0x0a42;
 
-  t["uuvowelsignbengali"] = 0x09c2;
 
-  t["uuvowelsigndeva"] = 0x0942;
 
-  t["uuvowelsigngujarati"] = 0x0ac2;
 
-  t["uvowelsignbengali"] = 0x09c1;
 
-  t["uvowelsigndeva"] = 0x0941;
 
-  t["uvowelsigngujarati"] = 0x0ac1;
 
-  t["v"] = 0x0076;
 
-  t["vadeva"] = 0x0935;
 
-  t["vagujarati"] = 0x0ab5;
 
-  t["vagurmukhi"] = 0x0a35;
 
-  t["vakatakana"] = 0x30f7;
 
-  t["vav"] = 0x05d5;
 
-  t["vavdagesh"] = 0xfb35;
 
-  t["vavdagesh65"] = 0xfb35;
 
-  t["vavdageshhebrew"] = 0xfb35;
 
-  t["vavhebrew"] = 0x05d5;
 
-  t["vavholam"] = 0xfb4b;
 
-  t["vavholamhebrew"] = 0xfb4b;
 
-  t["vavvavhebrew"] = 0x05f0;
 
-  t["vavyodhebrew"] = 0x05f1;
 
-  t["vcircle"] = 0x24e5;
 
-  t["vdotbelow"] = 0x1e7f;
 
-  t["vecyrillic"] = 0x0432;
 
-  t["veharabic"] = 0x06a4;
 
-  t["vehfinalarabic"] = 0xfb6b;
 
-  t["vehinitialarabic"] = 0xfb6c;
 
-  t["vehmedialarabic"] = 0xfb6d;
 
-  t["vekatakana"] = 0x30f9;
 
-  t["venus"] = 0x2640;
 
-  t["verticalbar"] = 0x007c;
 
-  t["verticallineabovecmb"] = 0x030d;
 
-  t["verticallinebelowcmb"] = 0x0329;
 
-  t["verticallinelowmod"] = 0x02cc;
 
-  t["verticallinemod"] = 0x02c8;
 
-  t["vewarmenian"] = 0x057e;
 
-  t["vhook"] = 0x028b;
 
-  t["vikatakana"] = 0x30f8;
 
-  t["viramabengali"] = 0x09cd;
 
-  t["viramadeva"] = 0x094d;
 
-  t["viramagujarati"] = 0x0acd;
 
-  t["visargabengali"] = 0x0983;
 
-  t["visargadeva"] = 0x0903;
 
-  t["visargagujarati"] = 0x0a83;
 
-  t["vmonospace"] = 0xff56;
 
-  t["voarmenian"] = 0x0578;
 
-  t["voicediterationhiragana"] = 0x309e;
 
-  t["voicediterationkatakana"] = 0x30fe;
 
-  t["voicedmarkkana"] = 0x309b;
 
-  t["voicedmarkkanahalfwidth"] = 0xff9e;
 
-  t["vokatakana"] = 0x30fa;
 
-  t["vparen"] = 0x24b1;
 
-  t["vtilde"] = 0x1e7d;
 
-  t["vturned"] = 0x028c;
 
-  t["vuhiragana"] = 0x3094;
 
-  t["vukatakana"] = 0x30f4;
 
-  t["w"] = 0x0077;
 
-  t["wacute"] = 0x1e83;
 
-  t["waekorean"] = 0x3159;
 
-  t["wahiragana"] = 0x308f;
 
-  t["wakatakana"] = 0x30ef;
 
-  t["wakatakanahalfwidth"] = 0xff9c;
 
-  t["wakorean"] = 0x3158;
 
-  t["wasmallhiragana"] = 0x308e;
 
-  t["wasmallkatakana"] = 0x30ee;
 
-  t["wattosquare"] = 0x3357;
 
-  t["wavedash"] = 0x301c;
 
-  t["wavyunderscorevertical"] = 0xfe34;
 
-  t["wawarabic"] = 0x0648;
 
-  t["wawfinalarabic"] = 0xfeee;
 
-  t["wawhamzaabovearabic"] = 0x0624;
 
-  t["wawhamzaabovefinalarabic"] = 0xfe86;
 
-  t["wbsquare"] = 0x33dd;
 
-  t["wcircle"] = 0x24e6;
 
-  t["wcircumflex"] = 0x0175;
 
-  t["wdieresis"] = 0x1e85;
 
-  t["wdotaccent"] = 0x1e87;
 
-  t["wdotbelow"] = 0x1e89;
 
-  t["wehiragana"] = 0x3091;
 
-  t["weierstrass"] = 0x2118;
 
-  t["wekatakana"] = 0x30f1;
 
-  t["wekorean"] = 0x315e;
 
-  t["weokorean"] = 0x315d;
 
-  t["wgrave"] = 0x1e81;
 
-  t["whitebullet"] = 0x25e6;
 
-  t["whitecircle"] = 0x25cb;
 
-  t["whitecircleinverse"] = 0x25d9;
 
-  t["whitecornerbracketleft"] = 0x300e;
 
-  t["whitecornerbracketleftvertical"] = 0xfe43;
 
-  t["whitecornerbracketright"] = 0x300f;
 
-  t["whitecornerbracketrightvertical"] = 0xfe44;
 
-  t["whitediamond"] = 0x25c7;
 
-  t["whitediamondcontainingblacksmalldiamond"] = 0x25c8;
 
-  t["whitedownpointingsmalltriangle"] = 0x25bf;
 
-  t["whitedownpointingtriangle"] = 0x25bd;
 
-  t["whiteleftpointingsmalltriangle"] = 0x25c3;
 
-  t["whiteleftpointingtriangle"] = 0x25c1;
 
-  t["whitelenticularbracketleft"] = 0x3016;
 
-  t["whitelenticularbracketright"] = 0x3017;
 
-  t["whiterightpointingsmalltriangle"] = 0x25b9;
 
-  t["whiterightpointingtriangle"] = 0x25b7;
 
-  t["whitesmallsquare"] = 0x25ab;
 
-  t["whitesmilingface"] = 0x263a;
 
-  t["whitesquare"] = 0x25a1;
 
-  t["whitestar"] = 0x2606;
 
-  t["whitetelephone"] = 0x260f;
 
-  t["whitetortoiseshellbracketleft"] = 0x3018;
 
-  t["whitetortoiseshellbracketright"] = 0x3019;
 
-  t["whiteuppointingsmalltriangle"] = 0x25b5;
 
-  t["whiteuppointingtriangle"] = 0x25b3;
 
-  t["wihiragana"] = 0x3090;
 
-  t["wikatakana"] = 0x30f0;
 
-  t["wikorean"] = 0x315f;
 
-  t["wmonospace"] = 0xff57;
 
-  t["wohiragana"] = 0x3092;
 
-  t["wokatakana"] = 0x30f2;
 
-  t["wokatakanahalfwidth"] = 0xff66;
 
-  t["won"] = 0x20a9;
 
-  t["wonmonospace"] = 0xffe6;
 
-  t["wowaenthai"] = 0x0e27;
 
-  t["wparen"] = 0x24b2;
 
-  t["wring"] = 0x1e98;
 
-  t["wsuperior"] = 0x02b7;
 
-  t["wturned"] = 0x028d;
 
-  t["wynn"] = 0x01bf;
 
-  t["x"] = 0x0078;
 
-  t["xabovecmb"] = 0x033d;
 
-  t["xbopomofo"] = 0x3112;
 
-  t["xcircle"] = 0x24e7;
 
-  t["xdieresis"] = 0x1e8d;
 
-  t["xdotaccent"] = 0x1e8b;
 
-  t["xeharmenian"] = 0x056d;
 
-  t["xi"] = 0x03be;
 
-  t["xmonospace"] = 0xff58;
 
-  t["xparen"] = 0x24b3;
 
-  t["xsuperior"] = 0x02e3;
 
-  t["y"] = 0x0079;
 
-  t["yaadosquare"] = 0x334e;
 
-  t["yabengali"] = 0x09af;
 
-  t["yacute"] = 0x00fd;
 
-  t["yadeva"] = 0x092f;
 
-  t["yaekorean"] = 0x3152;
 
-  t["yagujarati"] = 0x0aaf;
 
-  t["yagurmukhi"] = 0x0a2f;
 
-  t["yahiragana"] = 0x3084;
 
-  t["yakatakana"] = 0x30e4;
 
-  t["yakatakanahalfwidth"] = 0xff94;
 
-  t["yakorean"] = 0x3151;
 
-  t["yamakkanthai"] = 0x0e4e;
 
-  t["yasmallhiragana"] = 0x3083;
 
-  t["yasmallkatakana"] = 0x30e3;
 
-  t["yasmallkatakanahalfwidth"] = 0xff6c;
 
-  t["yatcyrillic"] = 0x0463;
 
-  t["ycircle"] = 0x24e8;
 
-  t["ycircumflex"] = 0x0177;
 
-  t["ydieresis"] = 0x00ff;
 
-  t["ydotaccent"] = 0x1e8f;
 
-  t["ydotbelow"] = 0x1ef5;
 
-  t["yeharabic"] = 0x064a;
 
-  t["yehbarreearabic"] = 0x06d2;
 
-  t["yehbarreefinalarabic"] = 0xfbaf;
 
-  t["yehfinalarabic"] = 0xfef2;
 
-  t["yehhamzaabovearabic"] = 0x0626;
 
-  t["yehhamzaabovefinalarabic"] = 0xfe8a;
 
-  t["yehhamzaaboveinitialarabic"] = 0xfe8b;
 
-  t["yehhamzaabovemedialarabic"] = 0xfe8c;
 
-  t["yehinitialarabic"] = 0xfef3;
 
-  t["yehmedialarabic"] = 0xfef4;
 
-  t["yehmeeminitialarabic"] = 0xfcdd;
 
-  t["yehmeemisolatedarabic"] = 0xfc58;
 
-  t["yehnoonfinalarabic"] = 0xfc94;
 
-  t["yehthreedotsbelowarabic"] = 0x06d1;
 
-  t["yekorean"] = 0x3156;
 
-  t["yen"] = 0x00a5;
 
-  t["yenmonospace"] = 0xffe5;
 
-  t["yeokorean"] = 0x3155;
 
-  t["yeorinhieuhkorean"] = 0x3186;
 
-  t["yerahbenyomohebrew"] = 0x05aa;
 
-  t["yerahbenyomolefthebrew"] = 0x05aa;
 
-  t["yericyrillic"] = 0x044b;
 
-  t["yerudieresiscyrillic"] = 0x04f9;
 
-  t["yesieungkorean"] = 0x3181;
 
-  t["yesieungpansioskorean"] = 0x3183;
 
-  t["yesieungsioskorean"] = 0x3182;
 
-  t["yetivhebrew"] = 0x059a;
 
-  t["ygrave"] = 0x1ef3;
 
-  t["yhook"] = 0x01b4;
 
-  t["yhookabove"] = 0x1ef7;
 
-  t["yiarmenian"] = 0x0575;
 
-  t["yicyrillic"] = 0x0457;
 
-  t["yikorean"] = 0x3162;
 
-  t["yinyang"] = 0x262f;
 
-  t["yiwnarmenian"] = 0x0582;
 
-  t["ymonospace"] = 0xff59;
 
-  t["yod"] = 0x05d9;
 
-  t["yoddagesh"] = 0xfb39;
 
-  t["yoddageshhebrew"] = 0xfb39;
 
-  t["yodhebrew"] = 0x05d9;
 
-  t["yodyodhebrew"] = 0x05f2;
 
-  t["yodyodpatahhebrew"] = 0xfb1f;
 
-  t["yohiragana"] = 0x3088;
 
-  t["yoikorean"] = 0x3189;
 
-  t["yokatakana"] = 0x30e8;
 
-  t["yokatakanahalfwidth"] = 0xff96;
 
-  t["yokorean"] = 0x315b;
 
-  t["yosmallhiragana"] = 0x3087;
 
-  t["yosmallkatakana"] = 0x30e7;
 
-  t["yosmallkatakanahalfwidth"] = 0xff6e;
 
-  t["yotgreek"] = 0x03f3;
 
-  t["yoyaekorean"] = 0x3188;
 
-  t["yoyakorean"] = 0x3187;
 
-  t["yoyakthai"] = 0x0e22;
 
-  t["yoyingthai"] = 0x0e0d;
 
-  t["yparen"] = 0x24b4;
 
-  t["ypogegrammeni"] = 0x037a;
 
-  t["ypogegrammenigreekcmb"] = 0x0345;
 
-  t["yr"] = 0x01a6;
 
-  t["yring"] = 0x1e99;
 
-  t["ysuperior"] = 0x02b8;
 
-  t["ytilde"] = 0x1ef9;
 
-  t["yturned"] = 0x028e;
 
-  t["yuhiragana"] = 0x3086;
 
-  t["yuikorean"] = 0x318c;
 
-  t["yukatakana"] = 0x30e6;
 
-  t["yukatakanahalfwidth"] = 0xff95;
 
-  t["yukorean"] = 0x3160;
 
-  t["yusbigcyrillic"] = 0x046b;
 
-  t["yusbigiotifiedcyrillic"] = 0x046d;
 
-  t["yuslittlecyrillic"] = 0x0467;
 
-  t["yuslittleiotifiedcyrillic"] = 0x0469;
 
-  t["yusmallhiragana"] = 0x3085;
 
-  t["yusmallkatakana"] = 0x30e5;
 
-  t["yusmallkatakanahalfwidth"] = 0xff6d;
 
-  t["yuyekorean"] = 0x318b;
 
-  t["yuyeokorean"] = 0x318a;
 
-  t["yyabengali"] = 0x09df;
 
-  t["yyadeva"] = 0x095f;
 
-  t["z"] = 0x007a;
 
-  t["zaarmenian"] = 0x0566;
 
-  t["zacute"] = 0x017a;
 
-  t["zadeva"] = 0x095b;
 
-  t["zagurmukhi"] = 0x0a5b;
 
-  t["zaharabic"] = 0x0638;
 
-  t["zahfinalarabic"] = 0xfec6;
 
-  t["zahinitialarabic"] = 0xfec7;
 
-  t["zahiragana"] = 0x3056;
 
-  t["zahmedialarabic"] = 0xfec8;
 
-  t["zainarabic"] = 0x0632;
 
-  t["zainfinalarabic"] = 0xfeb0;
 
-  t["zakatakana"] = 0x30b6;
 
-  t["zaqefgadolhebrew"] = 0x0595;
 
-  t["zaqefqatanhebrew"] = 0x0594;
 
-  t["zarqahebrew"] = 0x0598;
 
-  t["zayin"] = 0x05d6;
 
-  t["zayindagesh"] = 0xfb36;
 
-  t["zayindageshhebrew"] = 0xfb36;
 
-  t["zayinhebrew"] = 0x05d6;
 
-  t["zbopomofo"] = 0x3117;
 
-  t["zcaron"] = 0x017e;
 
-  t["zcircle"] = 0x24e9;
 
-  t["zcircumflex"] = 0x1e91;
 
-  t["zcurl"] = 0x0291;
 
-  t["zdot"] = 0x017c;
 
-  t["zdotaccent"] = 0x017c;
 
-  t["zdotbelow"] = 0x1e93;
 
-  t["zecyrillic"] = 0x0437;
 
-  t["zedescendercyrillic"] = 0x0499;
 
-  t["zedieresiscyrillic"] = 0x04df;
 
-  t["zehiragana"] = 0x305c;
 
-  t["zekatakana"] = 0x30bc;
 
-  t["zero"] = 0x0030;
 
-  t["zeroarabic"] = 0x0660;
 
-  t["zerobengali"] = 0x09e6;
 
-  t["zerodeva"] = 0x0966;
 
-  t["zerogujarati"] = 0x0ae6;
 
-  t["zerogurmukhi"] = 0x0a66;
 
-  t["zerohackarabic"] = 0x0660;
 
-  t["zeroinferior"] = 0x2080;
 
-  t["zeromonospace"] = 0xff10;
 
-  t["zerooldstyle"] = 0xf730;
 
-  t["zeropersian"] = 0x06f0;
 
-  t["zerosuperior"] = 0x2070;
 
-  t["zerothai"] = 0x0e50;
 
-  t["zerowidthjoiner"] = 0xfeff;
 
-  t["zerowidthnonjoiner"] = 0x200c;
 
-  t["zerowidthspace"] = 0x200b;
 
-  t["zeta"] = 0x03b6;
 
-  t["zhbopomofo"] = 0x3113;
 
-  t["zhearmenian"] = 0x056a;
 
-  t["zhebrevecyrillic"] = 0x04c2;
 
-  t["zhecyrillic"] = 0x0436;
 
-  t["zhedescendercyrillic"] = 0x0497;
 
-  t["zhedieresiscyrillic"] = 0x04dd;
 
-  t["zihiragana"] = 0x3058;
 
-  t["zikatakana"] = 0x30b8;
 
-  t["zinorhebrew"] = 0x05ae;
 
-  t["zlinebelow"] = 0x1e95;
 
-  t["zmonospace"] = 0xff5a;
 
-  t["zohiragana"] = 0x305e;
 
-  t["zokatakana"] = 0x30be;
 
-  t["zparen"] = 0x24b5;
 
-  t["zretroflexhook"] = 0x0290;
 
-  t["zstroke"] = 0x01b6;
 
-  t["zuhiragana"] = 0x305a;
 
-  t["zukatakana"] = 0x30ba;
 
-  t[".notdef"] = 0x0000;
 
-  t["angbracketleftbig"] = 0x2329;
 
-  t["angbracketleftBig"] = 0x2329;
 
-  t["angbracketleftbigg"] = 0x2329;
 
-  t["angbracketleftBigg"] = 0x2329;
 
-  t["angbracketrightBig"] = 0x232a;
 
-  t["angbracketrightbig"] = 0x232a;
 
-  t["angbracketrightBigg"] = 0x232a;
 
-  t["angbracketrightbigg"] = 0x232a;
 
-  t["arrowhookleft"] = 0x21aa;
 
-  t["arrowhookright"] = 0x21a9;
 
-  t["arrowlefttophalf"] = 0x21bc;
 
-  t["arrowleftbothalf"] = 0x21bd;
 
-  t["arrownortheast"] = 0x2197;
 
-  t["arrownorthwest"] = 0x2196;
 
-  t["arrowrighttophalf"] = 0x21c0;
 
-  t["arrowrightbothalf"] = 0x21c1;
 
-  t["arrowsoutheast"] = 0x2198;
 
-  t["arrowsouthwest"] = 0x2199;
 
-  t["backslashbig"] = 0x2216;
 
-  t["backslashBig"] = 0x2216;
 
-  t["backslashBigg"] = 0x2216;
 
-  t["backslashbigg"] = 0x2216;
 
-  t["bardbl"] = 0x2016;
 
-  t["bracehtipdownleft"] = 0xfe37;
 
-  t["bracehtipdownright"] = 0xfe37;
 
-  t["bracehtipupleft"] = 0xfe38;
 
-  t["bracehtipupright"] = 0xfe38;
 
-  t["braceleftBig"] = 0x007b;
 
-  t["braceleftbig"] = 0x007b;
 
-  t["braceleftbigg"] = 0x007b;
 
-  t["braceleftBigg"] = 0x007b;
 
-  t["bracerightBig"] = 0x007d;
 
-  t["bracerightbig"] = 0x007d;
 
-  t["bracerightbigg"] = 0x007d;
 
-  t["bracerightBigg"] = 0x007d;
 
-  t["bracketleftbig"] = 0x005b;
 
-  t["bracketleftBig"] = 0x005b;
 
-  t["bracketleftbigg"] = 0x005b;
 
-  t["bracketleftBigg"] = 0x005b;
 
-  t["bracketrightBig"] = 0x005d;
 
-  t["bracketrightbig"] = 0x005d;
 
-  t["bracketrightbigg"] = 0x005d;
 
-  t["bracketrightBigg"] = 0x005d;
 
-  t["ceilingleftbig"] = 0x2308;
 
-  t["ceilingleftBig"] = 0x2308;
 
-  t["ceilingleftBigg"] = 0x2308;
 
-  t["ceilingleftbigg"] = 0x2308;
 
-  t["ceilingrightbig"] = 0x2309;
 
-  t["ceilingrightBig"] = 0x2309;
 
-  t["ceilingrightbigg"] = 0x2309;
 
-  t["ceilingrightBigg"] = 0x2309;
 
-  t["circledotdisplay"] = 0x2299;
 
-  t["circledottext"] = 0x2299;
 
-  t["circlemultiplydisplay"] = 0x2297;
 
-  t["circlemultiplytext"] = 0x2297;
 
-  t["circleplusdisplay"] = 0x2295;
 
-  t["circleplustext"] = 0x2295;
 
-  t["contintegraldisplay"] = 0x222e;
 
-  t["contintegraltext"] = 0x222e;
 
-  t["coproductdisplay"] = 0x2210;
 
-  t["coproducttext"] = 0x2210;
 
-  t["floorleftBig"] = 0x230a;
 
-  t["floorleftbig"] = 0x230a;
 
-  t["floorleftbigg"] = 0x230a;
 
-  t["floorleftBigg"] = 0x230a;
 
-  t["floorrightbig"] = 0x230b;
 
-  t["floorrightBig"] = 0x230b;
 
-  t["floorrightBigg"] = 0x230b;
 
-  t["floorrightbigg"] = 0x230b;
 
-  t["hatwide"] = 0x0302;
 
-  t["hatwider"] = 0x0302;
 
-  t["hatwidest"] = 0x0302;
 
-  t["intercal"] = 0x1d40;
 
-  t["integraldisplay"] = 0x222b;
 
-  t["integraltext"] = 0x222b;
 
-  t["intersectiondisplay"] = 0x22c2;
 
-  t["intersectiontext"] = 0x22c2;
 
-  t["logicalanddisplay"] = 0x2227;
 
-  t["logicalandtext"] = 0x2227;
 
-  t["logicalordisplay"] = 0x2228;
 
-  t["logicalortext"] = 0x2228;
 
-  t["parenleftBig"] = 0x0028;
 
-  t["parenleftbig"] = 0x0028;
 
-  t["parenleftBigg"] = 0x0028;
 
-  t["parenleftbigg"] = 0x0028;
 
-  t["parenrightBig"] = 0x0029;
 
-  t["parenrightbig"] = 0x0029;
 
-  t["parenrightBigg"] = 0x0029;
 
-  t["parenrightbigg"] = 0x0029;
 
-  t["prime"] = 0x2032;
 
-  t["productdisplay"] = 0x220f;
 
-  t["producttext"] = 0x220f;
 
-  t["radicalbig"] = 0x221a;
 
-  t["radicalBig"] = 0x221a;
 
-  t["radicalBigg"] = 0x221a;
 
-  t["radicalbigg"] = 0x221a;
 
-  t["radicalbt"] = 0x221a;
 
-  t["radicaltp"] = 0x221a;
 
-  t["radicalvertex"] = 0x221a;
 
-  t["slashbig"] = 0x002f;
 
-  t["slashBig"] = 0x002f;
 
-  t["slashBigg"] = 0x002f;
 
-  t["slashbigg"] = 0x002f;
 
-  t["summationdisplay"] = 0x2211;
 
-  t["summationtext"] = 0x2211;
 
-  t["tildewide"] = 0x02dc;
 
-  t["tildewider"] = 0x02dc;
 
-  t["tildewidest"] = 0x02dc;
 
-  t["uniondisplay"] = 0x22c3;
 
-  t["unionmultidisplay"] = 0x228e;
 
-  t["unionmultitext"] = 0x228e;
 
-  t["unionsqdisplay"] = 0x2294;
 
-  t["unionsqtext"] = 0x2294;
 
-  t["uniontext"] = 0x22c3;
 
-  t["vextenddouble"] = 0x2225;
 
-  t["vextendsingle"] = 0x2223;
 
- });
 
- var getDingbatsGlyphsUnicode = getLookupTableFactory(function (t) {
 
-  t["space"] = 0x0020;
 
-  t["a1"] = 0x2701;
 
-  t["a2"] = 0x2702;
 
-  t["a202"] = 0x2703;
 
-  t["a3"] = 0x2704;
 
-  t["a4"] = 0x260e;
 
-  t["a5"] = 0x2706;
 
-  t["a119"] = 0x2707;
 
-  t["a118"] = 0x2708;
 
-  t["a117"] = 0x2709;
 
-  t["a11"] = 0x261b;
 
-  t["a12"] = 0x261e;
 
-  t["a13"] = 0x270c;
 
-  t["a14"] = 0x270d;
 
-  t["a15"] = 0x270e;
 
-  t["a16"] = 0x270f;
 
-  t["a105"] = 0x2710;
 
-  t["a17"] = 0x2711;
 
-  t["a18"] = 0x2712;
 
-  t["a19"] = 0x2713;
 
-  t["a20"] = 0x2714;
 
-  t["a21"] = 0x2715;
 
-  t["a22"] = 0x2716;
 
-  t["a23"] = 0x2717;
 
-  t["a24"] = 0x2718;
 
-  t["a25"] = 0x2719;
 
-  t["a26"] = 0x271a;
 
-  t["a27"] = 0x271b;
 
-  t["a28"] = 0x271c;
 
-  t["a6"] = 0x271d;
 
-  t["a7"] = 0x271e;
 
-  t["a8"] = 0x271f;
 
-  t["a9"] = 0x2720;
 
-  t["a10"] = 0x2721;
 
-  t["a29"] = 0x2722;
 
-  t["a30"] = 0x2723;
 
-  t["a31"] = 0x2724;
 
-  t["a32"] = 0x2725;
 
-  t["a33"] = 0x2726;
 
-  t["a34"] = 0x2727;
 
-  t["a35"] = 0x2605;
 
-  t["a36"] = 0x2729;
 
-  t["a37"] = 0x272a;
 
-  t["a38"] = 0x272b;
 
-  t["a39"] = 0x272c;
 
-  t["a40"] = 0x272d;
 
-  t["a41"] = 0x272e;
 
-  t["a42"] = 0x272f;
 
-  t["a43"] = 0x2730;
 
-  t["a44"] = 0x2731;
 
-  t["a45"] = 0x2732;
 
-  t["a46"] = 0x2733;
 
-  t["a47"] = 0x2734;
 
-  t["a48"] = 0x2735;
 
-  t["a49"] = 0x2736;
 
-  t["a50"] = 0x2737;
 
-  t["a51"] = 0x2738;
 
-  t["a52"] = 0x2739;
 
-  t["a53"] = 0x273a;
 
-  t["a54"] = 0x273b;
 
-  t["a55"] = 0x273c;
 
-  t["a56"] = 0x273d;
 
-  t["a57"] = 0x273e;
 
-  t["a58"] = 0x273f;
 
-  t["a59"] = 0x2740;
 
-  t["a60"] = 0x2741;
 
-  t["a61"] = 0x2742;
 
-  t["a62"] = 0x2743;
 
-  t["a63"] = 0x2744;
 
-  t["a64"] = 0x2745;
 
-  t["a65"] = 0x2746;
 
-  t["a66"] = 0x2747;
 
-  t["a67"] = 0x2748;
 
-  t["a68"] = 0x2749;
 
-  t["a69"] = 0x274a;
 
-  t["a70"] = 0x274b;
 
-  t["a71"] = 0x25cf;
 
-  t["a72"] = 0x274d;
 
-  t["a73"] = 0x25a0;
 
-  t["a74"] = 0x274f;
 
-  t["a203"] = 0x2750;
 
-  t["a75"] = 0x2751;
 
-  t["a204"] = 0x2752;
 
-  t["a76"] = 0x25b2;
 
-  t["a77"] = 0x25bc;
 
-  t["a78"] = 0x25c6;
 
-  t["a79"] = 0x2756;
 
-  t["a81"] = 0x25d7;
 
-  t["a82"] = 0x2758;
 
-  t["a83"] = 0x2759;
 
-  t["a84"] = 0x275a;
 
-  t["a97"] = 0x275b;
 
-  t["a98"] = 0x275c;
 
-  t["a99"] = 0x275d;
 
-  t["a100"] = 0x275e;
 
-  t["a101"] = 0x2761;
 
-  t["a102"] = 0x2762;
 
-  t["a103"] = 0x2763;
 
-  t["a104"] = 0x2764;
 
-  t["a106"] = 0x2765;
 
-  t["a107"] = 0x2766;
 
-  t["a108"] = 0x2767;
 
-  t["a112"] = 0x2663;
 
-  t["a111"] = 0x2666;
 
-  t["a110"] = 0x2665;
 
-  t["a109"] = 0x2660;
 
-  t["a120"] = 0x2460;
 
-  t["a121"] = 0x2461;
 
-  t["a122"] = 0x2462;
 
-  t["a123"] = 0x2463;
 
-  t["a124"] = 0x2464;
 
-  t["a125"] = 0x2465;
 
-  t["a126"] = 0x2466;
 
-  t["a127"] = 0x2467;
 
-  t["a128"] = 0x2468;
 
-  t["a129"] = 0x2469;
 
-  t["a130"] = 0x2776;
 
-  t["a131"] = 0x2777;
 
-  t["a132"] = 0x2778;
 
-  t["a133"] = 0x2779;
 
-  t["a134"] = 0x277a;
 
-  t["a135"] = 0x277b;
 
-  t["a136"] = 0x277c;
 
-  t["a137"] = 0x277d;
 
-  t["a138"] = 0x277e;
 
-  t["a139"] = 0x277f;
 
-  t["a140"] = 0x2780;
 
-  t["a141"] = 0x2781;
 
-  t["a142"] = 0x2782;
 
-  t["a143"] = 0x2783;
 
-  t["a144"] = 0x2784;
 
-  t["a145"] = 0x2785;
 
-  t["a146"] = 0x2786;
 
-  t["a147"] = 0x2787;
 
-  t["a148"] = 0x2788;
 
-  t["a149"] = 0x2789;
 
-  t["a150"] = 0x278a;
 
-  t["a151"] = 0x278b;
 
-  t["a152"] = 0x278c;
 
-  t["a153"] = 0x278d;
 
-  t["a154"] = 0x278e;
 
-  t["a155"] = 0x278f;
 
-  t["a156"] = 0x2790;
 
-  t["a157"] = 0x2791;
 
-  t["a158"] = 0x2792;
 
-  t["a159"] = 0x2793;
 
-  t["a160"] = 0x2794;
 
-  t["a161"] = 0x2192;
 
-  t["a163"] = 0x2194;
 
-  t["a164"] = 0x2195;
 
-  t["a196"] = 0x2798;
 
-  t["a165"] = 0x2799;
 
-  t["a192"] = 0x279a;
 
-  t["a166"] = 0x279b;
 
-  t["a167"] = 0x279c;
 
-  t["a168"] = 0x279d;
 
-  t["a169"] = 0x279e;
 
-  t["a170"] = 0x279f;
 
-  t["a171"] = 0x27a0;
 
-  t["a172"] = 0x27a1;
 
-  t["a173"] = 0x27a2;
 
-  t["a162"] = 0x27a3;
 
-  t["a174"] = 0x27a4;
 
-  t["a175"] = 0x27a5;
 
-  t["a176"] = 0x27a6;
 
-  t["a177"] = 0x27a7;
 
-  t["a178"] = 0x27a8;
 
-  t["a179"] = 0x27a9;
 
-  t["a193"] = 0x27aa;
 
-  t["a180"] = 0x27ab;
 
-  t["a199"] = 0x27ac;
 
-  t["a181"] = 0x27ad;
 
-  t["a200"] = 0x27ae;
 
-  t["a182"] = 0x27af;
 
-  t["a201"] = 0x27b1;
 
-  t["a183"] = 0x27b2;
 
-  t["a184"] = 0x27b3;
 
-  t["a197"] = 0x27b4;
 
-  t["a185"] = 0x27b5;
 
-  t["a194"] = 0x27b6;
 
-  t["a198"] = 0x27b7;
 
-  t["a186"] = 0x27b8;
 
-  t["a195"] = 0x27b9;
 
-  t["a187"] = 0x27ba;
 
-  t["a188"] = 0x27bb;
 
-  t["a189"] = 0x27bc;
 
-  t["a190"] = 0x27bd;
 
-  t["a191"] = 0x27be;
 
-  t["a89"] = 0x2768;
 
-  t["a90"] = 0x2769;
 
-  t["a93"] = 0x276a;
 
-  t["a94"] = 0x276b;
 
-  t["a91"] = 0x276c;
 
-  t["a92"] = 0x276d;
 
-  t["a205"] = 0x276e;
 
-  t["a85"] = 0x276f;
 
-  t["a206"] = 0x2770;
 
-  t["a86"] = 0x2771;
 
-  t["a87"] = 0x2772;
 
-  t["a88"] = 0x2773;
 
-  t["a95"] = 0x2774;
 
-  t["a96"] = 0x2775;
 
-  t[".notdef"] = 0x0000;
 
- });
 
- exports.getGlyphsUnicode = getGlyphsUnicode;
 
- exports.getDingbatsGlyphsUnicode = getDingbatsGlyphsUnicode;
 
- /***/ }),
 
- /* 32 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getSupplementalGlyphMapForCalibri = exports.getSupplementalGlyphMapForArialBlack = exports.getGlyphMapForStandardFonts = exports.getSymbolsFonts = exports.getSerifFonts = exports.getNonStdFontMap = exports.getStdFontMap = void 0;
 
- var _core_utils = __w_pdfjs_require__(7);
 
- const getStdFontMap = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t["ArialNarrow"] = "Helvetica";
 
-   t["ArialNarrow-Bold"] = "Helvetica-Bold";
 
-   t["ArialNarrow-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["ArialNarrow-Italic"] = "Helvetica-Oblique";
 
-   t["ArialBlack"] = "Helvetica";
 
-   t["ArialBlack-Bold"] = "Helvetica-Bold";
 
-   t["ArialBlack-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["ArialBlack-Italic"] = "Helvetica-Oblique";
 
-   t["Arial-Black"] = "Helvetica";
 
-   t["Arial-Black-Bold"] = "Helvetica-Bold";
 
-   t["Arial-Black-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["Arial-Black-Italic"] = "Helvetica-Oblique";
 
-   t["Arial"] = "Helvetica";
 
-   t["Arial-Bold"] = "Helvetica-Bold";
 
-   t["Arial-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["Arial-Italic"] = "Helvetica-Oblique";
 
-   t["Arial-BoldItalicMT"] = "Helvetica-BoldOblique";
 
-   t["Arial-BoldMT"] = "Helvetica-Bold";
 
-   t["Arial-ItalicMT"] = "Helvetica-Oblique";
 
-   t["ArialMT"] = "Helvetica";
 
-   t["Courier-Bold"] = "Courier-Bold";
 
-   t["Courier-BoldItalic"] = "Courier-BoldOblique";
 
-   t["Courier-Italic"] = "Courier-Oblique";
 
-   t["CourierNew"] = "Courier";
 
-   t["CourierNew-Bold"] = "Courier-Bold";
 
-   t["CourierNew-BoldItalic"] = "Courier-BoldOblique";
 
-   t["CourierNew-Italic"] = "Courier-Oblique";
 
-   t["CourierNewPS-BoldItalicMT"] = "Courier-BoldOblique";
 
-   t["CourierNewPS-BoldMT"] = "Courier-Bold";
 
-   t["CourierNewPS-ItalicMT"] = "Courier-Oblique";
 
-   t["CourierNewPSMT"] = "Courier";
 
-   t["Helvetica"] = "Helvetica";
 
-   t["Helvetica-Bold"] = "Helvetica-Bold";
 
-   t["Helvetica-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["Helvetica-BoldOblique"] = "Helvetica-BoldOblique";
 
-   t["Helvetica-Italic"] = "Helvetica-Oblique";
 
-   t["Helvetica-Oblique"] = "Helvetica-Oblique";
 
-   t["Symbol-Bold"] = "Symbol";
 
-   t["Symbol-BoldItalic"] = "Symbol";
 
-   t["Symbol-Italic"] = "Symbol";
 
-   t["TimesNewRoman"] = "Times-Roman";
 
-   t["TimesNewRoman-Bold"] = "Times-Bold";
 
-   t["TimesNewRoman-BoldItalic"] = "Times-BoldItalic";
 
-   t["TimesNewRoman-Italic"] = "Times-Italic";
 
-   t["TimesNewRomanPS"] = "Times-Roman";
 
-   t["TimesNewRomanPS-Bold"] = "Times-Bold";
 
-   t["TimesNewRomanPS-BoldItalic"] = "Times-BoldItalic";
 
-   t["TimesNewRomanPS-BoldItalicMT"] = "Times-BoldItalic";
 
-   t["TimesNewRomanPS-BoldMT"] = "Times-Bold";
 
-   t["TimesNewRomanPS-Italic"] = "Times-Italic";
 
-   t["TimesNewRomanPS-ItalicMT"] = "Times-Italic";
 
-   t["TimesNewRomanPSMT"] = "Times-Roman";
 
-   t["TimesNewRomanPSMT-Bold"] = "Times-Bold";
 
-   t["TimesNewRomanPSMT-BoldItalic"] = "Times-BoldItalic";
 
-   t["TimesNewRomanPSMT-Italic"] = "Times-Italic";
 
- });
 
- exports.getStdFontMap = getStdFontMap;
 
- const getNonStdFontMap = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t["Calibri"] = "Helvetica";
 
-   t["Calibri-Bold"] = "Helvetica-Bold";
 
-   t["Calibri-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["Calibri-Italic"] = "Helvetica-Oblique";
 
-   t["CenturyGothic"] = "Helvetica";
 
-   t["CenturyGothic-Bold"] = "Helvetica-Bold";
 
-   t["CenturyGothic-BoldItalic"] = "Helvetica-BoldOblique";
 
-   t["CenturyGothic-Italic"] = "Helvetica-Oblique";
 
-   t["ComicSansMS"] = "Comic Sans MS";
 
-   t["ComicSansMS-Bold"] = "Comic Sans MS-Bold";
 
-   t["ComicSansMS-BoldItalic"] = "Comic Sans MS-BoldItalic";
 
-   t["ComicSansMS-Italic"] = "Comic Sans MS-Italic";
 
-   t["LucidaConsole"] = "Courier";
 
-   t["LucidaConsole-Bold"] = "Courier-Bold";
 
-   t["LucidaConsole-BoldItalic"] = "Courier-BoldOblique";
 
-   t["LucidaConsole-Italic"] = "Courier-Oblique";
 
-   t["LucidaSans-Demi"] = "Helvetica-Bold";
 
-   t["MS-Gothic"] = "MS Gothic";
 
-   t["MS-Gothic-Bold"] = "MS Gothic-Bold";
 
-   t["MS-Gothic-BoldItalic"] = "MS Gothic-BoldItalic";
 
-   t["MS-Gothic-Italic"] = "MS Gothic-Italic";
 
-   t["MS-Mincho"] = "MS Mincho";
 
-   t["MS-Mincho-Bold"] = "MS Mincho-Bold";
 
-   t["MS-Mincho-BoldItalic"] = "MS Mincho-BoldItalic";
 
-   t["MS-Mincho-Italic"] = "MS Mincho-Italic";
 
-   t["MS-PGothic"] = "MS PGothic";
 
-   t["MS-PGothic-Bold"] = "MS PGothic-Bold";
 
-   t["MS-PGothic-BoldItalic"] = "MS PGothic-BoldItalic";
 
-   t["MS-PGothic-Italic"] = "MS PGothic-Italic";
 
-   t["MS-PMincho"] = "MS PMincho";
 
-   t["MS-PMincho-Bold"] = "MS PMincho-Bold";
 
-   t["MS-PMincho-BoldItalic"] = "MS PMincho-BoldItalic";
 
-   t["MS-PMincho-Italic"] = "MS PMincho-Italic";
 
-   t["NuptialScript"] = "Times-Italic";
 
-   t["SegoeUISymbol"] = "Helvetica";
 
-   t["Wingdings"] = "ZapfDingbats";
 
-   t["Wingdings-Regular"] = "ZapfDingbats";
 
- });
 
- exports.getNonStdFontMap = getNonStdFontMap;
 
- const getSerifFonts = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t["Adobe Jenson"] = true;
 
-   t["Adobe Text"] = true;
 
-   t["Albertus"] = true;
 
-   t["Aldus"] = true;
 
-   t["Alexandria"] = true;
 
-   t["Algerian"] = true;
 
-   t["American Typewriter"] = true;
 
-   t["Antiqua"] = true;
 
-   t["Apex"] = true;
 
-   t["Arno"] = true;
 
-   t["Aster"] = true;
 
-   t["Aurora"] = true;
 
-   t["Baskerville"] = true;
 
-   t["Bell"] = true;
 
-   t["Bembo"] = true;
 
-   t["Bembo Schoolbook"] = true;
 
-   t["Benguiat"] = true;
 
-   t["Berkeley Old Style"] = true;
 
-   t["Bernhard Modern"] = true;
 
-   t["Berthold City"] = true;
 
-   t["Bodoni"] = true;
 
-   t["Bauer Bodoni"] = true;
 
-   t["Book Antiqua"] = true;
 
-   t["Bookman"] = true;
 
-   t["Bordeaux Roman"] = true;
 
-   t["Californian FB"] = true;
 
-   t["Calisto"] = true;
 
-   t["Calvert"] = true;
 
-   t["Capitals"] = true;
 
-   t["Cambria"] = true;
 
-   t["Cartier"] = true;
 
-   t["Caslon"] = true;
 
-   t["Catull"] = true;
 
-   t["Centaur"] = true;
 
-   t["Century Old Style"] = true;
 
-   t["Century Schoolbook"] = true;
 
-   t["Chaparral"] = true;
 
-   t["Charis SIL"] = true;
 
-   t["Cheltenham"] = true;
 
-   t["Cholla Slab"] = true;
 
-   t["Clarendon"] = true;
 
-   t["Clearface"] = true;
 
-   t["Cochin"] = true;
 
-   t["Colonna"] = true;
 
-   t["Computer Modern"] = true;
 
-   t["Concrete Roman"] = true;
 
-   t["Constantia"] = true;
 
-   t["Cooper Black"] = true;
 
-   t["Corona"] = true;
 
-   t["Ecotype"] = true;
 
-   t["Egyptienne"] = true;
 
-   t["Elephant"] = true;
 
-   t["Excelsior"] = true;
 
-   t["Fairfield"] = true;
 
-   t["FF Scala"] = true;
 
-   t["Folkard"] = true;
 
-   t["Footlight"] = true;
 
-   t["FreeSerif"] = true;
 
-   t["Friz Quadrata"] = true;
 
-   t["Garamond"] = true;
 
-   t["Gentium"] = true;
 
-   t["Georgia"] = true;
 
-   t["Gloucester"] = true;
 
-   t["Goudy Old Style"] = true;
 
-   t["Goudy Schoolbook"] = true;
 
-   t["Goudy Pro Font"] = true;
 
-   t["Granjon"] = true;
 
-   t["Guardian Egyptian"] = true;
 
-   t["Heather"] = true;
 
-   t["Hercules"] = true;
 
-   t["High Tower Text"] = true;
 
-   t["Hiroshige"] = true;
 
-   t["Hoefler Text"] = true;
 
-   t["Humana Serif"] = true;
 
-   t["Imprint"] = true;
 
-   t["Ionic No. 5"] = true;
 
-   t["Janson"] = true;
 
-   t["Joanna"] = true;
 
-   t["Korinna"] = true;
 
-   t["Lexicon"] = true;
 
-   t["Liberation Serif"] = true;
 
-   t["Linux Libertine"] = true;
 
-   t["Literaturnaya"] = true;
 
-   t["Lucida"] = true;
 
-   t["Lucida Bright"] = true;
 
-   t["Melior"] = true;
 
-   t["Memphis"] = true;
 
-   t["Miller"] = true;
 
-   t["Minion"] = true;
 
-   t["Modern"] = true;
 
-   t["Mona Lisa"] = true;
 
-   t["Mrs Eaves"] = true;
 
-   t["MS Serif"] = true;
 
-   t["Museo Slab"] = true;
 
-   t["New York"] = true;
 
-   t["Nimbus Roman"] = true;
 
-   t["NPS Rawlinson Roadway"] = true;
 
-   t["NuptialScript"] = true;
 
-   t["Palatino"] = true;
 
-   t["Perpetua"] = true;
 
-   t["Plantin"] = true;
 
-   t["Plantin Schoolbook"] = true;
 
-   t["Playbill"] = true;
 
-   t["Poor Richard"] = true;
 
-   t["Rawlinson Roadway"] = true;
 
-   t["Renault"] = true;
 
-   t["Requiem"] = true;
 
-   t["Rockwell"] = true;
 
-   t["Roman"] = true;
 
-   t["Rotis Serif"] = true;
 
-   t["Sabon"] = true;
 
-   t["Scala"] = true;
 
-   t["Seagull"] = true;
 
-   t["Sistina"] = true;
 
-   t["Souvenir"] = true;
 
-   t["STIX"] = true;
 
-   t["Stone Informal"] = true;
 
-   t["Stone Serif"] = true;
 
-   t["Sylfaen"] = true;
 
-   t["Times"] = true;
 
-   t["Trajan"] = true;
 
-   t["Trinité"] = true;
 
-   t["Trump Mediaeval"] = true;
 
-   t["Utopia"] = true;
 
-   t["Vale Type"] = true;
 
-   t["Bitstream Vera"] = true;
 
-   t["Vera Serif"] = true;
 
-   t["Versailles"] = true;
 
-   t["Wanted"] = true;
 
-   t["Weiss"] = true;
 
-   t["Wide Latin"] = true;
 
-   t["Windsor"] = true;
 
-   t["XITS"] = true;
 
- });
 
- exports.getSerifFonts = getSerifFonts;
 
- const getSymbolsFonts = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t["Dingbats"] = true;
 
-   t["Symbol"] = true;
 
-   t["ZapfDingbats"] = true;
 
- });
 
- exports.getSymbolsFonts = getSymbolsFonts;
 
- const getGlyphMapForStandardFonts = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t[2] = 10;
 
-   t[3] = 32;
 
-   t[4] = 33;
 
-   t[5] = 34;
 
-   t[6] = 35;
 
-   t[7] = 36;
 
-   t[8] = 37;
 
-   t[9] = 38;
 
-   t[10] = 39;
 
-   t[11] = 40;
 
-   t[12] = 41;
 
-   t[13] = 42;
 
-   t[14] = 43;
 
-   t[15] = 44;
 
-   t[16] = 45;
 
-   t[17] = 46;
 
-   t[18] = 47;
 
-   t[19] = 48;
 
-   t[20] = 49;
 
-   t[21] = 50;
 
-   t[22] = 51;
 
-   t[23] = 52;
 
-   t[24] = 53;
 
-   t[25] = 54;
 
-   t[26] = 55;
 
-   t[27] = 56;
 
-   t[28] = 57;
 
-   t[29] = 58;
 
-   t[30] = 894;
 
-   t[31] = 60;
 
-   t[32] = 61;
 
-   t[33] = 62;
 
-   t[34] = 63;
 
-   t[35] = 64;
 
-   t[36] = 65;
 
-   t[37] = 66;
 
-   t[38] = 67;
 
-   t[39] = 68;
 
-   t[40] = 69;
 
-   t[41] = 70;
 
-   t[42] = 71;
 
-   t[43] = 72;
 
-   t[44] = 73;
 
-   t[45] = 74;
 
-   t[46] = 75;
 
-   t[47] = 76;
 
-   t[48] = 77;
 
-   t[49] = 78;
 
-   t[50] = 79;
 
-   t[51] = 80;
 
-   t[52] = 81;
 
-   t[53] = 82;
 
-   t[54] = 83;
 
-   t[55] = 84;
 
-   t[56] = 85;
 
-   t[57] = 86;
 
-   t[58] = 87;
 
-   t[59] = 88;
 
-   t[60] = 89;
 
-   t[61] = 90;
 
-   t[62] = 91;
 
-   t[63] = 92;
 
-   t[64] = 93;
 
-   t[65] = 94;
 
-   t[66] = 95;
 
-   t[67] = 96;
 
-   t[68] = 97;
 
-   t[69] = 98;
 
-   t[70] = 99;
 
-   t[71] = 100;
 
-   t[72] = 101;
 
-   t[73] = 102;
 
-   t[74] = 103;
 
-   t[75] = 104;
 
-   t[76] = 105;
 
-   t[77] = 106;
 
-   t[78] = 107;
 
-   t[79] = 108;
 
-   t[80] = 109;
 
-   t[81] = 110;
 
-   t[82] = 111;
 
-   t[83] = 112;
 
-   t[84] = 113;
 
-   t[85] = 114;
 
-   t[86] = 115;
 
-   t[87] = 116;
 
-   t[88] = 117;
 
-   t[89] = 118;
 
-   t[90] = 119;
 
-   t[91] = 120;
 
-   t[92] = 121;
 
-   t[93] = 122;
 
-   t[94] = 123;
 
-   t[95] = 124;
 
-   t[96] = 125;
 
-   t[97] = 126;
 
-   t[98] = 196;
 
-   t[99] = 197;
 
-   t[100] = 199;
 
-   t[101] = 201;
 
-   t[102] = 209;
 
-   t[103] = 214;
 
-   t[104] = 220;
 
-   t[105] = 225;
 
-   t[106] = 224;
 
-   t[107] = 226;
 
-   t[108] = 228;
 
-   t[109] = 227;
 
-   t[110] = 229;
 
-   t[111] = 231;
 
-   t[112] = 233;
 
-   t[113] = 232;
 
-   t[114] = 234;
 
-   t[115] = 235;
 
-   t[116] = 237;
 
-   t[117] = 236;
 
-   t[118] = 238;
 
-   t[119] = 239;
 
-   t[120] = 241;
 
-   t[121] = 243;
 
-   t[122] = 242;
 
-   t[123] = 244;
 
-   t[124] = 246;
 
-   t[125] = 245;
 
-   t[126] = 250;
 
-   t[127] = 249;
 
-   t[128] = 251;
 
-   t[129] = 252;
 
-   t[130] = 8224;
 
-   t[131] = 176;
 
-   t[132] = 162;
 
-   t[133] = 163;
 
-   t[134] = 167;
 
-   t[135] = 8226;
 
-   t[136] = 182;
 
-   t[137] = 223;
 
-   t[138] = 174;
 
-   t[139] = 169;
 
-   t[140] = 8482;
 
-   t[141] = 180;
 
-   t[142] = 168;
 
-   t[143] = 8800;
 
-   t[144] = 198;
 
-   t[145] = 216;
 
-   t[146] = 8734;
 
-   t[147] = 177;
 
-   t[148] = 8804;
 
-   t[149] = 8805;
 
-   t[150] = 165;
 
-   t[151] = 181;
 
-   t[152] = 8706;
 
-   t[153] = 8721;
 
-   t[154] = 8719;
 
-   t[156] = 8747;
 
-   t[157] = 170;
 
-   t[158] = 186;
 
-   t[159] = 8486;
 
-   t[160] = 230;
 
-   t[161] = 248;
 
-   t[162] = 191;
 
-   t[163] = 161;
 
-   t[164] = 172;
 
-   t[165] = 8730;
 
-   t[166] = 402;
 
-   t[167] = 8776;
 
-   t[168] = 8710;
 
-   t[169] = 171;
 
-   t[170] = 187;
 
-   t[171] = 8230;
 
-   t[210] = 218;
 
-   t[223] = 711;
 
-   t[224] = 321;
 
-   t[225] = 322;
 
-   t[227] = 353;
 
-   t[229] = 382;
 
-   t[234] = 253;
 
-   t[252] = 263;
 
-   t[253] = 268;
 
-   t[254] = 269;
 
-   t[258] = 258;
 
-   t[260] = 260;
 
-   t[261] = 261;
 
-   t[265] = 280;
 
-   t[266] = 281;
 
-   t[268] = 283;
 
-   t[269] = 313;
 
-   t[275] = 323;
 
-   t[276] = 324;
 
-   t[278] = 328;
 
-   t[284] = 345;
 
-   t[285] = 346;
 
-   t[286] = 347;
 
-   t[292] = 367;
 
-   t[295] = 377;
 
-   t[296] = 378;
 
-   t[298] = 380;
 
-   t[305] = 963;
 
-   t[306] = 964;
 
-   t[307] = 966;
 
-   t[308] = 8215;
 
-   t[309] = 8252;
 
-   t[310] = 8319;
 
-   t[311] = 8359;
 
-   t[312] = 8592;
 
-   t[313] = 8593;
 
-   t[337] = 9552;
 
-   t[493] = 1039;
 
-   t[494] = 1040;
 
-   t[705] = 1524;
 
-   t[706] = 8362;
 
-   t[710] = 64288;
 
-   t[711] = 64298;
 
-   t[759] = 1617;
 
-   t[761] = 1776;
 
-   t[763] = 1778;
 
-   t[775] = 1652;
 
-   t[777] = 1764;
 
-   t[778] = 1780;
 
-   t[779] = 1781;
 
-   t[780] = 1782;
 
-   t[782] = 771;
 
-   t[783] = 64726;
 
-   t[786] = 8363;
 
-   t[788] = 8532;
 
-   t[790] = 768;
 
-   t[791] = 769;
 
-   t[792] = 768;
 
-   t[795] = 803;
 
-   t[797] = 64336;
 
-   t[798] = 64337;
 
-   t[799] = 64342;
 
-   t[800] = 64343;
 
-   t[801] = 64344;
 
-   t[802] = 64345;
 
-   t[803] = 64362;
 
-   t[804] = 64363;
 
-   t[805] = 64364;
 
-   t[2424] = 7821;
 
-   t[2425] = 7822;
 
-   t[2426] = 7823;
 
-   t[2427] = 7824;
 
-   t[2428] = 7825;
 
-   t[2429] = 7826;
 
-   t[2430] = 7827;
 
-   t[2433] = 7682;
 
-   t[2678] = 8045;
 
-   t[2679] = 8046;
 
-   t[2830] = 1552;
 
-   t[2838] = 686;
 
-   t[2840] = 751;
 
-   t[2842] = 753;
 
-   t[2843] = 754;
 
-   t[2844] = 755;
 
-   t[2846] = 757;
 
-   t[2856] = 767;
 
-   t[2857] = 848;
 
-   t[2858] = 849;
 
-   t[2862] = 853;
 
-   t[2863] = 854;
 
-   t[2864] = 855;
 
-   t[2865] = 861;
 
-   t[2866] = 862;
 
-   t[2906] = 7460;
 
-   t[2908] = 7462;
 
-   t[2909] = 7463;
 
-   t[2910] = 7464;
 
-   t[2912] = 7466;
 
-   t[2913] = 7467;
 
-   t[2914] = 7468;
 
-   t[2916] = 7470;
 
-   t[2917] = 7471;
 
-   t[2918] = 7472;
 
-   t[2920] = 7474;
 
-   t[2921] = 7475;
 
-   t[2922] = 7476;
 
-   t[2924] = 7478;
 
-   t[2925] = 7479;
 
-   t[2926] = 7480;
 
-   t[2928] = 7482;
 
-   t[2929] = 7483;
 
-   t[2930] = 7484;
 
-   t[2932] = 7486;
 
-   t[2933] = 7487;
 
-   t[2934] = 7488;
 
-   t[2936] = 7490;
 
-   t[2937] = 7491;
 
-   t[2938] = 7492;
 
-   t[2940] = 7494;
 
-   t[2941] = 7495;
 
-   t[2942] = 7496;
 
-   t[2944] = 7498;
 
-   t[2946] = 7500;
 
-   t[2948] = 7502;
 
-   t[2950] = 7504;
 
-   t[2951] = 7505;
 
-   t[2952] = 7506;
 
-   t[2954] = 7508;
 
-   t[2955] = 7509;
 
-   t[2956] = 7510;
 
-   t[2958] = 7512;
 
-   t[2959] = 7513;
 
-   t[2960] = 7514;
 
-   t[2962] = 7516;
 
-   t[2963] = 7517;
 
-   t[2964] = 7518;
 
-   t[2966] = 7520;
 
-   t[2967] = 7521;
 
-   t[2968] = 7522;
 
-   t[2970] = 7524;
 
-   t[2971] = 7525;
 
-   t[2972] = 7526;
 
-   t[2974] = 7528;
 
-   t[2975] = 7529;
 
-   t[2976] = 7530;
 
-   t[2978] = 1537;
 
-   t[2979] = 1538;
 
-   t[2980] = 1539;
 
-   t[2982] = 1549;
 
-   t[2983] = 1551;
 
-   t[2984] = 1552;
 
-   t[2986] = 1554;
 
-   t[2987] = 1555;
 
-   t[2988] = 1556;
 
-   t[2990] = 1623;
 
-   t[2991] = 1624;
 
-   t[2995] = 1775;
 
-   t[2999] = 1791;
 
-   t[3002] = 64290;
 
-   t[3003] = 64291;
 
-   t[3004] = 64292;
 
-   t[3006] = 64294;
 
-   t[3007] = 64295;
 
-   t[3008] = 64296;
 
-   t[3011] = 1900;
 
-   t[3014] = 8223;
 
-   t[3015] = 8244;
 
-   t[3017] = 7532;
 
-   t[3018] = 7533;
 
-   t[3019] = 7534;
 
-   t[3075] = 7590;
 
-   t[3076] = 7591;
 
-   t[3079] = 7594;
 
-   t[3080] = 7595;
 
-   t[3083] = 7598;
 
-   t[3084] = 7599;
 
-   t[3087] = 7602;
 
-   t[3088] = 7603;
 
-   t[3091] = 7606;
 
-   t[3092] = 7607;
 
-   t[3095] = 7610;
 
-   t[3096] = 7611;
 
-   t[3099] = 7614;
 
-   t[3100] = 7615;
 
-   t[3103] = 7618;
 
-   t[3104] = 7619;
 
-   t[3107] = 8337;
 
-   t[3108] = 8338;
 
-   t[3116] = 1884;
 
-   t[3119] = 1885;
 
-   t[3120] = 1885;
 
-   t[3123] = 1886;
 
-   t[3124] = 1886;
 
-   t[3127] = 1887;
 
-   t[3128] = 1887;
 
-   t[3131] = 1888;
 
-   t[3132] = 1888;
 
-   t[3135] = 1889;
 
-   t[3136] = 1889;
 
-   t[3139] = 1890;
 
-   t[3140] = 1890;
 
-   t[3143] = 1891;
 
-   t[3144] = 1891;
 
-   t[3147] = 1892;
 
-   t[3148] = 1892;
 
-   t[3153] = 580;
 
-   t[3154] = 581;
 
-   t[3157] = 584;
 
-   t[3158] = 585;
 
-   t[3161] = 588;
 
-   t[3162] = 589;
 
-   t[3165] = 891;
 
-   t[3166] = 892;
 
-   t[3169] = 1274;
 
-   t[3170] = 1275;
 
-   t[3173] = 1278;
 
-   t[3174] = 1279;
 
-   t[3181] = 7622;
 
-   t[3182] = 7623;
 
-   t[3282] = 11799;
 
-   t[3316] = 578;
 
-   t[3379] = 42785;
 
-   t[3393] = 1159;
 
-   t[3416] = 8377;
 
- });
 
- exports.getGlyphMapForStandardFonts = getGlyphMapForStandardFonts;
 
- const getSupplementalGlyphMapForArialBlack = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t[227] = 322;
 
-   t[264] = 261;
 
-   t[291] = 346;
 
- });
 
- exports.getSupplementalGlyphMapForArialBlack = getSupplementalGlyphMapForArialBlack;
 
- const getSupplementalGlyphMapForCalibri = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t[1] = 32;
 
-   t[4] = 65;
 
-   t[17] = 66;
 
-   t[18] = 67;
 
-   t[24] = 68;
 
-   t[28] = 69;
 
-   t[38] = 70;
 
-   t[39] = 71;
 
-   t[44] = 72;
 
-   t[47] = 73;
 
-   t[58] = 74;
 
-   t[60] = 75;
 
-   t[62] = 76;
 
-   t[68] = 77;
 
-   t[69] = 78;
 
-   t[75] = 79;
 
-   t[87] = 80;
 
-   t[89] = 81;
 
-   t[90] = 82;
 
-   t[94] = 83;
 
-   t[100] = 84;
 
-   t[104] = 85;
 
-   t[115] = 86;
 
-   t[116] = 87;
 
-   t[121] = 88;
 
-   t[122] = 89;
 
-   t[127] = 90;
 
-   t[258] = 97;
 
-   t[268] = 261;
 
-   t[271] = 98;
 
-   t[272] = 99;
 
-   t[273] = 263;
 
-   t[282] = 100;
 
-   t[286] = 101;
 
-   t[295] = 281;
 
-   t[296] = 102;
 
-   t[336] = 103;
 
-   t[346] = 104;
 
-   t[349] = 105;
 
-   t[361] = 106;
 
-   t[364] = 107;
 
-   t[367] = 108;
 
-   t[371] = 322;
 
-   t[373] = 109;
 
-   t[374] = 110;
 
-   t[381] = 111;
 
-   t[383] = 243;
 
-   t[393] = 112;
 
-   t[395] = 113;
 
-   t[396] = 114;
 
-   t[400] = 115;
 
-   t[401] = 347;
 
-   t[410] = 116;
 
-   t[437] = 117;
 
-   t[448] = 118;
 
-   t[449] = 119;
 
-   t[454] = 120;
 
-   t[455] = 121;
 
-   t[460] = 122;
 
-   t[463] = 380;
 
-   t[853] = 44;
 
-   t[855] = 58;
 
-   t[856] = 46;
 
-   t[876] = 47;
 
-   t[878] = 45;
 
-   t[882] = 45;
 
-   t[894] = 40;
 
-   t[895] = 41;
 
-   t[896] = 91;
 
-   t[897] = 93;
 
-   t[923] = 64;
 
-   t[1004] = 48;
 
-   t[1005] = 49;
 
-   t[1006] = 50;
 
-   t[1007] = 51;
 
-   t[1008] = 52;
 
-   t[1009] = 53;
 
-   t[1010] = 54;
 
-   t[1011] = 55;
 
-   t[1012] = 56;
 
-   t[1013] = 57;
 
-   t[1081] = 37;
 
-   t[1085] = 43;
 
-   t[1086] = 45;
 
- });
 
- exports.getSupplementalGlyphMapForCalibri = getSupplementalGlyphMapForCalibri;
 
- /***/ }),
 
- /* 33 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- var getLookupTableFactory = __w_pdfjs_require__(7).getLookupTableFactory;
 
- var getSpecialPUASymbols = getLookupTableFactory(function (t) {
 
-  t[63721] = 0x00a9;
 
-  t[63193] = 0x00a9;
 
-  t[63720] = 0x00ae;
 
-  t[63194] = 0x00ae;
 
-  t[63722] = 0x2122;
 
-  t[63195] = 0x2122;
 
-  t[63729] = 0x23a7;
 
-  t[63730] = 0x23a8;
 
-  t[63731] = 0x23a9;
 
-  t[63740] = 0x23ab;
 
-  t[63741] = 0x23ac;
 
-  t[63742] = 0x23ad;
 
-  t[63726] = 0x23a1;
 
-  t[63727] = 0x23a2;
 
-  t[63728] = 0x23a3;
 
-  t[63737] = 0x23a4;
 
-  t[63738] = 0x23a5;
 
-  t[63739] = 0x23a6;
 
-  t[63723] = 0x239b;
 
-  t[63724] = 0x239c;
 
-  t[63725] = 0x239d;
 
-  t[63734] = 0x239e;
 
-  t[63735] = 0x239f;
 
-  t[63736] = 0x23a0;
 
- });
 
- function mapSpecialUnicodeValues(code) {
 
-  if (code >= 0xfff0 && code <= 0xffff) {
 
-   return 0;
 
-  } else if (code >= 0xf600 && code <= 0xf8ff) {
 
-   return getSpecialPUASymbols()[code] || code;
 
-  } else if (code === 0x00ad) {
 
-   return 0x002d;
 
-  }
 
-  return code;
 
- }
 
- function getUnicodeForGlyph(name, glyphsUnicodeMap) {
 
-  var unicode = glyphsUnicodeMap[name];
 
-  if (unicode !== undefined) {
 
-   return unicode;
 
-  }
 
-  if (!name) {
 
-   return -1;
 
-  }
 
-  if (name[0] === "u") {
 
-   var nameLen = name.length, hexStr;
 
-   if (nameLen === 7 && name[1] === "n" && name[2] === "i") {
 
-    hexStr = name.substring(3);
 
-   } else if (nameLen >= 5 && nameLen <= 7) {
 
-    hexStr = name.substring(1);
 
-   } else {
 
-    return -1;
 
-   }
 
-   if (hexStr === hexStr.toUpperCase()) {
 
-    unicode = parseInt(hexStr, 16);
 
-    if (unicode >= 0) {
 
-     return unicode;
 
-    }
 
-   }
 
-  }
 
-  return -1;
 
- }
 
- var UnicodeRanges = [
 
-  {
 
-   begin: 0x0000,
 
-   end: 0x007f
 
-  },
 
-  {
 
-   begin: 0x0080,
 
-   end: 0x00ff
 
-  },
 
-  {
 
-   begin: 0x0100,
 
-   end: 0x017f
 
-  },
 
-  {
 
-   begin: 0x0180,
 
-   end: 0x024f
 
-  },
 
-  {
 
-   begin: 0x0250,
 
-   end: 0x02af
 
-  },
 
-  {
 
-   begin: 0x02b0,
 
-   end: 0x02ff
 
-  },
 
-  {
 
-   begin: 0x0300,
 
-   end: 0x036f
 
-  },
 
-  {
 
-   begin: 0x0370,
 
-   end: 0x03ff
 
-  },
 
-  {
 
-   begin: 0x2c80,
 
-   end: 0x2cff
 
-  },
 
-  {
 
-   begin: 0x0400,
 
-   end: 0x04ff
 
-  },
 
-  {
 
-   begin: 0x0530,
 
-   end: 0x058f
 
-  },
 
-  {
 
-   begin: 0x0590,
 
-   end: 0x05ff
 
-  },
 
-  {
 
-   begin: 0xa500,
 
-   end: 0xa63f
 
-  },
 
-  {
 
-   begin: 0x0600,
 
-   end: 0x06ff
 
-  },
 
-  {
 
-   begin: 0x07c0,
 
-   end: 0x07ff
 
-  },
 
-  {
 
-   begin: 0x0900,
 
-   end: 0x097f
 
-  },
 
-  {
 
-   begin: 0x0980,
 
-   end: 0x09ff
 
-  },
 
-  {
 
-   begin: 0x0a00,
 
-   end: 0x0a7f
 
-  },
 
-  {
 
-   begin: 0x0a80,
 
-   end: 0x0aff
 
-  },
 
-  {
 
-   begin: 0x0b00,
 
-   end: 0x0b7f
 
-  },
 
-  {
 
-   begin: 0x0b80,
 
-   end: 0x0bff
 
-  },
 
-  {
 
-   begin: 0x0c00,
 
-   end: 0x0c7f
 
-  },
 
-  {
 
-   begin: 0x0c80,
 
-   end: 0x0cff
 
-  },
 
-  {
 
-   begin: 0x0d00,
 
-   end: 0x0d7f
 
-  },
 
-  {
 
-   begin: 0x0e00,
 
-   end: 0x0e7f
 
-  },
 
-  {
 
-   begin: 0x0e80,
 
-   end: 0x0eff
 
-  },
 
-  {
 
-   begin: 0x10a0,
 
-   end: 0x10ff
 
-  },
 
-  {
 
-   begin: 0x1b00,
 
-   end: 0x1b7f
 
-  },
 
-  {
 
-   begin: 0x1100,
 
-   end: 0x11ff
 
-  },
 
-  {
 
-   begin: 0x1e00,
 
-   end: 0x1eff
 
-  },
 
-  {
 
-   begin: 0x1f00,
 
-   end: 0x1fff
 
-  },
 
-  {
 
-   begin: 0x2000,
 
-   end: 0x206f
 
-  },
 
-  {
 
-   begin: 0x2070,
 
-   end: 0x209f
 
-  },
 
-  {
 
-   begin: 0x20a0,
 
-   end: 0x20cf
 
-  },
 
-  {
 
-   begin: 0x20d0,
 
-   end: 0x20ff
 
-  },
 
-  {
 
-   begin: 0x2100,
 
-   end: 0x214f
 
-  },
 
-  {
 
-   begin: 0x2150,
 
-   end: 0x218f
 
-  },
 
-  {
 
-   begin: 0x2190,
 
-   end: 0x21ff
 
-  },
 
-  {
 
-   begin: 0x2200,
 
-   end: 0x22ff
 
-  },
 
-  {
 
-   begin: 0x2300,
 
-   end: 0x23ff
 
-  },
 
-  {
 
-   begin: 0x2400,
 
-   end: 0x243f
 
-  },
 
-  {
 
-   begin: 0x2440,
 
-   end: 0x245f
 
-  },
 
-  {
 
-   begin: 0x2460,
 
-   end: 0x24ff
 
-  },
 
-  {
 
-   begin: 0x2500,
 
-   end: 0x257f
 
-  },
 
-  {
 
-   begin: 0x2580,
 
-   end: 0x259f
 
-  },
 
-  {
 
-   begin: 0x25a0,
 
-   end: 0x25ff
 
-  },
 
-  {
 
-   begin: 0x2600,
 
-   end: 0x26ff
 
-  },
 
-  {
 
-   begin: 0x2700,
 
-   end: 0x27bf
 
-  },
 
-  {
 
-   begin: 0x3000,
 
-   end: 0x303f
 
-  },
 
-  {
 
-   begin: 0x3040,
 
-   end: 0x309f
 
-  },
 
-  {
 
-   begin: 0x30a0,
 
-   end: 0x30ff
 
-  },
 
-  {
 
-   begin: 0x3100,
 
-   end: 0x312f
 
-  },
 
-  {
 
-   begin: 0x3130,
 
-   end: 0x318f
 
-  },
 
-  {
 
-   begin: 0xa840,
 
-   end: 0xa87f
 
-  },
 
-  {
 
-   begin: 0x3200,
 
-   end: 0x32ff
 
-  },
 
-  {
 
-   begin: 0x3300,
 
-   end: 0x33ff
 
-  },
 
-  {
 
-   begin: 0xac00,
 
-   end: 0xd7af
 
-  },
 
-  {
 
-   begin: 0xd800,
 
-   end: 0xdfff
 
-  },
 
-  {
 
-   begin: 0x10900,
 
-   end: 0x1091f
 
-  },
 
-  {
 
-   begin: 0x4e00,
 
-   end: 0x9fff
 
-  },
 
-  {
 
-   begin: 0xe000,
 
-   end: 0xf8ff
 
-  },
 
-  {
 
-   begin: 0x31c0,
 
-   end: 0x31ef
 
-  },
 
-  {
 
-   begin: 0xfb00,
 
-   end: 0xfb4f
 
-  },
 
-  {
 
-   begin: 0xfb50,
 
-   end: 0xfdff
 
-  },
 
-  {
 
-   begin: 0xfe20,
 
-   end: 0xfe2f
 
-  },
 
-  {
 
-   begin: 0xfe10,
 
-   end: 0xfe1f
 
-  },
 
-  {
 
-   begin: 0xfe50,
 
-   end: 0xfe6f
 
-  },
 
-  {
 
-   begin: 0xfe70,
 
-   end: 0xfeff
 
-  },
 
-  {
 
-   begin: 0xff00,
 
-   end: 0xffef
 
-  },
 
-  {
 
-   begin: 0xfff0,
 
-   end: 0xffff
 
-  },
 
-  {
 
-   begin: 0x0f00,
 
-   end: 0x0fff
 
-  },
 
-  {
 
-   begin: 0x0700,
 
-   end: 0x074f
 
-  },
 
-  {
 
-   begin: 0x0780,
 
-   end: 0x07bf
 
-  },
 
-  {
 
-   begin: 0x0d80,
 
-   end: 0x0dff
 
-  },
 
-  {
 
-   begin: 0x1000,
 
-   end: 0x109f
 
-  },
 
-  {
 
-   begin: 0x1200,
 
-   end: 0x137f
 
-  },
 
-  {
 
-   begin: 0x13a0,
 
-   end: 0x13ff
 
-  },
 
-  {
 
-   begin: 0x1400,
 
-   end: 0x167f
 
-  },
 
-  {
 
-   begin: 0x1680,
 
-   end: 0x169f
 
-  },
 
-  {
 
-   begin: 0x16a0,
 
-   end: 0x16ff
 
-  },
 
-  {
 
-   begin: 0x1780,
 
-   end: 0x17ff
 
-  },
 
-  {
 
-   begin: 0x1800,
 
-   end: 0x18af
 
-  },
 
-  {
 
-   begin: 0x2800,
 
-   end: 0x28ff
 
-  },
 
-  {
 
-   begin: 0xa000,
 
-   end: 0xa48f
 
-  },
 
-  {
 
-   begin: 0x1700,
 
-   end: 0x171f
 
-  },
 
-  {
 
-   begin: 0x10300,
 
-   end: 0x1032f
 
-  },
 
-  {
 
-   begin: 0x10330,
 
-   end: 0x1034f
 
-  },
 
-  {
 
-   begin: 0x10400,
 
-   end: 0x1044f
 
-  },
 
-  {
 
-   begin: 0x1d000,
 
-   end: 0x1d0ff
 
-  },
 
-  {
 
-   begin: 0x1d400,
 
-   end: 0x1d7ff
 
-  },
 
-  {
 
-   begin: 0xff000,
 
-   end: 0xffffd
 
-  },
 
-  {
 
-   begin: 0xfe00,
 
-   end: 0xfe0f
 
-  },
 
-  {
 
-   begin: 0xe0000,
 
-   end: 0xe007f
 
-  },
 
-  {
 
-   begin: 0x1900,
 
-   end: 0x194f
 
-  },
 
-  {
 
-   begin: 0x1950,
 
-   end: 0x197f
 
-  },
 
-  {
 
-   begin: 0x1980,
 
-   end: 0x19df
 
-  },
 
-  {
 
-   begin: 0x1a00,
 
-   end: 0x1a1f
 
-  },
 
-  {
 
-   begin: 0x2c00,
 
-   end: 0x2c5f
 
-  },
 
-  {
 
-   begin: 0x2d30,
 
-   end: 0x2d7f
 
-  },
 
-  {
 
-   begin: 0x4dc0,
 
-   end: 0x4dff
 
-  },
 
-  {
 
-   begin: 0xa800,
 
-   end: 0xa82f
 
-  },
 
-  {
 
-   begin: 0x10000,
 
-   end: 0x1007f
 
-  },
 
-  {
 
-   begin: 0x10140,
 
-   end: 0x1018f
 
-  },
 
-  {
 
-   begin: 0x10380,
 
-   end: 0x1039f
 
-  },
 
-  {
 
-   begin: 0x103a0,
 
-   end: 0x103df
 
-  },
 
-  {
 
-   begin: 0x10450,
 
-   end: 0x1047f
 
-  },
 
-  {
 
-   begin: 0x10480,
 
-   end: 0x104af
 
-  },
 
-  {
 
-   begin: 0x10800,
 
-   end: 0x1083f
 
-  },
 
-  {
 
-   begin: 0x10a00,
 
-   end: 0x10a5f
 
-  },
 
-  {
 
-   begin: 0x1d300,
 
-   end: 0x1d35f
 
-  },
 
-  {
 
-   begin: 0x12000,
 
-   end: 0x123ff
 
-  },
 
-  {
 
-   begin: 0x1d360,
 
-   end: 0x1d37f
 
-  },
 
-  {
 
-   begin: 0x1b80,
 
-   end: 0x1bbf
 
-  },
 
-  {
 
-   begin: 0x1c00,
 
-   end: 0x1c4f
 
-  },
 
-  {
 
-   begin: 0x1c50,
 
-   end: 0x1c7f
 
-  },
 
-  {
 
-   begin: 0xa880,
 
-   end: 0xa8df
 
-  },
 
-  {
 
-   begin: 0xa900,
 
-   end: 0xa92f
 
-  },
 
-  {
 
-   begin: 0xa930,
 
-   end: 0xa95f
 
-  },
 
-  {
 
-   begin: 0xaa00,
 
-   end: 0xaa5f
 
-  },
 
-  {
 
-   begin: 0x10190,
 
-   end: 0x101cf
 
-  },
 
-  {
 
-   begin: 0x101d0,
 
-   end: 0x101ff
 
-  },
 
-  {
 
-   begin: 0x102a0,
 
-   end: 0x102df
 
-  },
 
-  {
 
-   begin: 0x1f030,
 
-   end: 0x1f09f
 
-  }
 
- ];
 
- function getUnicodeRangeFor(value) {
 
-  for (var i = 0, ii = UnicodeRanges.length; i < ii; i++) {
 
-   var range = UnicodeRanges[i];
 
-   if (value >= range.begin && value < range.end) {
 
-    return i;
 
-   }
 
-  }
 
-  return -1;
 
- }
 
- function isRTLRangeFor(value) {
 
-  var range = UnicodeRanges[13];
 
-  if (value >= range.begin && value < range.end) {
 
-   return true;
 
-  }
 
-  range = UnicodeRanges[11];
 
-  if (value >= range.begin && value < range.end) {
 
-   return true;
 
-  }
 
-  return false;
 
- }
 
- var getNormalizedUnicodes = getLookupTableFactory(function (t) {
 
-  t["\u00A8"] = "\u0020\u0308";
 
-  t["\u00AF"] = "\u0020\u0304";
 
-  t["\u00B4"] = "\u0020\u0301";
 
-  t["\u00B5"] = "\u03BC";
 
-  t["\u00B8"] = "\u0020\u0327";
 
-  t["\u0132"] = "\u0049\u004A";
 
-  t["\u0133"] = "\u0069\u006A";
 
-  t["\u013F"] = "\u004C\u00B7";
 
-  t["\u0140"] = "\u006C\u00B7";
 
-  t["\u0149"] = "\u02BC\u006E";
 
-  t["\u017F"] = "\u0073";
 
-  t["\u01C4"] = "\u0044\u017D";
 
-  t["\u01C5"] = "\u0044\u017E";
 
-  t["\u01C6"] = "\u0064\u017E";
 
-  t["\u01C7"] = "\u004C\u004A";
 
-  t["\u01C8"] = "\u004C\u006A";
 
-  t["\u01C9"] = "\u006C\u006A";
 
-  t["\u01CA"] = "\u004E\u004A";
 
-  t["\u01CB"] = "\u004E\u006A";
 
-  t["\u01CC"] = "\u006E\u006A";
 
-  t["\u01F1"] = "\u0044\u005A";
 
-  t["\u01F2"] = "\u0044\u007A";
 
-  t["\u01F3"] = "\u0064\u007A";
 
-  t["\u02D8"] = "\u0020\u0306";
 
-  t["\u02D9"] = "\u0020\u0307";
 
-  t["\u02DA"] = "\u0020\u030A";
 
-  t["\u02DB"] = "\u0020\u0328";
 
-  t["\u02DC"] = "\u0020\u0303";
 
-  t["\u02DD"] = "\u0020\u030B";
 
-  t["\u037A"] = "\u0020\u0345";
 
-  t["\u0384"] = "\u0020\u0301";
 
-  t["\u03D0"] = "\u03B2";
 
-  t["\u03D1"] = "\u03B8";
 
-  t["\u03D2"] = "\u03A5";
 
-  t["\u03D5"] = "\u03C6";
 
-  t["\u03D6"] = "\u03C0";
 
-  t["\u03F0"] = "\u03BA";
 
-  t["\u03F1"] = "\u03C1";
 
-  t["\u03F2"] = "\u03C2";
 
-  t["\u03F4"] = "\u0398";
 
-  t["\u03F5"] = "\u03B5";
 
-  t["\u03F9"] = "\u03A3";
 
-  t["\u0587"] = "\u0565\u0582";
 
-  t["\u0675"] = "\u0627\u0674";
 
-  t["\u0676"] = "\u0648\u0674";
 
-  t["\u0677"] = "\u06C7\u0674";
 
-  t["\u0678"] = "\u064A\u0674";
 
-  t["\u0E33"] = "\u0E4D\u0E32";
 
-  t["\u0EB3"] = "\u0ECD\u0EB2";
 
-  t["\u0EDC"] = "\u0EAB\u0E99";
 
-  t["\u0EDD"] = "\u0EAB\u0EA1";
 
-  t["\u0F77"] = "\u0FB2\u0F81";
 
-  t["\u0F79"] = "\u0FB3\u0F81";
 
-  t["\u1E9A"] = "\u0061\u02BE";
 
-  t["\u1FBD"] = "\u0020\u0313";
 
-  t["\u1FBF"] = "\u0020\u0313";
 
-  t["\u1FC0"] = "\u0020\u0342";
 
-  t["\u1FFE"] = "\u0020\u0314";
 
-  t["\u2002"] = "\u0020";
 
-  t["\u2003"] = "\u0020";
 
-  t["\u2004"] = "\u0020";
 
-  t["\u2005"] = "\u0020";
 
-  t["\u2006"] = "\u0020";
 
-  t["\u2008"] = "\u0020";
 
-  t["\u2009"] = "\u0020";
 
-  t["\u200A"] = "\u0020";
 
-  t["\u2017"] = "\u0020\u0333";
 
-  t["\u2024"] = "\u002E";
 
-  t["\u2025"] = "\u002E\u002E";
 
-  t["\u2026"] = "\u002E\u002E\u002E";
 
-  t["\u2033"] = "\u2032\u2032";
 
-  t["\u2034"] = "\u2032\u2032\u2032";
 
-  t["\u2036"] = "\u2035\u2035";
 
-  t["\u2037"] = "\u2035\u2035\u2035";
 
-  t["\u203C"] = "\u0021\u0021";
 
-  t["\u203E"] = "\u0020\u0305";
 
-  t["\u2047"] = "\u003F\u003F";
 
-  t["\u2048"] = "\u003F\u0021";
 
-  t["\u2049"] = "\u0021\u003F";
 
-  t["\u2057"] = "\u2032\u2032\u2032\u2032";
 
-  t["\u205F"] = "\u0020";
 
-  t["\u20A8"] = "\u0052\u0073";
 
-  t["\u2100"] = "\u0061\u002F\u0063";
 
-  t["\u2101"] = "\u0061\u002F\u0073";
 
-  t["\u2103"] = "\u00B0\u0043";
 
-  t["\u2105"] = "\u0063\u002F\u006F";
 
-  t["\u2106"] = "\u0063\u002F\u0075";
 
-  t["\u2107"] = "\u0190";
 
-  t["\u2109"] = "\u00B0\u0046";
 
-  t["\u2116"] = "\u004E\u006F";
 
-  t["\u2121"] = "\u0054\u0045\u004C";
 
-  t["\u2135"] = "\u05D0";
 
-  t["\u2136"] = "\u05D1";
 
-  t["\u2137"] = "\u05D2";
 
-  t["\u2138"] = "\u05D3";
 
-  t["\u213B"] = "\u0046\u0041\u0058";
 
-  t["\u2160"] = "\u0049";
 
-  t["\u2161"] = "\u0049\u0049";
 
-  t["\u2162"] = "\u0049\u0049\u0049";
 
-  t["\u2163"] = "\u0049\u0056";
 
-  t["\u2164"] = "\u0056";
 
-  t["\u2165"] = "\u0056\u0049";
 
-  t["\u2166"] = "\u0056\u0049\u0049";
 
-  t["\u2167"] = "\u0056\u0049\u0049\u0049";
 
-  t["\u2168"] = "\u0049\u0058";
 
-  t["\u2169"] = "\u0058";
 
-  t["\u216A"] = "\u0058\u0049";
 
-  t["\u216B"] = "\u0058\u0049\u0049";
 
-  t["\u216C"] = "\u004C";
 
-  t["\u216D"] = "\u0043";
 
-  t["\u216E"] = "\u0044";
 
-  t["\u216F"] = "\u004D";
 
-  t["\u2170"] = "\u0069";
 
-  t["\u2171"] = "\u0069\u0069";
 
-  t["\u2172"] = "\u0069\u0069\u0069";
 
-  t["\u2173"] = "\u0069\u0076";
 
-  t["\u2174"] = "\u0076";
 
-  t["\u2175"] = "\u0076\u0069";
 
-  t["\u2176"] = "\u0076\u0069\u0069";
 
-  t["\u2177"] = "\u0076\u0069\u0069\u0069";
 
-  t["\u2178"] = "\u0069\u0078";
 
-  t["\u2179"] = "\u0078";
 
-  t["\u217A"] = "\u0078\u0069";
 
-  t["\u217B"] = "\u0078\u0069\u0069";
 
-  t["\u217C"] = "\u006C";
 
-  t["\u217D"] = "\u0063";
 
-  t["\u217E"] = "\u0064";
 
-  t["\u217F"] = "\u006D";
 
-  t["\u222C"] = "\u222B\u222B";
 
-  t["\u222D"] = "\u222B\u222B\u222B";
 
-  t["\u222F"] = "\u222E\u222E";
 
-  t["\u2230"] = "\u222E\u222E\u222E";
 
-  t["\u2474"] = "\u0028\u0031\u0029";
 
-  t["\u2475"] = "\u0028\u0032\u0029";
 
-  t["\u2476"] = "\u0028\u0033\u0029";
 
-  t["\u2477"] = "\u0028\u0034\u0029";
 
-  t["\u2478"] = "\u0028\u0035\u0029";
 
-  t["\u2479"] = "\u0028\u0036\u0029";
 
-  t["\u247A"] = "\u0028\u0037\u0029";
 
-  t["\u247B"] = "\u0028\u0038\u0029";
 
-  t["\u247C"] = "\u0028\u0039\u0029";
 
-  t["\u247D"] = "\u0028\u0031\u0030\u0029";
 
-  t["\u247E"] = "\u0028\u0031\u0031\u0029";
 
-  t["\u247F"] = "\u0028\u0031\u0032\u0029";
 
-  t["\u2480"] = "\u0028\u0031\u0033\u0029";
 
-  t["\u2481"] = "\u0028\u0031\u0034\u0029";
 
-  t["\u2482"] = "\u0028\u0031\u0035\u0029";
 
-  t["\u2483"] = "\u0028\u0031\u0036\u0029";
 
-  t["\u2484"] = "\u0028\u0031\u0037\u0029";
 
-  t["\u2485"] = "\u0028\u0031\u0038\u0029";
 
-  t["\u2486"] = "\u0028\u0031\u0039\u0029";
 
-  t["\u2487"] = "\u0028\u0032\u0030\u0029";
 
-  t["\u2488"] = "\u0031\u002E";
 
-  t["\u2489"] = "\u0032\u002E";
 
-  t["\u248A"] = "\u0033\u002E";
 
-  t["\u248B"] = "\u0034\u002E";
 
-  t["\u248C"] = "\u0035\u002E";
 
-  t["\u248D"] = "\u0036\u002E";
 
-  t["\u248E"] = "\u0037\u002E";
 
-  t["\u248F"] = "\u0038\u002E";
 
-  t["\u2490"] = "\u0039\u002E";
 
-  t["\u2491"] = "\u0031\u0030\u002E";
 
-  t["\u2492"] = "\u0031\u0031\u002E";
 
-  t["\u2493"] = "\u0031\u0032\u002E";
 
-  t["\u2494"] = "\u0031\u0033\u002E";
 
-  t["\u2495"] = "\u0031\u0034\u002E";
 
-  t["\u2496"] = "\u0031\u0035\u002E";
 
-  t["\u2497"] = "\u0031\u0036\u002E";
 
-  t["\u2498"] = "\u0031\u0037\u002E";
 
-  t["\u2499"] = "\u0031\u0038\u002E";
 
-  t["\u249A"] = "\u0031\u0039\u002E";
 
-  t["\u249B"] = "\u0032\u0030\u002E";
 
-  t["\u249C"] = "\u0028\u0061\u0029";
 
-  t["\u249D"] = "\u0028\u0062\u0029";
 
-  t["\u249E"] = "\u0028\u0063\u0029";
 
-  t["\u249F"] = "\u0028\u0064\u0029";
 
-  t["\u24A0"] = "\u0028\u0065\u0029";
 
-  t["\u24A1"] = "\u0028\u0066\u0029";
 
-  t["\u24A2"] = "\u0028\u0067\u0029";
 
-  t["\u24A3"] = "\u0028\u0068\u0029";
 
-  t["\u24A4"] = "\u0028\u0069\u0029";
 
-  t["\u24A5"] = "\u0028\u006A\u0029";
 
-  t["\u24A6"] = "\u0028\u006B\u0029";
 
-  t["\u24A7"] = "\u0028\u006C\u0029";
 
-  t["\u24A8"] = "\u0028\u006D\u0029";
 
-  t["\u24A9"] = "\u0028\u006E\u0029";
 
-  t["\u24AA"] = "\u0028\u006F\u0029";
 
-  t["\u24AB"] = "\u0028\u0070\u0029";
 
-  t["\u24AC"] = "\u0028\u0071\u0029";
 
-  t["\u24AD"] = "\u0028\u0072\u0029";
 
-  t["\u24AE"] = "\u0028\u0073\u0029";
 
-  t["\u24AF"] = "\u0028\u0074\u0029";
 
-  t["\u24B0"] = "\u0028\u0075\u0029";
 
-  t["\u24B1"] = "\u0028\u0076\u0029";
 
-  t["\u24B2"] = "\u0028\u0077\u0029";
 
-  t["\u24B3"] = "\u0028\u0078\u0029";
 
-  t["\u24B4"] = "\u0028\u0079\u0029";
 
-  t["\u24B5"] = "\u0028\u007A\u0029";
 
-  t["\u2A0C"] = "\u222B\u222B\u222B\u222B";
 
-  t["\u2A74"] = "\u003A\u003A\u003D";
 
-  t["\u2A75"] = "\u003D\u003D";
 
-  t["\u2A76"] = "\u003D\u003D\u003D";
 
-  t["\u2E9F"] = "\u6BCD";
 
-  t["\u2EF3"] = "\u9F9F";
 
-  t["\u2F00"] = "\u4E00";
 
-  t["\u2F01"] = "\u4E28";
 
-  t["\u2F02"] = "\u4E36";
 
-  t["\u2F03"] = "\u4E3F";
 
-  t["\u2F04"] = "\u4E59";
 
-  t["\u2F05"] = "\u4E85";
 
-  t["\u2F06"] = "\u4E8C";
 
-  t["\u2F07"] = "\u4EA0";
 
-  t["\u2F08"] = "\u4EBA";
 
-  t["\u2F09"] = "\u513F";
 
-  t["\u2F0A"] = "\u5165";
 
-  t["\u2F0B"] = "\u516B";
 
-  t["\u2F0C"] = "\u5182";
 
-  t["\u2F0D"] = "\u5196";
 
-  t["\u2F0E"] = "\u51AB";
 
-  t["\u2F0F"] = "\u51E0";
 
-  t["\u2F10"] = "\u51F5";
 
-  t["\u2F11"] = "\u5200";
 
-  t["\u2F12"] = "\u529B";
 
-  t["\u2F13"] = "\u52F9";
 
-  t["\u2F14"] = "\u5315";
 
-  t["\u2F15"] = "\u531A";
 
-  t["\u2F16"] = "\u5338";
 
-  t["\u2F17"] = "\u5341";
 
-  t["\u2F18"] = "\u535C";
 
-  t["\u2F19"] = "\u5369";
 
-  t["\u2F1A"] = "\u5382";
 
-  t["\u2F1B"] = "\u53B6";
 
-  t["\u2F1C"] = "\u53C8";
 
-  t["\u2F1D"] = "\u53E3";
 
-  t["\u2F1E"] = "\u56D7";
 
-  t["\u2F1F"] = "\u571F";
 
-  t["\u2F20"] = "\u58EB";
 
-  t["\u2F21"] = "\u5902";
 
-  t["\u2F22"] = "\u590A";
 
-  t["\u2F23"] = "\u5915";
 
-  t["\u2F24"] = "\u5927";
 
-  t["\u2F25"] = "\u5973";
 
-  t["\u2F26"] = "\u5B50";
 
-  t["\u2F27"] = "\u5B80";
 
-  t["\u2F28"] = "\u5BF8";
 
-  t["\u2F29"] = "\u5C0F";
 
-  t["\u2F2A"] = "\u5C22";
 
-  t["\u2F2B"] = "\u5C38";
 
-  t["\u2F2C"] = "\u5C6E";
 
-  t["\u2F2D"] = "\u5C71";
 
-  t["\u2F2E"] = "\u5DDB";
 
-  t["\u2F2F"] = "\u5DE5";
 
-  t["\u2F30"] = "\u5DF1";
 
-  t["\u2F31"] = "\u5DFE";
 
-  t["\u2F32"] = "\u5E72";
 
-  t["\u2F33"] = "\u5E7A";
 
-  t["\u2F34"] = "\u5E7F";
 
-  t["\u2F35"] = "\u5EF4";
 
-  t["\u2F36"] = "\u5EFE";
 
-  t["\u2F37"] = "\u5F0B";
 
-  t["\u2F38"] = "\u5F13";
 
-  t["\u2F39"] = "\u5F50";
 
-  t["\u2F3A"] = "\u5F61";
 
-  t["\u2F3B"] = "\u5F73";
 
-  t["\u2F3C"] = "\u5FC3";
 
-  t["\u2F3D"] = "\u6208";
 
-  t["\u2F3E"] = "\u6236";
 
-  t["\u2F3F"] = "\u624B";
 
-  t["\u2F40"] = "\u652F";
 
-  t["\u2F41"] = "\u6534";
 
-  t["\u2F42"] = "\u6587";
 
-  t["\u2F43"] = "\u6597";
 
-  t["\u2F44"] = "\u65A4";
 
-  t["\u2F45"] = "\u65B9";
 
-  t["\u2F46"] = "\u65E0";
 
-  t["\u2F47"] = "\u65E5";
 
-  t["\u2F48"] = "\u66F0";
 
-  t["\u2F49"] = "\u6708";
 
-  t["\u2F4A"] = "\u6728";
 
-  t["\u2F4B"] = "\u6B20";
 
-  t["\u2F4C"] = "\u6B62";
 
-  t["\u2F4D"] = "\u6B79";
 
-  t["\u2F4E"] = "\u6BB3";
 
-  t["\u2F4F"] = "\u6BCB";
 
-  t["\u2F50"] = "\u6BD4";
 
-  t["\u2F51"] = "\u6BDB";
 
-  t["\u2F52"] = "\u6C0F";
 
-  t["\u2F53"] = "\u6C14";
 
-  t["\u2F54"] = "\u6C34";
 
-  t["\u2F55"] = "\u706B";
 
-  t["\u2F56"] = "\u722A";
 
-  t["\u2F57"] = "\u7236";
 
-  t["\u2F58"] = "\u723B";
 
-  t["\u2F59"] = "\u723F";
 
-  t["\u2F5A"] = "\u7247";
 
-  t["\u2F5B"] = "\u7259";
 
-  t["\u2F5C"] = "\u725B";
 
-  t["\u2F5D"] = "\u72AC";
 
-  t["\u2F5E"] = "\u7384";
 
-  t["\u2F5F"] = "\u7389";
 
-  t["\u2F60"] = "\u74DC";
 
-  t["\u2F61"] = "\u74E6";
 
-  t["\u2F62"] = "\u7518";
 
-  t["\u2F63"] = "\u751F";
 
-  t["\u2F64"] = "\u7528";
 
-  t["\u2F65"] = "\u7530";
 
-  t["\u2F66"] = "\u758B";
 
-  t["\u2F67"] = "\u7592";
 
-  t["\u2F68"] = "\u7676";
 
-  t["\u2F69"] = "\u767D";
 
-  t["\u2F6A"] = "\u76AE";
 
-  t["\u2F6B"] = "\u76BF";
 
-  t["\u2F6C"] = "\u76EE";
 
-  t["\u2F6D"] = "\u77DB";
 
-  t["\u2F6E"] = "\u77E2";
 
-  t["\u2F6F"] = "\u77F3";
 
-  t["\u2F70"] = "\u793A";
 
-  t["\u2F71"] = "\u79B8";
 
-  t["\u2F72"] = "\u79BE";
 
-  t["\u2F73"] = "\u7A74";
 
-  t["\u2F74"] = "\u7ACB";
 
-  t["\u2F75"] = "\u7AF9";
 
-  t["\u2F76"] = "\u7C73";
 
-  t["\u2F77"] = "\u7CF8";
 
-  t["\u2F78"] = "\u7F36";
 
-  t["\u2F79"] = "\u7F51";
 
-  t["\u2F7A"] = "\u7F8A";
 
-  t["\u2F7B"] = "\u7FBD";
 
-  t["\u2F7C"] = "\u8001";
 
-  t["\u2F7D"] = "\u800C";
 
-  t["\u2F7E"] = "\u8012";
 
-  t["\u2F7F"] = "\u8033";
 
-  t["\u2F80"] = "\u807F";
 
-  t["\u2F81"] = "\u8089";
 
-  t["\u2F82"] = "\u81E3";
 
-  t["\u2F83"] = "\u81EA";
 
-  t["\u2F84"] = "\u81F3";
 
-  t["\u2F85"] = "\u81FC";
 
-  t["\u2F86"] = "\u820C";
 
-  t["\u2F87"] = "\u821B";
 
-  t["\u2F88"] = "\u821F";
 
-  t["\u2F89"] = "\u826E";
 
-  t["\u2F8A"] = "\u8272";
 
-  t["\u2F8B"] = "\u8278";
 
-  t["\u2F8C"] = "\u864D";
 
-  t["\u2F8D"] = "\u866B";
 
-  t["\u2F8E"] = "\u8840";
 
-  t["\u2F8F"] = "\u884C";
 
-  t["\u2F90"] = "\u8863";
 
-  t["\u2F91"] = "\u897E";
 
-  t["\u2F92"] = "\u898B";
 
-  t["\u2F93"] = "\u89D2";
 
-  t["\u2F94"] = "\u8A00";
 
-  t["\u2F95"] = "\u8C37";
 
-  t["\u2F96"] = "\u8C46";
 
-  t["\u2F97"] = "\u8C55";
 
-  t["\u2F98"] = "\u8C78";
 
-  t["\u2F99"] = "\u8C9D";
 
-  t["\u2F9A"] = "\u8D64";
 
-  t["\u2F9B"] = "\u8D70";
 
-  t["\u2F9C"] = "\u8DB3";
 
-  t["\u2F9D"] = "\u8EAB";
 
-  t["\u2F9E"] = "\u8ECA";
 
-  t["\u2F9F"] = "\u8F9B";
 
-  t["\u2FA0"] = "\u8FB0";
 
-  t["\u2FA1"] = "\u8FB5";
 
-  t["\u2FA2"] = "\u9091";
 
-  t["\u2FA3"] = "\u9149";
 
-  t["\u2FA4"] = "\u91C6";
 
-  t["\u2FA5"] = "\u91CC";
 
-  t["\u2FA6"] = "\u91D1";
 
-  t["\u2FA7"] = "\u9577";
 
-  t["\u2FA8"] = "\u9580";
 
-  t["\u2FA9"] = "\u961C";
 
-  t["\u2FAA"] = "\u96B6";
 
-  t["\u2FAB"] = "\u96B9";
 
-  t["\u2FAC"] = "\u96E8";
 
-  t["\u2FAD"] = "\u9751";
 
-  t["\u2FAE"] = "\u975E";
 
-  t["\u2FAF"] = "\u9762";
 
-  t["\u2FB0"] = "\u9769";
 
-  t["\u2FB1"] = "\u97CB";
 
-  t["\u2FB2"] = "\u97ED";
 
-  t["\u2FB3"] = "\u97F3";
 
-  t["\u2FB4"] = "\u9801";
 
-  t["\u2FB5"] = "\u98A8";
 
-  t["\u2FB6"] = "\u98DB";
 
-  t["\u2FB7"] = "\u98DF";
 
-  t["\u2FB8"] = "\u9996";
 
-  t["\u2FB9"] = "\u9999";
 
-  t["\u2FBA"] = "\u99AC";
 
-  t["\u2FBB"] = "\u9AA8";
 
-  t["\u2FBC"] = "\u9AD8";
 
-  t["\u2FBD"] = "\u9ADF";
 
-  t["\u2FBE"] = "\u9B25";
 
-  t["\u2FBF"] = "\u9B2F";
 
-  t["\u2FC0"] = "\u9B32";
 
-  t["\u2FC1"] = "\u9B3C";
 
-  t["\u2FC2"] = "\u9B5A";
 
-  t["\u2FC3"] = "\u9CE5";
 
-  t["\u2FC4"] = "\u9E75";
 
-  t["\u2FC5"] = "\u9E7F";
 
-  t["\u2FC6"] = "\u9EA5";
 
-  t["\u2FC7"] = "\u9EBB";
 
-  t["\u2FC8"] = "\u9EC3";
 
-  t["\u2FC9"] = "\u9ECD";
 
-  t["\u2FCA"] = "\u9ED1";
 
-  t["\u2FCB"] = "\u9EF9";
 
-  t["\u2FCC"] = "\u9EFD";
 
-  t["\u2FCD"] = "\u9F0E";
 
-  t["\u2FCE"] = "\u9F13";
 
-  t["\u2FCF"] = "\u9F20";
 
-  t["\u2FD0"] = "\u9F3B";
 
-  t["\u2FD1"] = "\u9F4A";
 
-  t["\u2FD2"] = "\u9F52";
 
-  t["\u2FD3"] = "\u9F8D";
 
-  t["\u2FD4"] = "\u9F9C";
 
-  t["\u2FD5"] = "\u9FA0";
 
-  t["\u3036"] = "\u3012";
 
-  t["\u3038"] = "\u5341";
 
-  t["\u3039"] = "\u5344";
 
-  t["\u303A"] = "\u5345";
 
-  t["\u309B"] = "\u0020\u3099";
 
-  t["\u309C"] = "\u0020\u309A";
 
-  t["\u3131"] = "\u1100";
 
-  t["\u3132"] = "\u1101";
 
-  t["\u3133"] = "\u11AA";
 
-  t["\u3134"] = "\u1102";
 
-  t["\u3135"] = "\u11AC";
 
-  t["\u3136"] = "\u11AD";
 
-  t["\u3137"] = "\u1103";
 
-  t["\u3138"] = "\u1104";
 
-  t["\u3139"] = "\u1105";
 
-  t["\u313A"] = "\u11B0";
 
-  t["\u313B"] = "\u11B1";
 
-  t["\u313C"] = "\u11B2";
 
-  t["\u313D"] = "\u11B3";
 
-  t["\u313E"] = "\u11B4";
 
-  t["\u313F"] = "\u11B5";
 
-  t["\u3140"] = "\u111A";
 
-  t["\u3141"] = "\u1106";
 
-  t["\u3142"] = "\u1107";
 
-  t["\u3143"] = "\u1108";
 
-  t["\u3144"] = "\u1121";
 
-  t["\u3145"] = "\u1109";
 
-  t["\u3146"] = "\u110A";
 
-  t["\u3147"] = "\u110B";
 
-  t["\u3148"] = "\u110C";
 
-  t["\u3149"] = "\u110D";
 
-  t["\u314A"] = "\u110E";
 
-  t["\u314B"] = "\u110F";
 
-  t["\u314C"] = "\u1110";
 
-  t["\u314D"] = "\u1111";
 
-  t["\u314E"] = "\u1112";
 
-  t["\u314F"] = "\u1161";
 
-  t["\u3150"] = "\u1162";
 
-  t["\u3151"] = "\u1163";
 
-  t["\u3152"] = "\u1164";
 
-  t["\u3153"] = "\u1165";
 
-  t["\u3154"] = "\u1166";
 
-  t["\u3155"] = "\u1167";
 
-  t["\u3156"] = "\u1168";
 
-  t["\u3157"] = "\u1169";
 
-  t["\u3158"] = "\u116A";
 
-  t["\u3159"] = "\u116B";
 
-  t["\u315A"] = "\u116C";
 
-  t["\u315B"] = "\u116D";
 
-  t["\u315C"] = "\u116E";
 
-  t["\u315D"] = "\u116F";
 
-  t["\u315E"] = "\u1170";
 
-  t["\u315F"] = "\u1171";
 
-  t["\u3160"] = "\u1172";
 
-  t["\u3161"] = "\u1173";
 
-  t["\u3162"] = "\u1174";
 
-  t["\u3163"] = "\u1175";
 
-  t["\u3164"] = "\u1160";
 
-  t["\u3165"] = "\u1114";
 
-  t["\u3166"] = "\u1115";
 
-  t["\u3167"] = "\u11C7";
 
-  t["\u3168"] = "\u11C8";
 
-  t["\u3169"] = "\u11CC";
 
-  t["\u316A"] = "\u11CE";
 
-  t["\u316B"] = "\u11D3";
 
-  t["\u316C"] = "\u11D7";
 
-  t["\u316D"] = "\u11D9";
 
-  t["\u316E"] = "\u111C";
 
-  t["\u316F"] = "\u11DD";
 
-  t["\u3170"] = "\u11DF";
 
-  t["\u3171"] = "\u111D";
 
-  t["\u3172"] = "\u111E";
 
-  t["\u3173"] = "\u1120";
 
-  t["\u3174"] = "\u1122";
 
-  t["\u3175"] = "\u1123";
 
-  t["\u3176"] = "\u1127";
 
-  t["\u3177"] = "\u1129";
 
-  t["\u3178"] = "\u112B";
 
-  t["\u3179"] = "\u112C";
 
-  t["\u317A"] = "\u112D";
 
-  t["\u317B"] = "\u112E";
 
-  t["\u317C"] = "\u112F";
 
-  t["\u317D"] = "\u1132";
 
-  t["\u317E"] = "\u1136";
 
-  t["\u317F"] = "\u1140";
 
-  t["\u3180"] = "\u1147";
 
-  t["\u3181"] = "\u114C";
 
-  t["\u3182"] = "\u11F1";
 
-  t["\u3183"] = "\u11F2";
 
-  t["\u3184"] = "\u1157";
 
-  t["\u3185"] = "\u1158";
 
-  t["\u3186"] = "\u1159";
 
-  t["\u3187"] = "\u1184";
 
-  t["\u3188"] = "\u1185";
 
-  t["\u3189"] = "\u1188";
 
-  t["\u318A"] = "\u1191";
 
-  t["\u318B"] = "\u1192";
 
-  t["\u318C"] = "\u1194";
 
-  t["\u318D"] = "\u119E";
 
-  t["\u318E"] = "\u11A1";
 
-  t["\u3200"] = "\u0028\u1100\u0029";
 
-  t["\u3201"] = "\u0028\u1102\u0029";
 
-  t["\u3202"] = "\u0028\u1103\u0029";
 
-  t["\u3203"] = "\u0028\u1105\u0029";
 
-  t["\u3204"] = "\u0028\u1106\u0029";
 
-  t["\u3205"] = "\u0028\u1107\u0029";
 
-  t["\u3206"] = "\u0028\u1109\u0029";
 
-  t["\u3207"] = "\u0028\u110B\u0029";
 
-  t["\u3208"] = "\u0028\u110C\u0029";
 
-  t["\u3209"] = "\u0028\u110E\u0029";
 
-  t["\u320A"] = "\u0028\u110F\u0029";
 
-  t["\u320B"] = "\u0028\u1110\u0029";
 
-  t["\u320C"] = "\u0028\u1111\u0029";
 
-  t["\u320D"] = "\u0028\u1112\u0029";
 
-  t["\u320E"] = "\u0028\u1100\u1161\u0029";
 
-  t["\u320F"] = "\u0028\u1102\u1161\u0029";
 
-  t["\u3210"] = "\u0028\u1103\u1161\u0029";
 
-  t["\u3211"] = "\u0028\u1105\u1161\u0029";
 
-  t["\u3212"] = "\u0028\u1106\u1161\u0029";
 
-  t["\u3213"] = "\u0028\u1107\u1161\u0029";
 
-  t["\u3214"] = "\u0028\u1109\u1161\u0029";
 
-  t["\u3215"] = "\u0028\u110B\u1161\u0029";
 
-  t["\u3216"] = "\u0028\u110C\u1161\u0029";
 
-  t["\u3217"] = "\u0028\u110E\u1161\u0029";
 
-  t["\u3218"] = "\u0028\u110F\u1161\u0029";
 
-  t["\u3219"] = "\u0028\u1110\u1161\u0029";
 
-  t["\u321A"] = "\u0028\u1111\u1161\u0029";
 
-  t["\u321B"] = "\u0028\u1112\u1161\u0029";
 
-  t["\u321C"] = "\u0028\u110C\u116E\u0029";
 
-  t["\u321D"] = "\u0028\u110B\u1169\u110C\u1165\u11AB\u0029";
 
-  t["\u321E"] = "\u0028\u110B\u1169\u1112\u116E\u0029";
 
-  t["\u3220"] = "\u0028\u4E00\u0029";
 
-  t["\u3221"] = "\u0028\u4E8C\u0029";
 
-  t["\u3222"] = "\u0028\u4E09\u0029";
 
-  t["\u3223"] = "\u0028\u56DB\u0029";
 
-  t["\u3224"] = "\u0028\u4E94\u0029";
 
-  t["\u3225"] = "\u0028\u516D\u0029";
 
-  t["\u3226"] = "\u0028\u4E03\u0029";
 
-  t["\u3227"] = "\u0028\u516B\u0029";
 
-  t["\u3228"] = "\u0028\u4E5D\u0029";
 
-  t["\u3229"] = "\u0028\u5341\u0029";
 
-  t["\u322A"] = "\u0028\u6708\u0029";
 
-  t["\u322B"] = "\u0028\u706B\u0029";
 
-  t["\u322C"] = "\u0028\u6C34\u0029";
 
-  t["\u322D"] = "\u0028\u6728\u0029";
 
-  t["\u322E"] = "\u0028\u91D1\u0029";
 
-  t["\u322F"] = "\u0028\u571F\u0029";
 
-  t["\u3230"] = "\u0028\u65E5\u0029";
 
-  t["\u3231"] = "\u0028\u682A\u0029";
 
-  t["\u3232"] = "\u0028\u6709\u0029";
 
-  t["\u3233"] = "\u0028\u793E\u0029";
 
-  t["\u3234"] = "\u0028\u540D\u0029";
 
-  t["\u3235"] = "\u0028\u7279\u0029";
 
-  t["\u3236"] = "\u0028\u8CA1\u0029";
 
-  t["\u3237"] = "\u0028\u795D\u0029";
 
-  t["\u3238"] = "\u0028\u52B4\u0029";
 
-  t["\u3239"] = "\u0028\u4EE3\u0029";
 
-  t["\u323A"] = "\u0028\u547C\u0029";
 
-  t["\u323B"] = "\u0028\u5B66\u0029";
 
-  t["\u323C"] = "\u0028\u76E3\u0029";
 
-  t["\u323D"] = "\u0028\u4F01\u0029";
 
-  t["\u323E"] = "\u0028\u8CC7\u0029";
 
-  t["\u323F"] = "\u0028\u5354\u0029";
 
-  t["\u3240"] = "\u0028\u796D\u0029";
 
-  t["\u3241"] = "\u0028\u4F11\u0029";
 
-  t["\u3242"] = "\u0028\u81EA\u0029";
 
-  t["\u3243"] = "\u0028\u81F3\u0029";
 
-  t["\u32C0"] = "\u0031\u6708";
 
-  t["\u32C1"] = "\u0032\u6708";
 
-  t["\u32C2"] = "\u0033\u6708";
 
-  t["\u32C3"] = "\u0034\u6708";
 
-  t["\u32C4"] = "\u0035\u6708";
 
-  t["\u32C5"] = "\u0036\u6708";
 
-  t["\u32C6"] = "\u0037\u6708";
 
-  t["\u32C7"] = "\u0038\u6708";
 
-  t["\u32C8"] = "\u0039\u6708";
 
-  t["\u32C9"] = "\u0031\u0030\u6708";
 
-  t["\u32CA"] = "\u0031\u0031\u6708";
 
-  t["\u32CB"] = "\u0031\u0032\u6708";
 
-  t["\u3358"] = "\u0030\u70B9";
 
-  t["\u3359"] = "\u0031\u70B9";
 
-  t["\u335A"] = "\u0032\u70B9";
 
-  t["\u335B"] = "\u0033\u70B9";
 
-  t["\u335C"] = "\u0034\u70B9";
 
-  t["\u335D"] = "\u0035\u70B9";
 
-  t["\u335E"] = "\u0036\u70B9";
 
-  t["\u335F"] = "\u0037\u70B9";
 
-  t["\u3360"] = "\u0038\u70B9";
 
-  t["\u3361"] = "\u0039\u70B9";
 
-  t["\u3362"] = "\u0031\u0030\u70B9";
 
-  t["\u3363"] = "\u0031\u0031\u70B9";
 
-  t["\u3364"] = "\u0031\u0032\u70B9";
 
-  t["\u3365"] = "\u0031\u0033\u70B9";
 
-  t["\u3366"] = "\u0031\u0034\u70B9";
 
-  t["\u3367"] = "\u0031\u0035\u70B9";
 
-  t["\u3368"] = "\u0031\u0036\u70B9";
 
-  t["\u3369"] = "\u0031\u0037\u70B9";
 
-  t["\u336A"] = "\u0031\u0038\u70B9";
 
-  t["\u336B"] = "\u0031\u0039\u70B9";
 
-  t["\u336C"] = "\u0032\u0030\u70B9";
 
-  t["\u336D"] = "\u0032\u0031\u70B9";
 
-  t["\u336E"] = "\u0032\u0032\u70B9";
 
-  t["\u336F"] = "\u0032\u0033\u70B9";
 
-  t["\u3370"] = "\u0032\u0034\u70B9";
 
-  t["\u33E0"] = "\u0031\u65E5";
 
-  t["\u33E1"] = "\u0032\u65E5";
 
-  t["\u33E2"] = "\u0033\u65E5";
 
-  t["\u33E3"] = "\u0034\u65E5";
 
-  t["\u33E4"] = "\u0035\u65E5";
 
-  t["\u33E5"] = "\u0036\u65E5";
 
-  t["\u33E6"] = "\u0037\u65E5";
 
-  t["\u33E7"] = "\u0038\u65E5";
 
-  t["\u33E8"] = "\u0039\u65E5";
 
-  t["\u33E9"] = "\u0031\u0030\u65E5";
 
-  t["\u33EA"] = "\u0031\u0031\u65E5";
 
-  t["\u33EB"] = "\u0031\u0032\u65E5";
 
-  t["\u33EC"] = "\u0031\u0033\u65E5";
 
-  t["\u33ED"] = "\u0031\u0034\u65E5";
 
-  t["\u33EE"] = "\u0031\u0035\u65E5";
 
-  t["\u33EF"] = "\u0031\u0036\u65E5";
 
-  t["\u33F0"] = "\u0031\u0037\u65E5";
 
-  t["\u33F1"] = "\u0031\u0038\u65E5";
 
-  t["\u33F2"] = "\u0031\u0039\u65E5";
 
-  t["\u33F3"] = "\u0032\u0030\u65E5";
 
-  t["\u33F4"] = "\u0032\u0031\u65E5";
 
-  t["\u33F5"] = "\u0032\u0032\u65E5";
 
-  t["\u33F6"] = "\u0032\u0033\u65E5";
 
-  t["\u33F7"] = "\u0032\u0034\u65E5";
 
-  t["\u33F8"] = "\u0032\u0035\u65E5";
 
-  t["\u33F9"] = "\u0032\u0036\u65E5";
 
-  t["\u33FA"] = "\u0032\u0037\u65E5";
 
-  t["\u33FB"] = "\u0032\u0038\u65E5";
 
-  t["\u33FC"] = "\u0032\u0039\u65E5";
 
-  t["\u33FD"] = "\u0033\u0030\u65E5";
 
-  t["\u33FE"] = "\u0033\u0031\u65E5";
 
-  t["\uFB00"] = "\u0066\u0066";
 
-  t["\uFB01"] = "\u0066\u0069";
 
-  t["\uFB02"] = "\u0066\u006C";
 
-  t["\uFB03"] = "\u0066\u0066\u0069";
 
-  t["\uFB04"] = "\u0066\u0066\u006C";
 
-  t["\uFB05"] = "\u017F\u0074";
 
-  t["\uFB06"] = "\u0073\u0074";
 
-  t["\uFB13"] = "\u0574\u0576";
 
-  t["\uFB14"] = "\u0574\u0565";
 
-  t["\uFB15"] = "\u0574\u056B";
 
-  t["\uFB16"] = "\u057E\u0576";
 
-  t["\uFB17"] = "\u0574\u056D";
 
-  t["\uFB4F"] = "\u05D0\u05DC";
 
-  t["\uFB50"] = "\u0671";
 
-  t["\uFB51"] = "\u0671";
 
-  t["\uFB52"] = "\u067B";
 
-  t["\uFB53"] = "\u067B";
 
-  t["\uFB54"] = "\u067B";
 
-  t["\uFB55"] = "\u067B";
 
-  t["\uFB56"] = "\u067E";
 
-  t["\uFB57"] = "\u067E";
 
-  t["\uFB58"] = "\u067E";
 
-  t["\uFB59"] = "\u067E";
 
-  t["\uFB5A"] = "\u0680";
 
-  t["\uFB5B"] = "\u0680";
 
-  t["\uFB5C"] = "\u0680";
 
-  t["\uFB5D"] = "\u0680";
 
-  t["\uFB5E"] = "\u067A";
 
-  t["\uFB5F"] = "\u067A";
 
-  t["\uFB60"] = "\u067A";
 
-  t["\uFB61"] = "\u067A";
 
-  t["\uFB62"] = "\u067F";
 
-  t["\uFB63"] = "\u067F";
 
-  t["\uFB64"] = "\u067F";
 
-  t["\uFB65"] = "\u067F";
 
-  t["\uFB66"] = "\u0679";
 
-  t["\uFB67"] = "\u0679";
 
-  t["\uFB68"] = "\u0679";
 
-  t["\uFB69"] = "\u0679";
 
-  t["\uFB6A"] = "\u06A4";
 
-  t["\uFB6B"] = "\u06A4";
 
-  t["\uFB6C"] = "\u06A4";
 
-  t["\uFB6D"] = "\u06A4";
 
-  t["\uFB6E"] = "\u06A6";
 
-  t["\uFB6F"] = "\u06A6";
 
-  t["\uFB70"] = "\u06A6";
 
-  t["\uFB71"] = "\u06A6";
 
-  t["\uFB72"] = "\u0684";
 
-  t["\uFB73"] = "\u0684";
 
-  t["\uFB74"] = "\u0684";
 
-  t["\uFB75"] = "\u0684";
 
-  t["\uFB76"] = "\u0683";
 
-  t["\uFB77"] = "\u0683";
 
-  t["\uFB78"] = "\u0683";
 
-  t["\uFB79"] = "\u0683";
 
-  t["\uFB7A"] = "\u0686";
 
-  t["\uFB7B"] = "\u0686";
 
-  t["\uFB7C"] = "\u0686";
 
-  t["\uFB7D"] = "\u0686";
 
-  t["\uFB7E"] = "\u0687";
 
-  t["\uFB7F"] = "\u0687";
 
-  t["\uFB80"] = "\u0687";
 
-  t["\uFB81"] = "\u0687";
 
-  t["\uFB82"] = "\u068D";
 
-  t["\uFB83"] = "\u068D";
 
-  t["\uFB84"] = "\u068C";
 
-  t["\uFB85"] = "\u068C";
 
-  t["\uFB86"] = "\u068E";
 
-  t["\uFB87"] = "\u068E";
 
-  t["\uFB88"] = "\u0688";
 
-  t["\uFB89"] = "\u0688";
 
-  t["\uFB8A"] = "\u0698";
 
-  t["\uFB8B"] = "\u0698";
 
-  t["\uFB8C"] = "\u0691";
 
-  t["\uFB8D"] = "\u0691";
 
-  t["\uFB8E"] = "\u06A9";
 
-  t["\uFB8F"] = "\u06A9";
 
-  t["\uFB90"] = "\u06A9";
 
-  t["\uFB91"] = "\u06A9";
 
-  t["\uFB92"] = "\u06AF";
 
-  t["\uFB93"] = "\u06AF";
 
-  t["\uFB94"] = "\u06AF";
 
-  t["\uFB95"] = "\u06AF";
 
-  t["\uFB96"] = "\u06B3";
 
-  t["\uFB97"] = "\u06B3";
 
-  t["\uFB98"] = "\u06B3";
 
-  t["\uFB99"] = "\u06B3";
 
-  t["\uFB9A"] = "\u06B1";
 
-  t["\uFB9B"] = "\u06B1";
 
-  t["\uFB9C"] = "\u06B1";
 
-  t["\uFB9D"] = "\u06B1";
 
-  t["\uFB9E"] = "\u06BA";
 
-  t["\uFB9F"] = "\u06BA";
 
-  t["\uFBA0"] = "\u06BB";
 
-  t["\uFBA1"] = "\u06BB";
 
-  t["\uFBA2"] = "\u06BB";
 
-  t["\uFBA3"] = "\u06BB";
 
-  t["\uFBA4"] = "\u06C0";
 
-  t["\uFBA5"] = "\u06C0";
 
-  t["\uFBA6"] = "\u06C1";
 
-  t["\uFBA7"] = "\u06C1";
 
-  t["\uFBA8"] = "\u06C1";
 
-  t["\uFBA9"] = "\u06C1";
 
-  t["\uFBAA"] = "\u06BE";
 
-  t["\uFBAB"] = "\u06BE";
 
-  t["\uFBAC"] = "\u06BE";
 
-  t["\uFBAD"] = "\u06BE";
 
-  t["\uFBAE"] = "\u06D2";
 
-  t["\uFBAF"] = "\u06D2";
 
-  t["\uFBB0"] = "\u06D3";
 
-  t["\uFBB1"] = "\u06D3";
 
-  t["\uFBD3"] = "\u06AD";
 
-  t["\uFBD4"] = "\u06AD";
 
-  t["\uFBD5"] = "\u06AD";
 
-  t["\uFBD6"] = "\u06AD";
 
-  t["\uFBD7"] = "\u06C7";
 
-  t["\uFBD8"] = "\u06C7";
 
-  t["\uFBD9"] = "\u06C6";
 
-  t["\uFBDA"] = "\u06C6";
 
-  t["\uFBDB"] = "\u06C8";
 
-  t["\uFBDC"] = "\u06C8";
 
-  t["\uFBDD"] = "\u0677";
 
-  t["\uFBDE"] = "\u06CB";
 
-  t["\uFBDF"] = "\u06CB";
 
-  t["\uFBE0"] = "\u06C5";
 
-  t["\uFBE1"] = "\u06C5";
 
-  t["\uFBE2"] = "\u06C9";
 
-  t["\uFBE3"] = "\u06C9";
 
-  t["\uFBE4"] = "\u06D0";
 
-  t["\uFBE5"] = "\u06D0";
 
-  t["\uFBE6"] = "\u06D0";
 
-  t["\uFBE7"] = "\u06D0";
 
-  t["\uFBE8"] = "\u0649";
 
-  t["\uFBE9"] = "\u0649";
 
-  t["\uFBEA"] = "\u0626\u0627";
 
-  t["\uFBEB"] = "\u0626\u0627";
 
-  t["\uFBEC"] = "\u0626\u06D5";
 
-  t["\uFBED"] = "\u0626\u06D5";
 
-  t["\uFBEE"] = "\u0626\u0648";
 
-  t["\uFBEF"] = "\u0626\u0648";
 
-  t["\uFBF0"] = "\u0626\u06C7";
 
-  t["\uFBF1"] = "\u0626\u06C7";
 
-  t["\uFBF2"] = "\u0626\u06C6";
 
-  t["\uFBF3"] = "\u0626\u06C6";
 
-  t["\uFBF4"] = "\u0626\u06C8";
 
-  t["\uFBF5"] = "\u0626\u06C8";
 
-  t["\uFBF6"] = "\u0626\u06D0";
 
-  t["\uFBF7"] = "\u0626\u06D0";
 
-  t["\uFBF8"] = "\u0626\u06D0";
 
-  t["\uFBF9"] = "\u0626\u0649";
 
-  t["\uFBFA"] = "\u0626\u0649";
 
-  t["\uFBFB"] = "\u0626\u0649";
 
-  t["\uFBFC"] = "\u06CC";
 
-  t["\uFBFD"] = "\u06CC";
 
-  t["\uFBFE"] = "\u06CC";
 
-  t["\uFBFF"] = "\u06CC";
 
-  t["\uFC00"] = "\u0626\u062C";
 
-  t["\uFC01"] = "\u0626\u062D";
 
-  t["\uFC02"] = "\u0626\u0645";
 
-  t["\uFC03"] = "\u0626\u0649";
 
-  t["\uFC04"] = "\u0626\u064A";
 
-  t["\uFC05"] = "\u0628\u062C";
 
-  t["\uFC06"] = "\u0628\u062D";
 
-  t["\uFC07"] = "\u0628\u062E";
 
-  t["\uFC08"] = "\u0628\u0645";
 
-  t["\uFC09"] = "\u0628\u0649";
 
-  t["\uFC0A"] = "\u0628\u064A";
 
-  t["\uFC0B"] = "\u062A\u062C";
 
-  t["\uFC0C"] = "\u062A\u062D";
 
-  t["\uFC0D"] = "\u062A\u062E";
 
-  t["\uFC0E"] = "\u062A\u0645";
 
-  t["\uFC0F"] = "\u062A\u0649";
 
-  t["\uFC10"] = "\u062A\u064A";
 
-  t["\uFC11"] = "\u062B\u062C";
 
-  t["\uFC12"] = "\u062B\u0645";
 
-  t["\uFC13"] = "\u062B\u0649";
 
-  t["\uFC14"] = "\u062B\u064A";
 
-  t["\uFC15"] = "\u062C\u062D";
 
-  t["\uFC16"] = "\u062C\u0645";
 
-  t["\uFC17"] = "\u062D\u062C";
 
-  t["\uFC18"] = "\u062D\u0645";
 
-  t["\uFC19"] = "\u062E\u062C";
 
-  t["\uFC1A"] = "\u062E\u062D";
 
-  t["\uFC1B"] = "\u062E\u0645";
 
-  t["\uFC1C"] = "\u0633\u062C";
 
-  t["\uFC1D"] = "\u0633\u062D";
 
-  t["\uFC1E"] = "\u0633\u062E";
 
-  t["\uFC1F"] = "\u0633\u0645";
 
-  t["\uFC20"] = "\u0635\u062D";
 
-  t["\uFC21"] = "\u0635\u0645";
 
-  t["\uFC22"] = "\u0636\u062C";
 
-  t["\uFC23"] = "\u0636\u062D";
 
-  t["\uFC24"] = "\u0636\u062E";
 
-  t["\uFC25"] = "\u0636\u0645";
 
-  t["\uFC26"] = "\u0637\u062D";
 
-  t["\uFC27"] = "\u0637\u0645";
 
-  t["\uFC28"] = "\u0638\u0645";
 
-  t["\uFC29"] = "\u0639\u062C";
 
-  t["\uFC2A"] = "\u0639\u0645";
 
-  t["\uFC2B"] = "\u063A\u062C";
 
-  t["\uFC2C"] = "\u063A\u0645";
 
-  t["\uFC2D"] = "\u0641\u062C";
 
-  t["\uFC2E"] = "\u0641\u062D";
 
-  t["\uFC2F"] = "\u0641\u062E";
 
-  t["\uFC30"] = "\u0641\u0645";
 
-  t["\uFC31"] = "\u0641\u0649";
 
-  t["\uFC32"] = "\u0641\u064A";
 
-  t["\uFC33"] = "\u0642\u062D";
 
-  t["\uFC34"] = "\u0642\u0645";
 
-  t["\uFC35"] = "\u0642\u0649";
 
-  t["\uFC36"] = "\u0642\u064A";
 
-  t["\uFC37"] = "\u0643\u0627";
 
-  t["\uFC38"] = "\u0643\u062C";
 
-  t["\uFC39"] = "\u0643\u062D";
 
-  t["\uFC3A"] = "\u0643\u062E";
 
-  t["\uFC3B"] = "\u0643\u0644";
 
-  t["\uFC3C"] = "\u0643\u0645";
 
-  t["\uFC3D"] = "\u0643\u0649";
 
-  t["\uFC3E"] = "\u0643\u064A";
 
-  t["\uFC3F"] = "\u0644\u062C";
 
-  t["\uFC40"] = "\u0644\u062D";
 
-  t["\uFC41"] = "\u0644\u062E";
 
-  t["\uFC42"] = "\u0644\u0645";
 
-  t["\uFC43"] = "\u0644\u0649";
 
-  t["\uFC44"] = "\u0644\u064A";
 
-  t["\uFC45"] = "\u0645\u062C";
 
-  t["\uFC46"] = "\u0645\u062D";
 
-  t["\uFC47"] = "\u0645\u062E";
 
-  t["\uFC48"] = "\u0645\u0645";
 
-  t["\uFC49"] = "\u0645\u0649";
 
-  t["\uFC4A"] = "\u0645\u064A";
 
-  t["\uFC4B"] = "\u0646\u062C";
 
-  t["\uFC4C"] = "\u0646\u062D";
 
-  t["\uFC4D"] = "\u0646\u062E";
 
-  t["\uFC4E"] = "\u0646\u0645";
 
-  t["\uFC4F"] = "\u0646\u0649";
 
-  t["\uFC50"] = "\u0646\u064A";
 
-  t["\uFC51"] = "\u0647\u062C";
 
-  t["\uFC52"] = "\u0647\u0645";
 
-  t["\uFC53"] = "\u0647\u0649";
 
-  t["\uFC54"] = "\u0647\u064A";
 
-  t["\uFC55"] = "\u064A\u062C";
 
-  t["\uFC56"] = "\u064A\u062D";
 
-  t["\uFC57"] = "\u064A\u062E";
 
-  t["\uFC58"] = "\u064A\u0645";
 
-  t["\uFC59"] = "\u064A\u0649";
 
-  t["\uFC5A"] = "\u064A\u064A";
 
-  t["\uFC5B"] = "\u0630\u0670";
 
-  t["\uFC5C"] = "\u0631\u0670";
 
-  t["\uFC5D"] = "\u0649\u0670";
 
-  t["\uFC5E"] = "\u0020\u064C\u0651";
 
-  t["\uFC5F"] = "\u0020\u064D\u0651";
 
-  t["\uFC60"] = "\u0020\u064E\u0651";
 
-  t["\uFC61"] = "\u0020\u064F\u0651";
 
-  t["\uFC62"] = "\u0020\u0650\u0651";
 
-  t["\uFC63"] = "\u0020\u0651\u0670";
 
-  t["\uFC64"] = "\u0626\u0631";
 
-  t["\uFC65"] = "\u0626\u0632";
 
-  t["\uFC66"] = "\u0626\u0645";
 
-  t["\uFC67"] = "\u0626\u0646";
 
-  t["\uFC68"] = "\u0626\u0649";
 
-  t["\uFC69"] = "\u0626\u064A";
 
-  t["\uFC6A"] = "\u0628\u0631";
 
-  t["\uFC6B"] = "\u0628\u0632";
 
-  t["\uFC6C"] = "\u0628\u0645";
 
-  t["\uFC6D"] = "\u0628\u0646";
 
-  t["\uFC6E"] = "\u0628\u0649";
 
-  t["\uFC6F"] = "\u0628\u064A";
 
-  t["\uFC70"] = "\u062A\u0631";
 
-  t["\uFC71"] = "\u062A\u0632";
 
-  t["\uFC72"] = "\u062A\u0645";
 
-  t["\uFC73"] = "\u062A\u0646";
 
-  t["\uFC74"] = "\u062A\u0649";
 
-  t["\uFC75"] = "\u062A\u064A";
 
-  t["\uFC76"] = "\u062B\u0631";
 
-  t["\uFC77"] = "\u062B\u0632";
 
-  t["\uFC78"] = "\u062B\u0645";
 
-  t["\uFC79"] = "\u062B\u0646";
 
-  t["\uFC7A"] = "\u062B\u0649";
 
-  t["\uFC7B"] = "\u062B\u064A";
 
-  t["\uFC7C"] = "\u0641\u0649";
 
-  t["\uFC7D"] = "\u0641\u064A";
 
-  t["\uFC7E"] = "\u0642\u0649";
 
-  t["\uFC7F"] = "\u0642\u064A";
 
-  t["\uFC80"] = "\u0643\u0627";
 
-  t["\uFC81"] = "\u0643\u0644";
 
-  t["\uFC82"] = "\u0643\u0645";
 
-  t["\uFC83"] = "\u0643\u0649";
 
-  t["\uFC84"] = "\u0643\u064A";
 
-  t["\uFC85"] = "\u0644\u0645";
 
-  t["\uFC86"] = "\u0644\u0649";
 
-  t["\uFC87"] = "\u0644\u064A";
 
-  t["\uFC88"] = "\u0645\u0627";
 
-  t["\uFC89"] = "\u0645\u0645";
 
-  t["\uFC8A"] = "\u0646\u0631";
 
-  t["\uFC8B"] = "\u0646\u0632";
 
-  t["\uFC8C"] = "\u0646\u0645";
 
-  t["\uFC8D"] = "\u0646\u0646";
 
-  t["\uFC8E"] = "\u0646\u0649";
 
-  t["\uFC8F"] = "\u0646\u064A";
 
-  t["\uFC90"] = "\u0649\u0670";
 
-  t["\uFC91"] = "\u064A\u0631";
 
-  t["\uFC92"] = "\u064A\u0632";
 
-  t["\uFC93"] = "\u064A\u0645";
 
-  t["\uFC94"] = "\u064A\u0646";
 
-  t["\uFC95"] = "\u064A\u0649";
 
-  t["\uFC96"] = "\u064A\u064A";
 
-  t["\uFC97"] = "\u0626\u062C";
 
-  t["\uFC98"] = "\u0626\u062D";
 
-  t["\uFC99"] = "\u0626\u062E";
 
-  t["\uFC9A"] = "\u0626\u0645";
 
-  t["\uFC9B"] = "\u0626\u0647";
 
-  t["\uFC9C"] = "\u0628\u062C";
 
-  t["\uFC9D"] = "\u0628\u062D";
 
-  t["\uFC9E"] = "\u0628\u062E";
 
-  t["\uFC9F"] = "\u0628\u0645";
 
-  t["\uFCA0"] = "\u0628\u0647";
 
-  t["\uFCA1"] = "\u062A\u062C";
 
-  t["\uFCA2"] = "\u062A\u062D";
 
-  t["\uFCA3"] = "\u062A\u062E";
 
-  t["\uFCA4"] = "\u062A\u0645";
 
-  t["\uFCA5"] = "\u062A\u0647";
 
-  t["\uFCA6"] = "\u062B\u0645";
 
-  t["\uFCA7"] = "\u062C\u062D";
 
-  t["\uFCA8"] = "\u062C\u0645";
 
-  t["\uFCA9"] = "\u062D\u062C";
 
-  t["\uFCAA"] = "\u062D\u0645";
 
-  t["\uFCAB"] = "\u062E\u062C";
 
-  t["\uFCAC"] = "\u062E\u0645";
 
-  t["\uFCAD"] = "\u0633\u062C";
 
-  t["\uFCAE"] = "\u0633\u062D";
 
-  t["\uFCAF"] = "\u0633\u062E";
 
-  t["\uFCB0"] = "\u0633\u0645";
 
-  t["\uFCB1"] = "\u0635\u062D";
 
-  t["\uFCB2"] = "\u0635\u062E";
 
-  t["\uFCB3"] = "\u0635\u0645";
 
-  t["\uFCB4"] = "\u0636\u062C";
 
-  t["\uFCB5"] = "\u0636\u062D";
 
-  t["\uFCB6"] = "\u0636\u062E";
 
-  t["\uFCB7"] = "\u0636\u0645";
 
-  t["\uFCB8"] = "\u0637\u062D";
 
-  t["\uFCB9"] = "\u0638\u0645";
 
-  t["\uFCBA"] = "\u0639\u062C";
 
-  t["\uFCBB"] = "\u0639\u0645";
 
-  t["\uFCBC"] = "\u063A\u062C";
 
-  t["\uFCBD"] = "\u063A\u0645";
 
-  t["\uFCBE"] = "\u0641\u062C";
 
-  t["\uFCBF"] = "\u0641\u062D";
 
-  t["\uFCC0"] = "\u0641\u062E";
 
-  t["\uFCC1"] = "\u0641\u0645";
 
-  t["\uFCC2"] = "\u0642\u062D";
 
-  t["\uFCC3"] = "\u0642\u0645";
 
-  t["\uFCC4"] = "\u0643\u062C";
 
-  t["\uFCC5"] = "\u0643\u062D";
 
-  t["\uFCC6"] = "\u0643\u062E";
 
-  t["\uFCC7"] = "\u0643\u0644";
 
-  t["\uFCC8"] = "\u0643\u0645";
 
-  t["\uFCC9"] = "\u0644\u062C";
 
-  t["\uFCCA"] = "\u0644\u062D";
 
-  t["\uFCCB"] = "\u0644\u062E";
 
-  t["\uFCCC"] = "\u0644\u0645";
 
-  t["\uFCCD"] = "\u0644\u0647";
 
-  t["\uFCCE"] = "\u0645\u062C";
 
-  t["\uFCCF"] = "\u0645\u062D";
 
-  t["\uFCD0"] = "\u0645\u062E";
 
-  t["\uFCD1"] = "\u0645\u0645";
 
-  t["\uFCD2"] = "\u0646\u062C";
 
-  t["\uFCD3"] = "\u0646\u062D";
 
-  t["\uFCD4"] = "\u0646\u062E";
 
-  t["\uFCD5"] = "\u0646\u0645";
 
-  t["\uFCD6"] = "\u0646\u0647";
 
-  t["\uFCD7"] = "\u0647\u062C";
 
-  t["\uFCD8"] = "\u0647\u0645";
 
-  t["\uFCD9"] = "\u0647\u0670";
 
-  t["\uFCDA"] = "\u064A\u062C";
 
-  t["\uFCDB"] = "\u064A\u062D";
 
-  t["\uFCDC"] = "\u064A\u062E";
 
-  t["\uFCDD"] = "\u064A\u0645";
 
-  t["\uFCDE"] = "\u064A\u0647";
 
-  t["\uFCDF"] = "\u0626\u0645";
 
-  t["\uFCE0"] = "\u0626\u0647";
 
-  t["\uFCE1"] = "\u0628\u0645";
 
-  t["\uFCE2"] = "\u0628\u0647";
 
-  t["\uFCE3"] = "\u062A\u0645";
 
-  t["\uFCE4"] = "\u062A\u0647";
 
-  t["\uFCE5"] = "\u062B\u0645";
 
-  t["\uFCE6"] = "\u062B\u0647";
 
-  t["\uFCE7"] = "\u0633\u0645";
 
-  t["\uFCE8"] = "\u0633\u0647";
 
-  t["\uFCE9"] = "\u0634\u0645";
 
-  t["\uFCEA"] = "\u0634\u0647";
 
-  t["\uFCEB"] = "\u0643\u0644";
 
-  t["\uFCEC"] = "\u0643\u0645";
 
-  t["\uFCED"] = "\u0644\u0645";
 
-  t["\uFCEE"] = "\u0646\u0645";
 
-  t["\uFCEF"] = "\u0646\u0647";
 
-  t["\uFCF0"] = "\u064A\u0645";
 
-  t["\uFCF1"] = "\u064A\u0647";
 
-  t["\uFCF2"] = "\u0640\u064E\u0651";
 
-  t["\uFCF3"] = "\u0640\u064F\u0651";
 
-  t["\uFCF4"] = "\u0640\u0650\u0651";
 
-  t["\uFCF5"] = "\u0637\u0649";
 
-  t["\uFCF6"] = "\u0637\u064A";
 
-  t["\uFCF7"] = "\u0639\u0649";
 
-  t["\uFCF8"] = "\u0639\u064A";
 
-  t["\uFCF9"] = "\u063A\u0649";
 
-  t["\uFCFA"] = "\u063A\u064A";
 
-  t["\uFCFB"] = "\u0633\u0649";
 
-  t["\uFCFC"] = "\u0633\u064A";
 
-  t["\uFCFD"] = "\u0634\u0649";
 
-  t["\uFCFE"] = "\u0634\u064A";
 
-  t["\uFCFF"] = "\u062D\u0649";
 
-  t["\uFD00"] = "\u062D\u064A";
 
-  t["\uFD01"] = "\u062C\u0649";
 
-  t["\uFD02"] = "\u062C\u064A";
 
-  t["\uFD03"] = "\u062E\u0649";
 
-  t["\uFD04"] = "\u062E\u064A";
 
-  t["\uFD05"] = "\u0635\u0649";
 
-  t["\uFD06"] = "\u0635\u064A";
 
-  t["\uFD07"] = "\u0636\u0649";
 
-  t["\uFD08"] = "\u0636\u064A";
 
-  t["\uFD09"] = "\u0634\u062C";
 
-  t["\uFD0A"] = "\u0634\u062D";
 
-  t["\uFD0B"] = "\u0634\u062E";
 
-  t["\uFD0C"] = "\u0634\u0645";
 
-  t["\uFD0D"] = "\u0634\u0631";
 
-  t["\uFD0E"] = "\u0633\u0631";
 
-  t["\uFD0F"] = "\u0635\u0631";
 
-  t["\uFD10"] = "\u0636\u0631";
 
-  t["\uFD11"] = "\u0637\u0649";
 
-  t["\uFD12"] = "\u0637\u064A";
 
-  t["\uFD13"] = "\u0639\u0649";
 
-  t["\uFD14"] = "\u0639\u064A";
 
-  t["\uFD15"] = "\u063A\u0649";
 
-  t["\uFD16"] = "\u063A\u064A";
 
-  t["\uFD17"] = "\u0633\u0649";
 
-  t["\uFD18"] = "\u0633\u064A";
 
-  t["\uFD19"] = "\u0634\u0649";
 
-  t["\uFD1A"] = "\u0634\u064A";
 
-  t["\uFD1B"] = "\u062D\u0649";
 
-  t["\uFD1C"] = "\u062D\u064A";
 
-  t["\uFD1D"] = "\u062C\u0649";
 
-  t["\uFD1E"] = "\u062C\u064A";
 
-  t["\uFD1F"] = "\u062E\u0649";
 
-  t["\uFD20"] = "\u062E\u064A";
 
-  t["\uFD21"] = "\u0635\u0649";
 
-  t["\uFD22"] = "\u0635\u064A";
 
-  t["\uFD23"] = "\u0636\u0649";
 
-  t["\uFD24"] = "\u0636\u064A";
 
-  t["\uFD25"] = "\u0634\u062C";
 
-  t["\uFD26"] = "\u0634\u062D";
 
-  t["\uFD27"] = "\u0634\u062E";
 
-  t["\uFD28"] = "\u0634\u0645";
 
-  t["\uFD29"] = "\u0634\u0631";
 
-  t["\uFD2A"] = "\u0633\u0631";
 
-  t["\uFD2B"] = "\u0635\u0631";
 
-  t["\uFD2C"] = "\u0636\u0631";
 
-  t["\uFD2D"] = "\u0634\u062C";
 
-  t["\uFD2E"] = "\u0634\u062D";
 
-  t["\uFD2F"] = "\u0634\u062E";
 
-  t["\uFD30"] = "\u0634\u0645";
 
-  t["\uFD31"] = "\u0633\u0647";
 
-  t["\uFD32"] = "\u0634\u0647";
 
-  t["\uFD33"] = "\u0637\u0645";
 
-  t["\uFD34"] = "\u0633\u062C";
 
-  t["\uFD35"] = "\u0633\u062D";
 
-  t["\uFD36"] = "\u0633\u062E";
 
-  t["\uFD37"] = "\u0634\u062C";
 
-  t["\uFD38"] = "\u0634\u062D";
 
-  t["\uFD39"] = "\u0634\u062E";
 
-  t["\uFD3A"] = "\u0637\u0645";
 
-  t["\uFD3B"] = "\u0638\u0645";
 
-  t["\uFD3C"] = "\u0627\u064B";
 
-  t["\uFD3D"] = "\u0627\u064B";
 
-  t["\uFD50"] = "\u062A\u062C\u0645";
 
-  t["\uFD51"] = "\u062A\u062D\u062C";
 
-  t["\uFD52"] = "\u062A\u062D\u062C";
 
-  t["\uFD53"] = "\u062A\u062D\u0645";
 
-  t["\uFD54"] = "\u062A\u062E\u0645";
 
-  t["\uFD55"] = "\u062A\u0645\u062C";
 
-  t["\uFD56"] = "\u062A\u0645\u062D";
 
-  t["\uFD57"] = "\u062A\u0645\u062E";
 
-  t["\uFD58"] = "\u062C\u0645\u062D";
 
-  t["\uFD59"] = "\u062C\u0645\u062D";
 
-  t["\uFD5A"] = "\u062D\u0645\u064A";
 
-  t["\uFD5B"] = "\u062D\u0645\u0649";
 
-  t["\uFD5C"] = "\u0633\u062D\u062C";
 
-  t["\uFD5D"] = "\u0633\u062C\u062D";
 
-  t["\uFD5E"] = "\u0633\u062C\u0649";
 
-  t["\uFD5F"] = "\u0633\u0645\u062D";
 
-  t["\uFD60"] = "\u0633\u0645\u062D";
 
-  t["\uFD61"] = "\u0633\u0645\u062C";
 
-  t["\uFD62"] = "\u0633\u0645\u0645";
 
-  t["\uFD63"] = "\u0633\u0645\u0645";
 
-  t["\uFD64"] = "\u0635\u062D\u062D";
 
-  t["\uFD65"] = "\u0635\u062D\u062D";
 
-  t["\uFD66"] = "\u0635\u0645\u0645";
 
-  t["\uFD67"] = "\u0634\u062D\u0645";
 
-  t["\uFD68"] = "\u0634\u062D\u0645";
 
-  t["\uFD69"] = "\u0634\u062C\u064A";
 
-  t["\uFD6A"] = "\u0634\u0645\u062E";
 
-  t["\uFD6B"] = "\u0634\u0645\u062E";
 
-  t["\uFD6C"] = "\u0634\u0645\u0645";
 
-  t["\uFD6D"] = "\u0634\u0645\u0645";
 
-  t["\uFD6E"] = "\u0636\u062D\u0649";
 
-  t["\uFD6F"] = "\u0636\u062E\u0645";
 
-  t["\uFD70"] = "\u0636\u062E\u0645";
 
-  t["\uFD71"] = "\u0637\u0645\u062D";
 
-  t["\uFD72"] = "\u0637\u0645\u062D";
 
-  t["\uFD73"] = "\u0637\u0645\u0645";
 
-  t["\uFD74"] = "\u0637\u0645\u064A";
 
-  t["\uFD75"] = "\u0639\u062C\u0645";
 
-  t["\uFD76"] = "\u0639\u0645\u0645";
 
-  t["\uFD77"] = "\u0639\u0645\u0645";
 
-  t["\uFD78"] = "\u0639\u0645\u0649";
 
-  t["\uFD79"] = "\u063A\u0645\u0645";
 
-  t["\uFD7A"] = "\u063A\u0645\u064A";
 
-  t["\uFD7B"] = "\u063A\u0645\u0649";
 
-  t["\uFD7C"] = "\u0641\u062E\u0645";
 
-  t["\uFD7D"] = "\u0641\u062E\u0645";
 
-  t["\uFD7E"] = "\u0642\u0645\u062D";
 
-  t["\uFD7F"] = "\u0642\u0645\u0645";
 
-  t["\uFD80"] = "\u0644\u062D\u0645";
 
-  t["\uFD81"] = "\u0644\u062D\u064A";
 
-  t["\uFD82"] = "\u0644\u062D\u0649";
 
-  t["\uFD83"] = "\u0644\u062C\u062C";
 
-  t["\uFD84"] = "\u0644\u062C\u062C";
 
-  t["\uFD85"] = "\u0644\u062E\u0645";
 
-  t["\uFD86"] = "\u0644\u062E\u0645";
 
-  t["\uFD87"] = "\u0644\u0645\u062D";
 
-  t["\uFD88"] = "\u0644\u0645\u062D";
 
-  t["\uFD89"] = "\u0645\u062D\u062C";
 
-  t["\uFD8A"] = "\u0645\u062D\u0645";
 
-  t["\uFD8B"] = "\u0645\u062D\u064A";
 
-  t["\uFD8C"] = "\u0645\u062C\u062D";
 
-  t["\uFD8D"] = "\u0645\u062C\u0645";
 
-  t["\uFD8E"] = "\u0645\u062E\u062C";
 
-  t["\uFD8F"] = "\u0645\u062E\u0645";
 
-  t["\uFD92"] = "\u0645\u062C\u062E";
 
-  t["\uFD93"] = "\u0647\u0645\u062C";
 
-  t["\uFD94"] = "\u0647\u0645\u0645";
 
-  t["\uFD95"] = "\u0646\u062D\u0645";
 
-  t["\uFD96"] = "\u0646\u062D\u0649";
 
-  t["\uFD97"] = "\u0646\u062C\u0645";
 
-  t["\uFD98"] = "\u0646\u062C\u0645";
 
-  t["\uFD99"] = "\u0646\u062C\u0649";
 
-  t["\uFD9A"] = "\u0646\u0645\u064A";
 
-  t["\uFD9B"] = "\u0646\u0645\u0649";
 
-  t["\uFD9C"] = "\u064A\u0645\u0645";
 
-  t["\uFD9D"] = "\u064A\u0645\u0645";
 
-  t["\uFD9E"] = "\u0628\u062E\u064A";
 
-  t["\uFD9F"] = "\u062A\u062C\u064A";
 
-  t["\uFDA0"] = "\u062A\u062C\u0649";
 
-  t["\uFDA1"] = "\u062A\u062E\u064A";
 
-  t["\uFDA2"] = "\u062A\u062E\u0649";
 
-  t["\uFDA3"] = "\u062A\u0645\u064A";
 
-  t["\uFDA4"] = "\u062A\u0645\u0649";
 
-  t["\uFDA5"] = "\u062C\u0645\u064A";
 
-  t["\uFDA6"] = "\u062C\u062D\u0649";
 
-  t["\uFDA7"] = "\u062C\u0645\u0649";
 
-  t["\uFDA8"] = "\u0633\u062E\u0649";
 
-  t["\uFDA9"] = "\u0635\u062D\u064A";
 
-  t["\uFDAA"] = "\u0634\u062D\u064A";
 
-  t["\uFDAB"] = "\u0636\u062D\u064A";
 
-  t["\uFDAC"] = "\u0644\u062C\u064A";
 
-  t["\uFDAD"] = "\u0644\u0645\u064A";
 
-  t["\uFDAE"] = "\u064A\u062D\u064A";
 
-  t["\uFDAF"] = "\u064A\u062C\u064A";
 
-  t["\uFDB0"] = "\u064A\u0645\u064A";
 
-  t["\uFDB1"] = "\u0645\u0645\u064A";
 
-  t["\uFDB2"] = "\u0642\u0645\u064A";
 
-  t["\uFDB3"] = "\u0646\u062D\u064A";
 
-  t["\uFDB4"] = "\u0642\u0645\u062D";
 
-  t["\uFDB5"] = "\u0644\u062D\u0645";
 
-  t["\uFDB6"] = "\u0639\u0645\u064A";
 
-  t["\uFDB7"] = "\u0643\u0645\u064A";
 
-  t["\uFDB8"] = "\u0646\u062C\u062D";
 
-  t["\uFDB9"] = "\u0645\u062E\u064A";
 
-  t["\uFDBA"] = "\u0644\u062C\u0645";
 
-  t["\uFDBB"] = "\u0643\u0645\u0645";
 
-  t["\uFDBC"] = "\u0644\u062C\u0645";
 
-  t["\uFDBD"] = "\u0646\u062C\u062D";
 
-  t["\uFDBE"] = "\u062C\u062D\u064A";
 
-  t["\uFDBF"] = "\u062D\u062C\u064A";
 
-  t["\uFDC0"] = "\u0645\u062C\u064A";
 
-  t["\uFDC1"] = "\u0641\u0645\u064A";
 
-  t["\uFDC2"] = "\u0628\u062D\u064A";
 
-  t["\uFDC3"] = "\u0643\u0645\u0645";
 
-  t["\uFDC4"] = "\u0639\u062C\u0645";
 
-  t["\uFDC5"] = "\u0635\u0645\u0645";
 
-  t["\uFDC6"] = "\u0633\u062E\u064A";
 
-  t["\uFDC7"] = "\u0646\u062C\u064A";
 
-  t["\uFE49"] = "\u203E";
 
-  t["\uFE4A"] = "\u203E";
 
-  t["\uFE4B"] = "\u203E";
 
-  t["\uFE4C"] = "\u203E";
 
-  t["\uFE4D"] = "\u005F";
 
-  t["\uFE4E"] = "\u005F";
 
-  t["\uFE4F"] = "\u005F";
 
-  t["\uFE80"] = "\u0621";
 
-  t["\uFE81"] = "\u0622";
 
-  t["\uFE82"] = "\u0622";
 
-  t["\uFE83"] = "\u0623";
 
-  t["\uFE84"] = "\u0623";
 
-  t["\uFE85"] = "\u0624";
 
-  t["\uFE86"] = "\u0624";
 
-  t["\uFE87"] = "\u0625";
 
-  t["\uFE88"] = "\u0625";
 
-  t["\uFE89"] = "\u0626";
 
-  t["\uFE8A"] = "\u0626";
 
-  t["\uFE8B"] = "\u0626";
 
-  t["\uFE8C"] = "\u0626";
 
-  t["\uFE8D"] = "\u0627";
 
-  t["\uFE8E"] = "\u0627";
 
-  t["\uFE8F"] = "\u0628";
 
-  t["\uFE90"] = "\u0628";
 
-  t["\uFE91"] = "\u0628";
 
-  t["\uFE92"] = "\u0628";
 
-  t["\uFE93"] = "\u0629";
 
-  t["\uFE94"] = "\u0629";
 
-  t["\uFE95"] = "\u062A";
 
-  t["\uFE96"] = "\u062A";
 
-  t["\uFE97"] = "\u062A";
 
-  t["\uFE98"] = "\u062A";
 
-  t["\uFE99"] = "\u062B";
 
-  t["\uFE9A"] = "\u062B";
 
-  t["\uFE9B"] = "\u062B";
 
-  t["\uFE9C"] = "\u062B";
 
-  t["\uFE9D"] = "\u062C";
 
-  t["\uFE9E"] = "\u062C";
 
-  t["\uFE9F"] = "\u062C";
 
-  t["\uFEA0"] = "\u062C";
 
-  t["\uFEA1"] = "\u062D";
 
-  t["\uFEA2"] = "\u062D";
 
-  t["\uFEA3"] = "\u062D";
 
-  t["\uFEA4"] = "\u062D";
 
-  t["\uFEA5"] = "\u062E";
 
-  t["\uFEA6"] = "\u062E";
 
-  t["\uFEA7"] = "\u062E";
 
-  t["\uFEA8"] = "\u062E";
 
-  t["\uFEA9"] = "\u062F";
 
-  t["\uFEAA"] = "\u062F";
 
-  t["\uFEAB"] = "\u0630";
 
-  t["\uFEAC"] = "\u0630";
 
-  t["\uFEAD"] = "\u0631";
 
-  t["\uFEAE"] = "\u0631";
 
-  t["\uFEAF"] = "\u0632";
 
-  t["\uFEB0"] = "\u0632";
 
-  t["\uFEB1"] = "\u0633";
 
-  t["\uFEB2"] = "\u0633";
 
-  t["\uFEB3"] = "\u0633";
 
-  t["\uFEB4"] = "\u0633";
 
-  t["\uFEB5"] = "\u0634";
 
-  t["\uFEB6"] = "\u0634";
 
-  t["\uFEB7"] = "\u0634";
 
-  t["\uFEB8"] = "\u0634";
 
-  t["\uFEB9"] = "\u0635";
 
-  t["\uFEBA"] = "\u0635";
 
-  t["\uFEBB"] = "\u0635";
 
-  t["\uFEBC"] = "\u0635";
 
-  t["\uFEBD"] = "\u0636";
 
-  t["\uFEBE"] = "\u0636";
 
-  t["\uFEBF"] = "\u0636";
 
-  t["\uFEC0"] = "\u0636";
 
-  t["\uFEC1"] = "\u0637";
 
-  t["\uFEC2"] = "\u0637";
 
-  t["\uFEC3"] = "\u0637";
 
-  t["\uFEC4"] = "\u0637";
 
-  t["\uFEC5"] = "\u0638";
 
-  t["\uFEC6"] = "\u0638";
 
-  t["\uFEC7"] = "\u0638";
 
-  t["\uFEC8"] = "\u0638";
 
-  t["\uFEC9"] = "\u0639";
 
-  t["\uFECA"] = "\u0639";
 
-  t["\uFECB"] = "\u0639";
 
-  t["\uFECC"] = "\u0639";
 
-  t["\uFECD"] = "\u063A";
 
-  t["\uFECE"] = "\u063A";
 
-  t["\uFECF"] = "\u063A";
 
-  t["\uFED0"] = "\u063A";
 
-  t["\uFED1"] = "\u0641";
 
-  t["\uFED2"] = "\u0641";
 
-  t["\uFED3"] = "\u0641";
 
-  t["\uFED4"] = "\u0641";
 
-  t["\uFED5"] = "\u0642";
 
-  t["\uFED6"] = "\u0642";
 
-  t["\uFED7"] = "\u0642";
 
-  t["\uFED8"] = "\u0642";
 
-  t["\uFED9"] = "\u0643";
 
-  t["\uFEDA"] = "\u0643";
 
-  t["\uFEDB"] = "\u0643";
 
-  t["\uFEDC"] = "\u0643";
 
-  t["\uFEDD"] = "\u0644";
 
-  t["\uFEDE"] = "\u0644";
 
-  t["\uFEDF"] = "\u0644";
 
-  t["\uFEE0"] = "\u0644";
 
-  t["\uFEE1"] = "\u0645";
 
-  t["\uFEE2"] = "\u0645";
 
-  t["\uFEE3"] = "\u0645";
 
-  t["\uFEE4"] = "\u0645";
 
-  t["\uFEE5"] = "\u0646";
 
-  t["\uFEE6"] = "\u0646";
 
-  t["\uFEE7"] = "\u0646";
 
-  t["\uFEE8"] = "\u0646";
 
-  t["\uFEE9"] = "\u0647";
 
-  t["\uFEEA"] = "\u0647";
 
-  t["\uFEEB"] = "\u0647";
 
-  t["\uFEEC"] = "\u0647";
 
-  t["\uFEED"] = "\u0648";
 
-  t["\uFEEE"] = "\u0648";
 
-  t["\uFEEF"] = "\u0649";
 
-  t["\uFEF0"] = "\u0649";
 
-  t["\uFEF1"] = "\u064A";
 
-  t["\uFEF2"] = "\u064A";
 
-  t["\uFEF3"] = "\u064A";
 
-  t["\uFEF4"] = "\u064A";
 
-  t["\uFEF5"] = "\u0644\u0622";
 
-  t["\uFEF6"] = "\u0644\u0622";
 
-  t["\uFEF7"] = "\u0644\u0623";
 
-  t["\uFEF8"] = "\u0644\u0623";
 
-  t["\uFEF9"] = "\u0644\u0625";
 
-  t["\uFEFA"] = "\u0644\u0625";
 
-  t["\uFEFB"] = "\u0644\u0627";
 
-  t["\uFEFC"] = "\u0644\u0627";
 
- });
 
- function reverseIfRtl(chars) {
 
-  var charsLength = chars.length;
 
-  if (charsLength <= 1 || !isRTLRangeFor(chars.charCodeAt(0))) {
 
-   return chars;
 
-  }
 
-  var s = "";
 
-  for (var ii = charsLength - 1; ii >= 0; ii--) {
 
-   s += chars[ii];
 
-  }
 
-  return s;
 
- }
 
- exports.mapSpecialUnicodeValues = mapSpecialUnicodeValues;
 
- exports.reverseIfRtl = reverseIfRtl;
 
- exports.getUnicodeRangeFor = getUnicodeRangeFor;
 
- exports.getNormalizedUnicodes = getNormalizedUnicodes;
 
- exports.getUnicodeForGlyph = getUnicodeForGlyph;
 
- /***/ }),
 
- /* 34 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.FontRendererFactory = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _cff_parser = __w_pdfjs_require__(28);
 
- var _glyphlist = __w_pdfjs_require__(31);
 
- var _encodings = __w_pdfjs_require__(30);
 
- var _stream = __w_pdfjs_require__(11);
 
- var FontRendererFactory = function FontRendererFactoryClosure() {
 
-   function getLong(data, offset) {
 
-     return data[offset] << 24 | data[offset + 1] << 16 | data[offset + 2] << 8 | data[offset + 3];
 
-   }
 
-   function getUshort(data, offset) {
 
-     return data[offset] << 8 | data[offset + 1];
 
-   }
 
-   function getSubroutineBias(subrs) {
 
-     const numSubrs = subrs.length;
 
-     let bias = 32768;
 
-     if (numSubrs < 1240) {
 
-       bias = 107;
 
-     } else if (numSubrs < 33900) {
 
-       bias = 1131;
 
-     }
 
-     return bias;
 
-   }
 
-   function parseCmap(data, start, end) {
 
-     var offset = getUshort(data, start + 2) === 1 ? getLong(data, start + 8) : getLong(data, start + 16);
 
-     var format = getUshort(data, start + offset);
 
-     var ranges, p, i;
 
-     if (format === 4) {
 
-       getUshort(data, start + offset + 2);
 
-       var segCount = getUshort(data, start + offset + 6) >> 1;
 
-       p = start + offset + 14;
 
-       ranges = [];
 
-       for (i = 0; i < segCount; i++, p += 2) {
 
-         ranges[i] = {
 
-           end: getUshort(data, p)
 
-         };
 
-       }
 
-       p += 2;
 
-       for (i = 0; i < segCount; i++, p += 2) {
 
-         ranges[i].start = getUshort(data, p);
 
-       }
 
-       for (i = 0; i < segCount; i++, p += 2) {
 
-         ranges[i].idDelta = getUshort(data, p);
 
-       }
 
-       for (i = 0; i < segCount; i++, p += 2) {
 
-         var idOffset = getUshort(data, p);
 
-         if (idOffset === 0) {
 
-           continue;
 
-         }
 
-         ranges[i].ids = [];
 
-         for (var j = 0, jj = ranges[i].end - ranges[i].start + 1; j < jj; j++) {
 
-           ranges[i].ids[j] = getUshort(data, p + idOffset);
 
-           idOffset += 2;
 
-         }
 
-       }
 
-       return ranges;
 
-     } else if (format === 12) {
 
-       getLong(data, start + offset + 4);
 
-       var groups = getLong(data, start + offset + 12);
 
-       p = start + offset + 16;
 
-       ranges = [];
 
-       for (i = 0; i < groups; i++) {
 
-         ranges.push({
 
-           start: getLong(data, p),
 
-           end: getLong(data, p + 4),
 
-           idDelta: getLong(data, p + 8) - getLong(data, p)
 
-         });
 
-         p += 12;
 
-       }
 
-       return ranges;
 
-     }
 
-     throw new _util.FormatError(`unsupported cmap: ${format}`);
 
-   }
 
-   function parseCff(data, start, end, seacAnalysisEnabled) {
 
-     var properties = {};
 
-     var parser = new _cff_parser.CFFParser(new _stream.Stream(data, start, end - start), properties, seacAnalysisEnabled);
 
-     var cff = parser.parse();
 
-     return {
 
-       glyphs: cff.charStrings.objects,
 
-       subrs: cff.topDict.privateDict && cff.topDict.privateDict.subrsIndex && cff.topDict.privateDict.subrsIndex.objects,
 
-       gsubrs: cff.globalSubrIndex && cff.globalSubrIndex.objects,
 
-       isCFFCIDFont: cff.isCIDFont,
 
-       fdSelect: cff.fdSelect,
 
-       fdArray: cff.fdArray
 
-     };
 
-   }
 
-   function parseGlyfTable(glyf, loca, isGlyphLocationsLong) {
 
-     var itemSize, itemDecode;
 
-     if (isGlyphLocationsLong) {
 
-       itemSize = 4;
 
-       itemDecode = function fontItemDecodeLong(data, offset) {
 
-         return data[offset] << 24 | data[offset + 1] << 16 | data[offset + 2] << 8 | data[offset + 3];
 
-       };
 
-     } else {
 
-       itemSize = 2;
 
-       itemDecode = function fontItemDecode(data, offset) {
 
-         return data[offset] << 9 | data[offset + 1] << 1;
 
-       };
 
-     }
 
-     var glyphs = [];
 
-     var startOffset = itemDecode(loca, 0);
 
-     for (var j = itemSize; j < loca.length; j += itemSize) {
 
-       var endOffset = itemDecode(loca, j);
 
-       glyphs.push(glyf.subarray(startOffset, endOffset));
 
-       startOffset = endOffset;
 
-     }
 
-     return glyphs;
 
-   }
 
-   function lookupCmap(ranges, unicode) {
 
-     var code = unicode.codePointAt(0),
 
-         gid = 0;
 
-     var l = 0,
 
-         r = ranges.length - 1;
 
-     while (l < r) {
 
-       var c = l + r + 1 >> 1;
 
-       if (code < ranges[c].start) {
 
-         r = c - 1;
 
-       } else {
 
-         l = c;
 
-       }
 
-     }
 
-     if (ranges[l].start <= code && code <= ranges[l].end) {
 
-       gid = ranges[l].idDelta + (ranges[l].ids ? ranges[l].ids[code - ranges[l].start] : code) & 0xffff;
 
-     }
 
-     return {
 
-       charCode: code,
 
-       glyphId: gid
 
-     };
 
-   }
 
-   function compileGlyf(code, cmds, font) {
 
-     function moveTo(x, y) {
 
-       cmds.push({
 
-         cmd: "moveTo",
 
-         args: [x, y]
 
-       });
 
-     }
 
-     function lineTo(x, y) {
 
-       cmds.push({
 
-         cmd: "lineTo",
 
-         args: [x, y]
 
-       });
 
-     }
 
-     function quadraticCurveTo(xa, ya, x, y) {
 
-       cmds.push({
 
-         cmd: "quadraticCurveTo",
 
-         args: [xa, ya, x, y]
 
-       });
 
-     }
 
-     var i = 0;
 
-     var numberOfContours = (code[i] << 24 | code[i + 1] << 16) >> 16;
 
-     var flags;
 
-     var x = 0,
 
-         y = 0;
 
-     i += 10;
 
-     if (numberOfContours < 0) {
 
-       do {
 
-         flags = code[i] << 8 | code[i + 1];
 
-         var glyphIndex = code[i + 2] << 8 | code[i + 3];
 
-         i += 4;
 
-         var arg1, arg2;
 
-         if (flags & 0x01) {
 
-           arg1 = (code[i] << 24 | code[i + 1] << 16) >> 16;
 
-           arg2 = (code[i + 2] << 24 | code[i + 3] << 16) >> 16;
 
-           i += 4;
 
-         } else {
 
-           arg1 = code[i++];
 
-           arg2 = code[i++];
 
-         }
 
-         if (flags & 0x02) {
 
-           x = arg1;
 
-           y = arg2;
 
-         } else {
 
-           x = 0;
 
-           y = 0;
 
-         }
 
-         var scaleX = 1,
 
-             scaleY = 1,
 
-             scale01 = 0,
 
-             scale10 = 0;
 
-         if (flags & 0x08) {
 
-           scaleX = scaleY = (code[i] << 24 | code[i + 1] << 16) / 1073741824;
 
-           i += 2;
 
-         } else if (flags & 0x40) {
 
-           scaleX = (code[i] << 24 | code[i + 1] << 16) / 1073741824;
 
-           scaleY = (code[i + 2] << 24 | code[i + 3] << 16) / 1073741824;
 
-           i += 4;
 
-         } else if (flags & 0x80) {
 
-           scaleX = (code[i] << 24 | code[i + 1] << 16) / 1073741824;
 
-           scale01 = (code[i + 2] << 24 | code[i + 3] << 16) / 1073741824;
 
-           scale10 = (code[i + 4] << 24 | code[i + 5] << 16) / 1073741824;
 
-           scaleY = (code[i + 6] << 24 | code[i + 7] << 16) / 1073741824;
 
-           i += 8;
 
-         }
 
-         var subglyph = font.glyphs[glyphIndex];
 
-         if (subglyph) {
 
-           cmds.push({
 
-             cmd: "save"
 
-           });
 
-           cmds.push({
 
-             cmd: "transform",
 
-             args: [scaleX, scale01, scale10, scaleY, x, y]
 
-           });
 
-           compileGlyf(subglyph, cmds, font);
 
-           cmds.push({
 
-             cmd: "restore"
 
-           });
 
-         }
 
-       } while (flags & 0x20);
 
-     } else {
 
-       var endPtsOfContours = [];
 
-       var j, jj;
 
-       for (j = 0; j < numberOfContours; j++) {
 
-         endPtsOfContours.push(code[i] << 8 | code[i + 1]);
 
-         i += 2;
 
-       }
 
-       var instructionLength = code[i] << 8 | code[i + 1];
 
-       i += 2 + instructionLength;
 
-       var numberOfPoints = endPtsOfContours[endPtsOfContours.length - 1] + 1;
 
-       var points = [];
 
-       while (points.length < numberOfPoints) {
 
-         flags = code[i++];
 
-         var repeat = 1;
 
-         if (flags & 0x08) {
 
-           repeat += code[i++];
 
-         }
 
-         while (repeat-- > 0) {
 
-           points.push({
 
-             flags
 
-           });
 
-         }
 
-       }
 
-       for (j = 0; j < numberOfPoints; j++) {
 
-         switch (points[j].flags & 0x12) {
 
-           case 0x00:
 
-             x += (code[i] << 24 | code[i + 1] << 16) >> 16;
 
-             i += 2;
 
-             break;
 
-           case 0x02:
 
-             x -= code[i++];
 
-             break;
 
-           case 0x12:
 
-             x += code[i++];
 
-             break;
 
-         }
 
-         points[j].x = x;
 
-       }
 
-       for (j = 0; j < numberOfPoints; j++) {
 
-         switch (points[j].flags & 0x24) {
 
-           case 0x00:
 
-             y += (code[i] << 24 | code[i + 1] << 16) >> 16;
 
-             i += 2;
 
-             break;
 
-           case 0x04:
 
-             y -= code[i++];
 
-             break;
 
-           case 0x24:
 
-             y += code[i++];
 
-             break;
 
-         }
 
-         points[j].y = y;
 
-       }
 
-       var startPoint = 0;
 
-       for (i = 0; i < numberOfContours; i++) {
 
-         var endPoint = endPtsOfContours[i];
 
-         var contour = points.slice(startPoint, endPoint + 1);
 
-         if (contour[0].flags & 1) {
 
-           contour.push(contour[0]);
 
-         } else if (contour[contour.length - 1].flags & 1) {
 
-           contour.unshift(contour[contour.length - 1]);
 
-         } else {
 
-           var p = {
 
-             flags: 1,
 
-             x: (contour[0].x + contour[contour.length - 1].x) / 2,
 
-             y: (contour[0].y + contour[contour.length - 1].y) / 2
 
-           };
 
-           contour.unshift(p);
 
-           contour.push(p);
 
-         }
 
-         moveTo(contour[0].x, contour[0].y);
 
-         for (j = 1, jj = contour.length; j < jj; j++) {
 
-           if (contour[j].flags & 1) {
 
-             lineTo(contour[j].x, contour[j].y);
 
-           } else if (contour[j + 1].flags & 1) {
 
-             quadraticCurveTo(contour[j].x, contour[j].y, contour[j + 1].x, contour[j + 1].y);
 
-             j++;
 
-           } else {
 
-             quadraticCurveTo(contour[j].x, contour[j].y, (contour[j].x + contour[j + 1].x) / 2, (contour[j].y + contour[j + 1].y) / 2);
 
-           }
 
-         }
 
-         startPoint = endPoint + 1;
 
-       }
 
-     }
 
-   }
 
-   function compileCharString(code, cmds, font, glyphId) {
 
-     var stack = [];
 
-     var x = 0,
 
-         y = 0;
 
-     var stems = 0;
 
-     function moveTo(x, y) {
 
-       cmds.push({
 
-         cmd: "moveTo",
 
-         args: [x, y]
 
-       });
 
-     }
 
-     function lineTo(x, y) {
 
-       cmds.push({
 
-         cmd: "lineTo",
 
-         args: [x, y]
 
-       });
 
-     }
 
-     function bezierCurveTo(x1, y1, x2, y2, x, y) {
 
-       cmds.push({
 
-         cmd: "bezierCurveTo",
 
-         args: [x1, y1, x2, y2, x, y]
 
-       });
 
-     }
 
-     function parse(code) {
 
-       var i = 0;
 
-       while (i < code.length) {
 
-         var stackClean = false;
 
-         var v = code[i++];
 
-         var xa, xb, ya, yb, y1, y2, y3, n, subrCode;
 
-         switch (v) {
 
-           case 1:
 
-             stems += stack.length >> 1;
 
-             stackClean = true;
 
-             break;
 
-           case 3:
 
-             stems += stack.length >> 1;
 
-             stackClean = true;
 
-             break;
 
-           case 4:
 
-             y += stack.pop();
 
-             moveTo(x, y);
 
-             stackClean = true;
 
-             break;
 
-           case 5:
 
-             while (stack.length > 0) {
 
-               x += stack.shift();
 
-               y += stack.shift();
 
-               lineTo(x, y);
 
-             }
 
-             break;
 
-           case 6:
 
-             while (stack.length > 0) {
 
-               x += stack.shift();
 
-               lineTo(x, y);
 
-               if (stack.length === 0) {
 
-                 break;
 
-               }
 
-               y += stack.shift();
 
-               lineTo(x, y);
 
-             }
 
-             break;
 
-           case 7:
 
-             while (stack.length > 0) {
 
-               y += stack.shift();
 
-               lineTo(x, y);
 
-               if (stack.length === 0) {
 
-                 break;
 
-               }
 
-               x += stack.shift();
 
-               lineTo(x, y);
 
-             }
 
-             break;
 
-           case 8:
 
-             while (stack.length > 0) {
 
-               xa = x + stack.shift();
 
-               ya = y + stack.shift();
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb + stack.shift();
 
-               y = yb + stack.shift();
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             break;
 
-           case 10:
 
-             n = stack.pop();
 
-             subrCode = null;
 
-             if (font.isCFFCIDFont) {
 
-               const fdIndex = font.fdSelect.getFDIndex(glyphId);
 
-               if (fdIndex >= 0 && fdIndex < font.fdArray.length) {
 
-                 const fontDict = font.fdArray[fdIndex];
 
-                 let subrs;
 
-                 if (fontDict.privateDict && fontDict.privateDict.subrsIndex) {
 
-                   subrs = fontDict.privateDict.subrsIndex.objects;
 
-                 }
 
-                 if (subrs) {
 
-                   n += getSubroutineBias(subrs);
 
-                   subrCode = subrs[n];
 
-                 }
 
-               } else {
 
-                 (0, _util.warn)("Invalid fd index for glyph index.");
 
-               }
 
-             } else {
 
-               subrCode = font.subrs[n + font.subrsBias];
 
-             }
 
-             if (subrCode) {
 
-               parse(subrCode);
 
-             }
 
-             break;
 
-           case 11:
 
-             return;
 
-           case 12:
 
-             v = code[i++];
 
-             switch (v) {
 
-               case 34:
 
-                 xa = x + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 y1 = y + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 bezierCurveTo(xa, y, xb, y1, x, y1);
 
-                 xa = x + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 bezierCurveTo(xa, y1, xb, y, x, y);
 
-                 break;
 
-               case 35:
 
-                 xa = x + stack.shift();
 
-                 ya = y + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 yb = ya + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 y = yb + stack.shift();
 
-                 bezierCurveTo(xa, ya, xb, yb, x, y);
 
-                 xa = x + stack.shift();
 
-                 ya = y + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 yb = ya + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 y = yb + stack.shift();
 
-                 bezierCurveTo(xa, ya, xb, yb, x, y);
 
-                 stack.pop();
 
-                 break;
 
-               case 36:
 
-                 xa = x + stack.shift();
 
-                 y1 = y + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 y2 = y1 + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 bezierCurveTo(xa, y1, xb, y2, x, y2);
 
-                 xa = x + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 y3 = y2 + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 bezierCurveTo(xa, y2, xb, y3, x, y);
 
-                 break;
 
-               case 37:
 
-                 var x0 = x,
 
-                     y0 = y;
 
-                 xa = x + stack.shift();
 
-                 ya = y + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 yb = ya + stack.shift();
 
-                 x = xb + stack.shift();
 
-                 y = yb + stack.shift();
 
-                 bezierCurveTo(xa, ya, xb, yb, x, y);
 
-                 xa = x + stack.shift();
 
-                 ya = y + stack.shift();
 
-                 xb = xa + stack.shift();
 
-                 yb = ya + stack.shift();
 
-                 x = xb;
 
-                 y = yb;
 
-                 if (Math.abs(x - x0) > Math.abs(y - y0)) {
 
-                   x += stack.shift();
 
-                 } else {
 
-                   y += stack.shift();
 
-                 }
 
-                 bezierCurveTo(xa, ya, xb, yb, x, y);
 
-                 break;
 
-               default:
 
-                 throw new _util.FormatError(`unknown operator: 12 ${v}`);
 
-             }
 
-             break;
 
-           case 14:
 
-             if (stack.length >= 4) {
 
-               var achar = stack.pop();
 
-               var bchar = stack.pop();
 
-               y = stack.pop();
 
-               x = stack.pop();
 
-               cmds.push({
 
-                 cmd: "save"
 
-               });
 
-               cmds.push({
 
-                 cmd: "translate",
 
-                 args: [x, y]
 
-               });
 
-               var cmap = lookupCmap(font.cmap, String.fromCharCode(font.glyphNameMap[_encodings.StandardEncoding[achar]]));
 
-               compileCharString(font.glyphs[cmap.glyphId], cmds, font, cmap.glyphId);
 
-               cmds.push({
 
-                 cmd: "restore"
 
-               });
 
-               cmap = lookupCmap(font.cmap, String.fromCharCode(font.glyphNameMap[_encodings.StandardEncoding[bchar]]));
 
-               compileCharString(font.glyphs[cmap.glyphId], cmds, font, cmap.glyphId);
 
-             }
 
-             return;
 
-           case 18:
 
-             stems += stack.length >> 1;
 
-             stackClean = true;
 
-             break;
 
-           case 19:
 
-             stems += stack.length >> 1;
 
-             i += stems + 7 >> 3;
 
-             stackClean = true;
 
-             break;
 
-           case 20:
 
-             stems += stack.length >> 1;
 
-             i += stems + 7 >> 3;
 
-             stackClean = true;
 
-             break;
 
-           case 21:
 
-             y += stack.pop();
 
-             x += stack.pop();
 
-             moveTo(x, y);
 
-             stackClean = true;
 
-             break;
 
-           case 22:
 
-             x += stack.pop();
 
-             moveTo(x, y);
 
-             stackClean = true;
 
-             break;
 
-           case 23:
 
-             stems += stack.length >> 1;
 
-             stackClean = true;
 
-             break;
 
-           case 24:
 
-             while (stack.length > 2) {
 
-               xa = x + stack.shift();
 
-               ya = y + stack.shift();
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb + stack.shift();
 
-               y = yb + stack.shift();
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             x += stack.shift();
 
-             y += stack.shift();
 
-             lineTo(x, y);
 
-             break;
 
-           case 25:
 
-             while (stack.length > 6) {
 
-               x += stack.shift();
 
-               y += stack.shift();
 
-               lineTo(x, y);
 
-             }
 
-             xa = x + stack.shift();
 
-             ya = y + stack.shift();
 
-             xb = xa + stack.shift();
 
-             yb = ya + stack.shift();
 
-             x = xb + stack.shift();
 
-             y = yb + stack.shift();
 
-             bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             break;
 
-           case 26:
 
-             if (stack.length % 2) {
 
-               x += stack.shift();
 
-             }
 
-             while (stack.length > 0) {
 
-               xa = x;
 
-               ya = y + stack.shift();
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb;
 
-               y = yb + stack.shift();
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             break;
 
-           case 27:
 
-             if (stack.length % 2) {
 
-               y += stack.shift();
 
-             }
 
-             while (stack.length > 0) {
 
-               xa = x + stack.shift();
 
-               ya = y;
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb + stack.shift();
 
-               y = yb;
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             break;
 
-           case 28:
 
-             stack.push((code[i] << 24 | code[i + 1] << 16) >> 16);
 
-             i += 2;
 
-             break;
 
-           case 29:
 
-             n = stack.pop() + font.gsubrsBias;
 
-             subrCode = font.gsubrs[n];
 
-             if (subrCode) {
 
-               parse(subrCode);
 
-             }
 
-             break;
 
-           case 30:
 
-             while (stack.length > 0) {
 
-               xa = x;
 
-               ya = y + stack.shift();
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb + stack.shift();
 
-               y = yb + (stack.length === 1 ? stack.shift() : 0);
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-               if (stack.length === 0) {
 
-                 break;
 
-               }
 
-               xa = x + stack.shift();
 
-               ya = y;
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               y = yb + stack.shift();
 
-               x = xb + (stack.length === 1 ? stack.shift() : 0);
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             break;
 
-           case 31:
 
-             while (stack.length > 0) {
 
-               xa = x + stack.shift();
 
-               ya = y;
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               y = yb + stack.shift();
 
-               x = xb + (stack.length === 1 ? stack.shift() : 0);
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-               if (stack.length === 0) {
 
-                 break;
 
-               }
 
-               xa = x;
 
-               ya = y + stack.shift();
 
-               xb = xa + stack.shift();
 
-               yb = ya + stack.shift();
 
-               x = xb + stack.shift();
 
-               y = yb + (stack.length === 1 ? stack.shift() : 0);
 
-               bezierCurveTo(xa, ya, xb, yb, x, y);
 
-             }
 
-             break;
 
-           default:
 
-             if (v < 32) {
 
-               throw new _util.FormatError(`unknown operator: ${v}`);
 
-             }
 
-             if (v < 247) {
 
-               stack.push(v - 139);
 
-             } else if (v < 251) {
 
-               stack.push((v - 247) * 256 + code[i++] + 108);
 
-             } else if (v < 255) {
 
-               stack.push(-(v - 251) * 256 - code[i++] - 108);
 
-             } else {
 
-               stack.push((code[i] << 24 | code[i + 1] << 16 | code[i + 2] << 8 | code[i + 3]) / 65536);
 
-               i += 4;
 
-             }
 
-             break;
 
-         }
 
-         if (stackClean) {
 
-           stack.length = 0;
 
-         }
 
-       }
 
-     }
 
-     parse(code);
 
-   }
 
-   const NOOP = [];
 
-   class CompiledFont {
 
-     constructor(fontMatrix) {
 
-       if (this.constructor === CompiledFont) {
 
-         (0, _util.unreachable)("Cannot initialize CompiledFont.");
 
-       }
 
-       this.fontMatrix = fontMatrix;
 
-       this.compiledGlyphs = Object.create(null);
 
-       this.compiledCharCodeToGlyphId = Object.create(null);
 
-     }
 
-     getPathJs(unicode) {
 
-       const cmap = lookupCmap(this.cmap, unicode);
 
-       let fn = this.compiledGlyphs[cmap.glyphId];
 
-       if (!fn) {
 
-         fn = this.compileGlyph(this.glyphs[cmap.glyphId], cmap.glyphId);
 
-         this.compiledGlyphs[cmap.glyphId] = fn;
 
-       }
 
-       if (this.compiledCharCodeToGlyphId[cmap.charCode] === undefined) {
 
-         this.compiledCharCodeToGlyphId[cmap.charCode] = cmap.glyphId;
 
-       }
 
-       return fn;
 
-     }
 
-     compileGlyph(code, glyphId) {
 
-       if (!code || code.length === 0 || code[0] === 14) {
 
-         return NOOP;
 
-       }
 
-       let fontMatrix = this.fontMatrix;
 
-       if (this.isCFFCIDFont) {
 
-         const fdIndex = this.fdSelect.getFDIndex(glyphId);
 
-         if (fdIndex >= 0 && fdIndex < this.fdArray.length) {
 
-           const fontDict = this.fdArray[fdIndex];
 
-           fontMatrix = fontDict.getByName("FontMatrix") || _util.FONT_IDENTITY_MATRIX;
 
-         } else {
 
-           (0, _util.warn)("Invalid fd index for glyph index.");
 
-         }
 
-       }
 
-       const cmds = [];
 
-       cmds.push({
 
-         cmd: "save"
 
-       });
 
-       cmds.push({
 
-         cmd: "transform",
 
-         args: fontMatrix.slice()
 
-       });
 
-       cmds.push({
 
-         cmd: "scale",
 
-         args: ["size", "-size"]
 
-       });
 
-       this.compileGlyphImpl(code, cmds, glyphId);
 
-       cmds.push({
 
-         cmd: "restore"
 
-       });
 
-       return cmds;
 
-     }
 
-     compileGlyphImpl() {
 
-       (0, _util.unreachable)("Children classes should implement this.");
 
-     }
 
-     hasBuiltPath(unicode) {
 
-       const cmap = lookupCmap(this.cmap, unicode);
 
-       return this.compiledGlyphs[cmap.glyphId] !== undefined && this.compiledCharCodeToGlyphId[cmap.charCode] !== undefined;
 
-     }
 
-   }
 
-   class TrueTypeCompiled extends CompiledFont {
 
-     constructor(glyphs, cmap, fontMatrix) {
 
-       super(fontMatrix || [0.000488, 0, 0, 0.000488, 0, 0]);
 
-       this.glyphs = glyphs;
 
-       this.cmap = cmap;
 
-     }
 
-     compileGlyphImpl(code, cmds) {
 
-       compileGlyf(code, cmds, this);
 
-     }
 
-   }
 
-   class Type2Compiled extends CompiledFont {
 
-     constructor(cffInfo, cmap, fontMatrix, glyphNameMap) {
 
-       super(fontMatrix || [0.001, 0, 0, 0.001, 0, 0]);
 
-       this.glyphs = cffInfo.glyphs;
 
-       this.gsubrs = cffInfo.gsubrs || [];
 
-       this.subrs = cffInfo.subrs || [];
 
-       this.cmap = cmap;
 
-       this.glyphNameMap = glyphNameMap || (0, _glyphlist.getGlyphsUnicode)();
 
-       this.gsubrsBias = getSubroutineBias(this.gsubrs);
 
-       this.subrsBias = getSubroutineBias(this.subrs);
 
-       this.isCFFCIDFont = cffInfo.isCFFCIDFont;
 
-       this.fdSelect = cffInfo.fdSelect;
 
-       this.fdArray = cffInfo.fdArray;
 
-     }
 
-     compileGlyphImpl(code, cmds, glyphId) {
 
-       compileCharString(code, cmds, this, glyphId);
 
-     }
 
-   }
 
-   return {
 
-     create: function FontRendererFactory_create(font, seacAnalysisEnabled) {
 
-       var data = new Uint8Array(font.data);
 
-       var cmap, glyf, loca, cff, indexToLocFormat, unitsPerEm;
 
-       var numTables = getUshort(data, 4);
 
-       for (var i = 0, p = 12; i < numTables; i++, p += 16) {
 
-         var tag = (0, _util.bytesToString)(data.subarray(p, p + 4));
 
-         var offset = getLong(data, p + 8);
 
-         var length = getLong(data, p + 12);
 
-         switch (tag) {
 
-           case "cmap":
 
-             cmap = parseCmap(data, offset, offset + length);
 
-             break;
 
-           case "glyf":
 
-             glyf = data.subarray(offset, offset + length);
 
-             break;
 
-           case "loca":
 
-             loca = data.subarray(offset, offset + length);
 
-             break;
 
-           case "head":
 
-             unitsPerEm = getUshort(data, offset + 18);
 
-             indexToLocFormat = getUshort(data, offset + 50);
 
-             break;
 
-           case "CFF ":
 
-             cff = parseCff(data, offset, offset + length, seacAnalysisEnabled);
 
-             break;
 
-         }
 
-       }
 
-       if (glyf) {
 
-         var fontMatrix = !unitsPerEm ? font.fontMatrix : [1 / unitsPerEm, 0, 0, 1 / unitsPerEm, 0, 0];
 
-         return new TrueTypeCompiled(parseGlyfTable(glyf, loca, indexToLocFormat), cmap, fontMatrix);
 
-       }
 
-       return new Type2Compiled(cff, cmap, font.fontMatrix, font.glyphNameMap);
 
-     }
 
-   };
 
- }();
 
- exports.FontRendererFactory = FontRendererFactory;
 
- /***/ }),
 
- /* 35 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.Type1Parser = void 0;
 
- var _encodings = __w_pdfjs_require__(30);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _util = __w_pdfjs_require__(2);
 
- var HINTING_ENABLED = false;
 
- var Type1CharString = function Type1CharStringClosure() {
 
-   var COMMAND_MAP = {
 
-     hstem: [1],
 
-     vstem: [3],
 
-     vmoveto: [4],
 
-     rlineto: [5],
 
-     hlineto: [6],
 
-     vlineto: [7],
 
-     rrcurveto: [8],
 
-     callsubr: [10],
 
-     flex: [12, 35],
 
-     drop: [12, 18],
 
-     endchar: [14],
 
-     rmoveto: [21],
 
-     hmoveto: [22],
 
-     vhcurveto: [30],
 
-     hvcurveto: [31]
 
-   };
 
-   function Type1CharString() {
 
-     this.width = 0;
 
-     this.lsb = 0;
 
-     this.flexing = false;
 
-     this.output = [];
 
-     this.stack = [];
 
-   }
 
-   Type1CharString.prototype = {
 
-     convert: function Type1CharString_convert(encoded, subrs, seacAnalysisEnabled) {
 
-       var count = encoded.length;
 
-       var error = false;
 
-       var wx, sbx, subrNumber;
 
-       for (var i = 0; i < count; i++) {
 
-         var value = encoded[i];
 
-         if (value < 32) {
 
-           if (value === 12) {
 
-             value = (value << 8) + encoded[++i];
 
-           }
 
-           switch (value) {
 
-             case 1:
 
-               if (!HINTING_ENABLED) {
 
-                 this.stack = [];
 
-                 break;
 
-               }
 
-               error = this.executeCommand(2, COMMAND_MAP.hstem);
 
-               break;
 
-             case 3:
 
-               if (!HINTING_ENABLED) {
 
-                 this.stack = [];
 
-                 break;
 
-               }
 
-               error = this.executeCommand(2, COMMAND_MAP.vstem);
 
-               break;
 
-             case 4:
 
-               if (this.flexing) {
 
-                 if (this.stack.length < 1) {
 
-                   error = true;
 
-                   break;
 
-                 }
 
-                 var dy = this.stack.pop();
 
-                 this.stack.push(0, dy);
 
-                 break;
 
-               }
 
-               error = this.executeCommand(1, COMMAND_MAP.vmoveto);
 
-               break;
 
-             case 5:
 
-               error = this.executeCommand(2, COMMAND_MAP.rlineto);
 
-               break;
 
-             case 6:
 
-               error = this.executeCommand(1, COMMAND_MAP.hlineto);
 
-               break;
 
-             case 7:
 
-               error = this.executeCommand(1, COMMAND_MAP.vlineto);
 
-               break;
 
-             case 8:
 
-               error = this.executeCommand(6, COMMAND_MAP.rrcurveto);
 
-               break;
 
-             case 9:
 
-               this.stack = [];
 
-               break;
 
-             case 10:
 
-               if (this.stack.length < 1) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               subrNumber = this.stack.pop();
 
-               if (!subrs[subrNumber]) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               error = this.convert(subrs[subrNumber], subrs, seacAnalysisEnabled);
 
-               break;
 
-             case 11:
 
-               return error;
 
-             case 13:
 
-               if (this.stack.length < 2) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               wx = this.stack.pop();
 
-               sbx = this.stack.pop();
 
-               this.lsb = sbx;
 
-               this.width = wx;
 
-               this.stack.push(wx, sbx);
 
-               error = this.executeCommand(2, COMMAND_MAP.hmoveto);
 
-               break;
 
-             case 14:
 
-               this.output.push(COMMAND_MAP.endchar[0]);
 
-               break;
 
-             case 21:
 
-               if (this.flexing) {
 
-                 break;
 
-               }
 
-               error = this.executeCommand(2, COMMAND_MAP.rmoveto);
 
-               break;
 
-             case 22:
 
-               if (this.flexing) {
 
-                 this.stack.push(0);
 
-                 break;
 
-               }
 
-               error = this.executeCommand(1, COMMAND_MAP.hmoveto);
 
-               break;
 
-             case 30:
 
-               error = this.executeCommand(4, COMMAND_MAP.vhcurveto);
 
-               break;
 
-             case 31:
 
-               error = this.executeCommand(4, COMMAND_MAP.hvcurveto);
 
-               break;
 
-             case (12 << 8) + 0:
 
-               this.stack = [];
 
-               break;
 
-             case (12 << 8) + 1:
 
-               if (!HINTING_ENABLED) {
 
-                 this.stack = [];
 
-                 break;
 
-               }
 
-               error = this.executeCommand(2, COMMAND_MAP.vstem);
 
-               break;
 
-             case (12 << 8) + 2:
 
-               if (!HINTING_ENABLED) {
 
-                 this.stack = [];
 
-                 break;
 
-               }
 
-               error = this.executeCommand(2, COMMAND_MAP.hstem);
 
-               break;
 
-             case (12 << 8) + 6:
 
-               if (seacAnalysisEnabled) {
 
-                 this.seac = this.stack.splice(-4, 4);
 
-                 error = this.executeCommand(0, COMMAND_MAP.endchar);
 
-               } else {
 
-                 error = this.executeCommand(4, COMMAND_MAP.endchar);
 
-               }
 
-               break;
 
-             case (12 << 8) + 7:
 
-               if (this.stack.length < 4) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               this.stack.pop();
 
-               wx = this.stack.pop();
 
-               var sby = this.stack.pop();
 
-               sbx = this.stack.pop();
 
-               this.lsb = sbx;
 
-               this.width = wx;
 
-               this.stack.push(wx, sbx, sby);
 
-               error = this.executeCommand(3, COMMAND_MAP.rmoveto);
 
-               break;
 
-             case (12 << 8) + 12:
 
-               if (this.stack.length < 2) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               var num2 = this.stack.pop();
 
-               var num1 = this.stack.pop();
 
-               this.stack.push(num1 / num2);
 
-               break;
 
-             case (12 << 8) + 16:
 
-               if (this.stack.length < 2) {
 
-                 error = true;
 
-                 break;
 
-               }
 
-               subrNumber = this.stack.pop();
 
-               var numArgs = this.stack.pop();
 
-               if (subrNumber === 0 && numArgs === 3) {
 
-                 var flexArgs = this.stack.splice(this.stack.length - 17, 17);
 
-                 this.stack.push(flexArgs[2] + flexArgs[0], flexArgs[3] + flexArgs[1], flexArgs[4], flexArgs[5], flexArgs[6], flexArgs[7], flexArgs[8], flexArgs[9], flexArgs[10], flexArgs[11], flexArgs[12], flexArgs[13], flexArgs[14]);
 
-                 error = this.executeCommand(13, COMMAND_MAP.flex, true);
 
-                 this.flexing = false;
 
-                 this.stack.push(flexArgs[15], flexArgs[16]);
 
-               } else if (subrNumber === 1 && numArgs === 0) {
 
-                 this.flexing = true;
 
-               }
 
-               break;
 
-             case (12 << 8) + 17:
 
-               break;
 
-             case (12 << 8) + 33:
 
-               this.stack = [];
 
-               break;
 
-             default:
 
-               (0, _util.warn)('Unknown type 1 charstring command of "' + value + '"');
 
-               break;
 
-           }
 
-           if (error) {
 
-             break;
 
-           }
 
-           continue;
 
-         } else if (value <= 246) {
 
-           value = value - 139;
 
-         } else if (value <= 250) {
 
-           value = (value - 247) * 256 + encoded[++i] + 108;
 
-         } else if (value <= 254) {
 
-           value = -((value - 251) * 256) - encoded[++i] - 108;
 
-         } else {
 
-           value = (encoded[++i] & 0xff) << 24 | (encoded[++i] & 0xff) << 16 | (encoded[++i] & 0xff) << 8 | (encoded[++i] & 0xff) << 0;
 
-         }
 
-         this.stack.push(value);
 
-       }
 
-       return error;
 
-     },
 
-     executeCommand(howManyArgs, command, keepStack) {
 
-       var stackLength = this.stack.length;
 
-       if (howManyArgs > stackLength) {
 
-         return true;
 
-       }
 
-       var start = stackLength - howManyArgs;
 
-       for (var i = start; i < stackLength; i++) {
 
-         var value = this.stack[i];
 
-         if (Number.isInteger(value)) {
 
-           this.output.push(28, value >> 8 & 0xff, value & 0xff);
 
-         } else {
 
-           value = 65536 * value | 0;
 
-           this.output.push(255, value >> 24 & 0xff, value >> 16 & 0xff, value >> 8 & 0xff, value & 0xff);
 
-         }
 
-       }
 
-       this.output.push.apply(this.output, command);
 
-       if (keepStack) {
 
-         this.stack.splice(start, howManyArgs);
 
-       } else {
 
-         this.stack.length = 0;
 
-       }
 
-       return false;
 
-     }
 
-   };
 
-   return Type1CharString;
 
- }();
 
- var Type1Parser = function Type1ParserClosure() {
 
-   var EEXEC_ENCRYPT_KEY = 55665;
 
-   var CHAR_STRS_ENCRYPT_KEY = 4330;
 
-   function isHexDigit(code) {
 
-     return code >= 48 && code <= 57 || code >= 65 && code <= 70 || code >= 97 && code <= 102;
 
-   }
 
-   function decrypt(data, key, discardNumber) {
 
-     if (discardNumber >= data.length) {
 
-       return new Uint8Array(0);
 
-     }
 
-     var r = key | 0,
 
-         c1 = 52845,
 
-         c2 = 22719,
 
-         i,
 
-         j;
 
-     for (i = 0; i < discardNumber; i++) {
 
-       r = (data[i] + r) * c1 + c2 & (1 << 16) - 1;
 
-     }
 
-     var count = data.length - discardNumber;
 
-     var decrypted = new Uint8Array(count);
 
-     for (i = discardNumber, j = 0; j < count; i++, j++) {
 
-       var value = data[i];
 
-       decrypted[j] = value ^ r >> 8;
 
-       r = (value + r) * c1 + c2 & (1 << 16) - 1;
 
-     }
 
-     return decrypted;
 
-   }
 
-   function decryptAscii(data, key, discardNumber) {
 
-     var r = key | 0,
 
-         c1 = 52845,
 
-         c2 = 22719;
 
-     var count = data.length,
 
-         maybeLength = count >>> 1;
 
-     var decrypted = new Uint8Array(maybeLength);
 
-     var i, j;
 
-     for (i = 0, j = 0; i < count; i++) {
 
-       var digit1 = data[i];
 
-       if (!isHexDigit(digit1)) {
 
-         continue;
 
-       }
 
-       i++;
 
-       var digit2;
 
-       while (i < count && !isHexDigit(digit2 = data[i])) {
 
-         i++;
 
-       }
 
-       if (i < count) {
 
-         var value = parseInt(String.fromCharCode(digit1, digit2), 16);
 
-         decrypted[j++] = value ^ r >> 8;
 
-         r = (value + r) * c1 + c2 & (1 << 16) - 1;
 
-       }
 
-     }
 
-     return Array.prototype.slice.call(decrypted, discardNumber, j);
 
-   }
 
-   function isSpecial(c) {
 
-     return c === 0x2f || c === 0x5b || c === 0x5d || c === 0x7b || c === 0x7d || c === 0x28 || c === 0x29;
 
-   }
 
-   function Type1Parser(stream, encrypted, seacAnalysisEnabled) {
 
-     if (encrypted) {
 
-       var data = stream.getBytes();
 
-       var isBinary = !(isHexDigit(data[0]) && isHexDigit(data[1]) && isHexDigit(data[2]) && isHexDigit(data[3]));
 
-       stream = new _stream.Stream(isBinary ? decrypt(data, EEXEC_ENCRYPT_KEY, 4) : decryptAscii(data, EEXEC_ENCRYPT_KEY, 4));
 
-     }
 
-     this.seacAnalysisEnabled = !!seacAnalysisEnabled;
 
-     this.stream = stream;
 
-     this.nextChar();
 
-   }
 
-   Type1Parser.prototype = {
 
-     readNumberArray: function Type1Parser_readNumberArray() {
 
-       this.getToken();
 
-       var array = [];
 
-       while (true) {
 
-         var token = this.getToken();
 
-         if (token === null || token === "]" || token === "}") {
 
-           break;
 
-         }
 
-         array.push(parseFloat(token || 0));
 
-       }
 
-       return array;
 
-     },
 
-     readNumber: function Type1Parser_readNumber() {
 
-       var token = this.getToken();
 
-       return parseFloat(token || 0);
 
-     },
 
-     readInt: function Type1Parser_readInt() {
 
-       var token = this.getToken();
 
-       return parseInt(token || 0, 10) | 0;
 
-     },
 
-     readBoolean: function Type1Parser_readBoolean() {
 
-       var token = this.getToken();
 
-       return token === "true" ? 1 : 0;
 
-     },
 
-     nextChar: function Type1_nextChar() {
 
-       return this.currentChar = this.stream.getByte();
 
-     },
 
-     getToken: function Type1Parser_getToken() {
 
-       var comment = false;
 
-       var ch = this.currentChar;
 
-       while (true) {
 
-         if (ch === -1) {
 
-           return null;
 
-         }
 
-         if (comment) {
 
-           if (ch === 0x0a || ch === 0x0d) {
 
-             comment = false;
 
-           }
 
-         } else if (ch === 0x25) {
 
-           comment = true;
 
-         } else if (!(0, _core_utils.isWhiteSpace)(ch)) {
 
-           break;
 
-         }
 
-         ch = this.nextChar();
 
-       }
 
-       if (isSpecial(ch)) {
 
-         this.nextChar();
 
-         return String.fromCharCode(ch);
 
-       }
 
-       var token = "";
 
-       do {
 
-         token += String.fromCharCode(ch);
 
-         ch = this.nextChar();
 
-       } while (ch >= 0 && !(0, _core_utils.isWhiteSpace)(ch) && !isSpecial(ch));
 
-       return token;
 
-     },
 
-     readCharStrings: function Type1Parser_readCharStrings(bytes, lenIV) {
 
-       if (lenIV === -1) {
 
-         return bytes;
 
-       }
 
-       return decrypt(bytes, CHAR_STRS_ENCRYPT_KEY, lenIV);
 
-     },
 
-     extractFontProgram: function Type1Parser_extractFontProgram(properties) {
 
-       var stream = this.stream;
 
-       var subrs = [],
 
-           charstrings = [];
 
-       var privateData = Object.create(null);
 
-       privateData["lenIV"] = 4;
 
-       var program = {
 
-         subrs: [],
 
-         charstrings: [],
 
-         properties: {
 
-           privateData
 
-         }
 
-       };
 
-       var token, length, data, lenIV, encoded;
 
-       while ((token = this.getToken()) !== null) {
 
-         if (token !== "/") {
 
-           continue;
 
-         }
 
-         token = this.getToken();
 
-         switch (token) {
 
-           case "CharStrings":
 
-             this.getToken();
 
-             this.getToken();
 
-             this.getToken();
 
-             this.getToken();
 
-             while (true) {
 
-               token = this.getToken();
 
-               if (token === null || token === "end") {
 
-                 break;
 
-               }
 
-               if (token !== "/") {
 
-                 continue;
 
-               }
 
-               var glyph = this.getToken();
 
-               length = this.readInt();
 
-               this.getToken();
 
-               data = length > 0 ? stream.getBytes(length) : new Uint8Array(0);
 
-               lenIV = program.properties.privateData["lenIV"];
 
-               encoded = this.readCharStrings(data, lenIV);
 
-               this.nextChar();
 
-               token = this.getToken();
 
-               if (token === "noaccess") {
 
-                 this.getToken();
 
-               }
 
-               charstrings.push({
 
-                 glyph,
 
-                 encoded
 
-               });
 
-             }
 
-             break;
 
-           case "Subrs":
 
-             this.readInt();
 
-             this.getToken();
 
-             while (this.getToken() === "dup") {
 
-               var index = this.readInt();
 
-               length = this.readInt();
 
-               this.getToken();
 
-               data = length > 0 ? stream.getBytes(length) : new Uint8Array(0);
 
-               lenIV = program.properties.privateData["lenIV"];
 
-               encoded = this.readCharStrings(data, lenIV);
 
-               this.nextChar();
 
-               token = this.getToken();
 
-               if (token === "noaccess") {
 
-                 this.getToken();
 
-               }
 
-               subrs[index] = encoded;
 
-             }
 
-             break;
 
-           case "BlueValues":
 
-           case "OtherBlues":
 
-           case "FamilyBlues":
 
-           case "FamilyOtherBlues":
 
-             var blueArray = this.readNumberArray();
 
-             if (blueArray.length > 0 && blueArray.length % 2 === 0 && HINTING_ENABLED) {
 
-               program.properties.privateData[token] = blueArray;
 
-             }
 
-             break;
 
-           case "StemSnapH":
 
-           case "StemSnapV":
 
-             program.properties.privateData[token] = this.readNumberArray();
 
-             break;
 
-           case "StdHW":
 
-           case "StdVW":
 
-             program.properties.privateData[token] = this.readNumberArray()[0];
 
-             break;
 
-           case "BlueShift":
 
-           case "lenIV":
 
-           case "BlueFuzz":
 
-           case "BlueScale":
 
-           case "LanguageGroup":
 
-           case "ExpansionFactor":
 
-             program.properties.privateData[token] = this.readNumber();
 
-             break;
 
-           case "ForceBold":
 
-             program.properties.privateData[token] = this.readBoolean();
 
-             break;
 
-         }
 
-       }
 
-       for (var i = 0; i < charstrings.length; i++) {
 
-         glyph = charstrings[i].glyph;
 
-         encoded = charstrings[i].encoded;
 
-         var charString = new Type1CharString();
 
-         var error = charString.convert(encoded, subrs, this.seacAnalysisEnabled);
 
-         var output = charString.output;
 
-         if (error) {
 
-           output = [14];
 
-         }
 
-         const charStringObject = {
 
-           glyphName: glyph,
 
-           charstring: output,
 
-           width: charString.width,
 
-           lsb: charString.lsb,
 
-           seac: charString.seac
 
-         };
 
-         if (glyph === ".notdef") {
 
-           program.charstrings.unshift(charStringObject);
 
-         } else {
 
-           program.charstrings.push(charStringObject);
 
-         }
 
-         if (properties.builtInEncoding) {
 
-           const index = properties.builtInEncoding.indexOf(glyph);
 
-           if (index > -1 && properties.widths[index] === undefined && index >= properties.firstChar && index <= properties.lastChar) {
 
-             properties.widths[index] = charString.width;
 
-           }
 
-         }
 
-       }
 
-       return program;
 
-     },
 
-     extractFontHeader: function Type1Parser_extractFontHeader(properties) {
 
-       var token;
 
-       while ((token = this.getToken()) !== null) {
 
-         if (token !== "/") {
 
-           continue;
 
-         }
 
-         token = this.getToken();
 
-         switch (token) {
 
-           case "FontMatrix":
 
-             var matrix = this.readNumberArray();
 
-             properties.fontMatrix = matrix;
 
-             break;
 
-           case "Encoding":
 
-             var encodingArg = this.getToken();
 
-             var encoding;
 
-             if (!/^\d+$/.test(encodingArg)) {
 
-               encoding = (0, _encodings.getEncoding)(encodingArg);
 
-             } else {
 
-               encoding = [];
 
-               var size = parseInt(encodingArg, 10) | 0;
 
-               this.getToken();
 
-               for (var j = 0; j < size; j++) {
 
-                 token = this.getToken();
 
-                 while (token !== "dup" && token !== "def") {
 
-                   token = this.getToken();
 
-                   if (token === null) {
 
-                     return;
 
-                   }
 
-                 }
 
-                 if (token === "def") {
 
-                   break;
 
-                 }
 
-                 var index = this.readInt();
 
-                 this.getToken();
 
-                 var glyph = this.getToken();
 
-                 encoding[index] = glyph;
 
-                 this.getToken();
 
-               }
 
-             }
 
-             properties.builtInEncoding = encoding;
 
-             break;
 
-           case "FontBBox":
 
-             var fontBBox = this.readNumberArray();
 
-             properties.ascent = Math.max(fontBBox[3], fontBBox[1]);
 
-             properties.descent = Math.min(fontBBox[1], fontBBox[3]);
 
-             properties.ascentScaled = true;
 
-             break;
 
-         }
 
-       }
 
-     }
 
-   };
 
-   return Type1Parser;
 
- }();
 
- exports.Type1Parser = Type1Parser;
 
- /***/ }),
 
- /* 36 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getTilingPatternIR = getTilingPatternIR;
 
- exports.Pattern = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _colorspace = __w_pdfjs_require__(22);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var ShadingType = {
 
-   FUNCTION_BASED: 1,
 
-   AXIAL: 2,
 
-   RADIAL: 3,
 
-   FREE_FORM_MESH: 4,
 
-   LATTICE_FORM_MESH: 5,
 
-   COONS_PATCH_MESH: 6,
 
-   TENSOR_PATCH_MESH: 7
 
- };
 
- var Pattern = function PatternClosure() {
 
-   function Pattern() {
 
-     (0, _util.unreachable)("should not call Pattern constructor");
 
-   }
 
-   Pattern.prototype = {
 
-     getPattern: function Pattern_getPattern(ctx) {
 
-       (0, _util.unreachable)(`Should not call Pattern.getStyle: ${ctx}`);
 
-     }
 
-   };
 
-   Pattern.parseShading = function (shading, matrix, xref, res, handler, pdfFunctionFactory) {
 
-     var dict = (0, _primitives.isStream)(shading) ? shading.dict : shading;
 
-     var type = dict.get("ShadingType");
 
-     try {
 
-       switch (type) {
 
-         case ShadingType.AXIAL:
 
-         case ShadingType.RADIAL:
 
-           return new Shadings.RadialAxial(dict, matrix, xref, res, pdfFunctionFactory);
 
-         case ShadingType.FREE_FORM_MESH:
 
-         case ShadingType.LATTICE_FORM_MESH:
 
-         case ShadingType.COONS_PATCH_MESH:
 
-         case ShadingType.TENSOR_PATCH_MESH:
 
-           return new Shadings.Mesh(shading, matrix, xref, res, pdfFunctionFactory);
 
-         default:
 
-           throw new _util.FormatError("Unsupported ShadingType: " + type);
 
-       }
 
-     } catch (ex) {
 
-       if (ex instanceof _core_utils.MissingDataException) {
 
-         throw ex;
 
-       }
 
-       handler.send("UnsupportedFeature", {
 
-         featureId: _util.UNSUPPORTED_FEATURES.shadingPattern
 
-       });
 
-       (0, _util.warn)(ex);
 
-       return new Shadings.Dummy();
 
-     }
 
-   };
 
-   return Pattern;
 
- }();
 
- exports.Pattern = Pattern;
 
- var Shadings = {};
 
- Shadings.SMALL_NUMBER = 1e-6;
 
- Shadings.RadialAxial = function RadialAxialClosure() {
 
-   function RadialAxial(dict, matrix, xref, res, pdfFunctionFactory) {
 
-     this.matrix = matrix;
 
-     this.coordsArr = dict.getArray("Coords");
 
-     this.shadingType = dict.get("ShadingType");
 
-     this.type = "Pattern";
 
-     var cs = dict.get("ColorSpace", "CS");
 
-     cs = _colorspace.ColorSpace.parse(cs, xref, res, pdfFunctionFactory);
 
-     this.cs = cs;
 
-     const bbox = dict.getArray("BBox");
 
-     if (Array.isArray(bbox) && bbox.length === 4) {
 
-       this.bbox = _util.Util.normalizeRect(bbox);
 
-     } else {
 
-       this.bbox = null;
 
-     }
 
-     var t0 = 0.0,
 
-         t1 = 1.0;
 
-     if (dict.has("Domain")) {
 
-       var domainArr = dict.getArray("Domain");
 
-       t0 = domainArr[0];
 
-       t1 = domainArr[1];
 
-     }
 
-     var extendStart = false,
 
-         extendEnd = false;
 
-     if (dict.has("Extend")) {
 
-       var extendArr = dict.getArray("Extend");
 
-       extendStart = extendArr[0];
 
-       extendEnd = extendArr[1];
 
-     }
 
-     if (this.shadingType === ShadingType.RADIAL && (!extendStart || !extendEnd)) {
 
-       var x1 = this.coordsArr[0];
 
-       var y1 = this.coordsArr[1];
 
-       var r1 = this.coordsArr[2];
 
-       var x2 = this.coordsArr[3];
 
-       var y2 = this.coordsArr[4];
 
-       var r2 = this.coordsArr[5];
 
-       var distance = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));
 
-       if (r1 <= r2 + distance && r2 <= r1 + distance) {
 
-         (0, _util.warn)("Unsupported radial gradient.");
 
-       }
 
-     }
 
-     this.extendStart = extendStart;
 
-     this.extendEnd = extendEnd;
 
-     var fnObj = dict.get("Function");
 
-     var fn = pdfFunctionFactory.createFromArray(fnObj);
 
-     const NUMBER_OF_SAMPLES = 10;
 
-     const step = (t1 - t0) / NUMBER_OF_SAMPLES;
 
-     var colorStops = this.colorStops = [];
 
-     if (t0 >= t1 || step <= 0) {
 
-       (0, _util.info)("Bad shading domain.");
 
-       return;
 
-     }
 
-     var color = new Float32Array(cs.numComps),
 
-         ratio = new Float32Array(1);
 
-     var rgbColor;
 
-     for (let i = 0; i <= NUMBER_OF_SAMPLES; i++) {
 
-       ratio[0] = t0 + i * step;
 
-       fn(ratio, 0, color, 0);
 
-       rgbColor = cs.getRgb(color, 0);
 
-       var cssColor = _util.Util.makeCssRgb(rgbColor[0], rgbColor[1], rgbColor[2]);
 
-       colorStops.push([i / NUMBER_OF_SAMPLES, cssColor]);
 
-     }
 
-     var background = "transparent";
 
-     if (dict.has("Background")) {
 
-       rgbColor = cs.getRgb(dict.get("Background"), 0);
 
-       background = _util.Util.makeCssRgb(rgbColor[0], rgbColor[1], rgbColor[2]);
 
-     }
 
-     if (!extendStart) {
 
-       colorStops.unshift([0, background]);
 
-       colorStops[1][0] += Shadings.SMALL_NUMBER;
 
-     }
 
-     if (!extendEnd) {
 
-       colorStops[colorStops.length - 1][0] -= Shadings.SMALL_NUMBER;
 
-       colorStops.push([1, background]);
 
-     }
 
-     this.colorStops = colorStops;
 
-   }
 
-   RadialAxial.prototype = {
 
-     getIR: function RadialAxial_getIR() {
 
-       var coordsArr = this.coordsArr;
 
-       var shadingType = this.shadingType;
 
-       var type, p0, p1, r0, r1;
 
-       if (shadingType === ShadingType.AXIAL) {
 
-         p0 = [coordsArr[0], coordsArr[1]];
 
-         p1 = [coordsArr[2], coordsArr[3]];
 
-         r0 = null;
 
-         r1 = null;
 
-         type = "axial";
 
-       } else if (shadingType === ShadingType.RADIAL) {
 
-         p0 = [coordsArr[0], coordsArr[1]];
 
-         p1 = [coordsArr[3], coordsArr[4]];
 
-         r0 = coordsArr[2];
 
-         r1 = coordsArr[5];
 
-         type = "radial";
 
-       } else {
 
-         (0, _util.unreachable)(`getPattern type unknown: ${shadingType}`);
 
-       }
 
-       var matrix = this.matrix;
 
-       if (matrix) {
 
-         p0 = _util.Util.applyTransform(p0, matrix);
 
-         p1 = _util.Util.applyTransform(p1, matrix);
 
-         if (shadingType === ShadingType.RADIAL) {
 
-           var scale = _util.Util.singularValueDecompose2dScale(matrix);
 
-           r0 *= scale[0];
 
-           r1 *= scale[1];
 
-         }
 
-       }
 
-       return ["RadialAxial", type, this.bbox, this.colorStops, p0, p1, r0, r1];
 
-     }
 
-   };
 
-   return RadialAxial;
 
- }();
 
- Shadings.Mesh = function MeshClosure() {
 
-   function MeshStreamReader(stream, context) {
 
-     this.stream = stream;
 
-     this.context = context;
 
-     this.buffer = 0;
 
-     this.bufferLength = 0;
 
-     var numComps = context.numComps;
 
-     this.tmpCompsBuf = new Float32Array(numComps);
 
-     var csNumComps = context.colorSpace.numComps;
 
-     this.tmpCsCompsBuf = context.colorFn ? new Float32Array(csNumComps) : this.tmpCompsBuf;
 
-   }
 
-   MeshStreamReader.prototype = {
 
-     get hasData() {
 
-       if (this.stream.end) {
 
-         return this.stream.pos < this.stream.end;
 
-       }
 
-       if (this.bufferLength > 0) {
 
-         return true;
 
-       }
 
-       var nextByte = this.stream.getByte();
 
-       if (nextByte < 0) {
 
-         return false;
 
-       }
 
-       this.buffer = nextByte;
 
-       this.bufferLength = 8;
 
-       return true;
 
-     },
 
-     readBits: function MeshStreamReader_readBits(n) {
 
-       var buffer = this.buffer;
 
-       var bufferLength = this.bufferLength;
 
-       if (n === 32) {
 
-         if (bufferLength === 0) {
 
-           return (this.stream.getByte() << 24 | this.stream.getByte() << 16 | this.stream.getByte() << 8 | this.stream.getByte()) >>> 0;
 
-         }
 
-         buffer = buffer << 24 | this.stream.getByte() << 16 | this.stream.getByte() << 8 | this.stream.getByte();
 
-         var nextByte = this.stream.getByte();
 
-         this.buffer = nextByte & (1 << bufferLength) - 1;
 
-         return (buffer << 8 - bufferLength | (nextByte & 0xff) >> bufferLength) >>> 0;
 
-       }
 
-       if (n === 8 && bufferLength === 0) {
 
-         return this.stream.getByte();
 
-       }
 
-       while (bufferLength < n) {
 
-         buffer = buffer << 8 | this.stream.getByte();
 
-         bufferLength += 8;
 
-       }
 
-       bufferLength -= n;
 
-       this.bufferLength = bufferLength;
 
-       this.buffer = buffer & (1 << bufferLength) - 1;
 
-       return buffer >> bufferLength;
 
-     },
 
-     align: function MeshStreamReader_align() {
 
-       this.buffer = 0;
 
-       this.bufferLength = 0;
 
-     },
 
-     readFlag: function MeshStreamReader_readFlag() {
 
-       return this.readBits(this.context.bitsPerFlag);
 
-     },
 
-     readCoordinate: function MeshStreamReader_readCoordinate() {
 
-       var bitsPerCoordinate = this.context.bitsPerCoordinate;
 
-       var xi = this.readBits(bitsPerCoordinate);
 
-       var yi = this.readBits(bitsPerCoordinate);
 
-       var decode = this.context.decode;
 
-       var scale = bitsPerCoordinate < 32 ? 1 / ((1 << bitsPerCoordinate) - 1) : 2.3283064365386963e-10;
 
-       return [xi * scale * (decode[1] - decode[0]) + decode[0], yi * scale * (decode[3] - decode[2]) + decode[2]];
 
-     },
 
-     readComponents: function MeshStreamReader_readComponents() {
 
-       var numComps = this.context.numComps;
 
-       var bitsPerComponent = this.context.bitsPerComponent;
 
-       var scale = bitsPerComponent < 32 ? 1 / ((1 << bitsPerComponent) - 1) : 2.3283064365386963e-10;
 
-       var decode = this.context.decode;
 
-       var components = this.tmpCompsBuf;
 
-       for (var i = 0, j = 4; i < numComps; i++, j += 2) {
 
-         var ci = this.readBits(bitsPerComponent);
 
-         components[i] = ci * scale * (decode[j + 1] - decode[j]) + decode[j];
 
-       }
 
-       var color = this.tmpCsCompsBuf;
 
-       if (this.context.colorFn) {
 
-         this.context.colorFn(components, 0, color, 0);
 
-       }
 
-       return this.context.colorSpace.getRgb(color, 0);
 
-     }
 
-   };
 
-   function decodeType4Shading(mesh, reader) {
 
-     var coords = mesh.coords;
 
-     var colors = mesh.colors;
 
-     var operators = [];
 
-     var ps = [];
 
-     var verticesLeft = 0;
 
-     while (reader.hasData) {
 
-       var f = reader.readFlag();
 
-       var coord = reader.readCoordinate();
 
-       var color = reader.readComponents();
 
-       if (verticesLeft === 0) {
 
-         if (!(0 <= f && f <= 2)) {
 
-           throw new _util.FormatError("Unknown type4 flag");
 
-         }
 
-         switch (f) {
 
-           case 0:
 
-             verticesLeft = 3;
 
-             break;
 
-           case 1:
 
-             ps.push(ps[ps.length - 2], ps[ps.length - 1]);
 
-             verticesLeft = 1;
 
-             break;
 
-           case 2:
 
-             ps.push(ps[ps.length - 3], ps[ps.length - 1]);
 
-             verticesLeft = 1;
 
-             break;
 
-         }
 
-         operators.push(f);
 
-       }
 
-       ps.push(coords.length);
 
-       coords.push(coord);
 
-       colors.push(color);
 
-       verticesLeft--;
 
-       reader.align();
 
-     }
 
-     mesh.figures.push({
 
-       type: "triangles",
 
-       coords: new Int32Array(ps),
 
-       colors: new Int32Array(ps)
 
-     });
 
-   }
 
-   function decodeType5Shading(mesh, reader, verticesPerRow) {
 
-     var coords = mesh.coords;
 
-     var colors = mesh.colors;
 
-     var ps = [];
 
-     while (reader.hasData) {
 
-       var coord = reader.readCoordinate();
 
-       var color = reader.readComponents();
 
-       ps.push(coords.length);
 
-       coords.push(coord);
 
-       colors.push(color);
 
-     }
 
-     mesh.figures.push({
 
-       type: "lattice",
 
-       coords: new Int32Array(ps),
 
-       colors: new Int32Array(ps),
 
-       verticesPerRow
 
-     });
 
-   }
 
-   var MIN_SPLIT_PATCH_CHUNKS_AMOUNT = 3;
 
-   var MAX_SPLIT_PATCH_CHUNKS_AMOUNT = 20;
 
-   var TRIANGLE_DENSITY = 20;
 
-   var getB = function getBClosure() {
 
-     function buildB(count) {
 
-       var lut = [];
 
-       for (var i = 0; i <= count; i++) {
 
-         var t = i / count,
 
-             t_ = 1 - t;
 
-         lut.push(new Float32Array([t_ * t_ * t_, 3 * t * t_ * t_, 3 * t * t * t_, t * t * t]));
 
-       }
 
-       return lut;
 
-     }
 
-     var cache = [];
 
-     return function getB(count) {
 
-       if (!cache[count]) {
 
-         cache[count] = buildB(count);
 
-       }
 
-       return cache[count];
 
-     };
 
-   }();
 
-   function buildFigureFromPatch(mesh, index) {
 
-     var figure = mesh.figures[index];
 
-     (0, _util.assert)(figure.type === "patch", "Unexpected patch mesh figure");
 
-     var coords = mesh.coords,
 
-         colors = mesh.colors;
 
-     var pi = figure.coords;
 
-     var ci = figure.colors;
 
-     var figureMinX = Math.min(coords[pi[0]][0], coords[pi[3]][0], coords[pi[12]][0], coords[pi[15]][0]);
 
-     var figureMinY = Math.min(coords[pi[0]][1], coords[pi[3]][1], coords[pi[12]][1], coords[pi[15]][1]);
 
-     var figureMaxX = Math.max(coords[pi[0]][0], coords[pi[3]][0], coords[pi[12]][0], coords[pi[15]][0]);
 
-     var figureMaxY = Math.max(coords[pi[0]][1], coords[pi[3]][1], coords[pi[12]][1], coords[pi[15]][1]);
 
-     var splitXBy = Math.ceil((figureMaxX - figureMinX) * TRIANGLE_DENSITY / (mesh.bounds[2] - mesh.bounds[0]));
 
-     splitXBy = Math.max(MIN_SPLIT_PATCH_CHUNKS_AMOUNT, Math.min(MAX_SPLIT_PATCH_CHUNKS_AMOUNT, splitXBy));
 
-     var splitYBy = Math.ceil((figureMaxY - figureMinY) * TRIANGLE_DENSITY / (mesh.bounds[3] - mesh.bounds[1]));
 
-     splitYBy = Math.max(MIN_SPLIT_PATCH_CHUNKS_AMOUNT, Math.min(MAX_SPLIT_PATCH_CHUNKS_AMOUNT, splitYBy));
 
-     var verticesPerRow = splitXBy + 1;
 
-     var figureCoords = new Int32Array((splitYBy + 1) * verticesPerRow);
 
-     var figureColors = new Int32Array((splitYBy + 1) * verticesPerRow);
 
-     var k = 0;
 
-     var cl = new Uint8Array(3),
 
-         cr = new Uint8Array(3);
 
-     var c0 = colors[ci[0]],
 
-         c1 = colors[ci[1]],
 
-         c2 = colors[ci[2]],
 
-         c3 = colors[ci[3]];
 
-     var bRow = getB(splitYBy),
 
-         bCol = getB(splitXBy);
 
-     for (var row = 0; row <= splitYBy; row++) {
 
-       cl[0] = (c0[0] * (splitYBy - row) + c2[0] * row) / splitYBy | 0;
 
-       cl[1] = (c0[1] * (splitYBy - row) + c2[1] * row) / splitYBy | 0;
 
-       cl[2] = (c0[2] * (splitYBy - row) + c2[2] * row) / splitYBy | 0;
 
-       cr[0] = (c1[0] * (splitYBy - row) + c3[0] * row) / splitYBy | 0;
 
-       cr[1] = (c1[1] * (splitYBy - row) + c3[1] * row) / splitYBy | 0;
 
-       cr[2] = (c1[2] * (splitYBy - row) + c3[2] * row) / splitYBy | 0;
 
-       for (var col = 0; col <= splitXBy; col++, k++) {
 
-         if ((row === 0 || row === splitYBy) && (col === 0 || col === splitXBy)) {
 
-           continue;
 
-         }
 
-         var x = 0,
 
-             y = 0;
 
-         var q = 0;
 
-         for (var i = 0; i <= 3; i++) {
 
-           for (var j = 0; j <= 3; j++, q++) {
 
-             var m = bRow[row][i] * bCol[col][j];
 
-             x += coords[pi[q]][0] * m;
 
-             y += coords[pi[q]][1] * m;
 
-           }
 
-         }
 
-         figureCoords[k] = coords.length;
 
-         coords.push([x, y]);
 
-         figureColors[k] = colors.length;
 
-         var newColor = new Uint8Array(3);
 
-         newColor[0] = (cl[0] * (splitXBy - col) + cr[0] * col) / splitXBy | 0;
 
-         newColor[1] = (cl[1] * (splitXBy - col) + cr[1] * col) / splitXBy | 0;
 
-         newColor[2] = (cl[2] * (splitXBy - col) + cr[2] * col) / splitXBy | 0;
 
-         colors.push(newColor);
 
-       }
 
-     }
 
-     figureCoords[0] = pi[0];
 
-     figureColors[0] = ci[0];
 
-     figureCoords[splitXBy] = pi[3];
 
-     figureColors[splitXBy] = ci[1];
 
-     figureCoords[verticesPerRow * splitYBy] = pi[12];
 
-     figureColors[verticesPerRow * splitYBy] = ci[2];
 
-     figureCoords[verticesPerRow * splitYBy + splitXBy] = pi[15];
 
-     figureColors[verticesPerRow * splitYBy + splitXBy] = ci[3];
 
-     mesh.figures[index] = {
 
-       type: "lattice",
 
-       coords: figureCoords,
 
-       colors: figureColors,
 
-       verticesPerRow
 
-     };
 
-   }
 
-   function decodeType6Shading(mesh, reader) {
 
-     var coords = mesh.coords;
 
-     var colors = mesh.colors;
 
-     var ps = new Int32Array(16);
 
-     var cs = new Int32Array(4);
 
-     while (reader.hasData) {
 
-       var f = reader.readFlag();
 
-       if (!(0 <= f && f <= 3)) {
 
-         throw new _util.FormatError("Unknown type6 flag");
 
-       }
 
-       var i, ii;
 
-       var pi = coords.length;
 
-       for (i = 0, ii = f !== 0 ? 8 : 12; i < ii; i++) {
 
-         coords.push(reader.readCoordinate());
 
-       }
 
-       var ci = colors.length;
 
-       for (i = 0, ii = f !== 0 ? 2 : 4; i < ii; i++) {
 
-         colors.push(reader.readComponents());
 
-       }
 
-       var tmp1, tmp2, tmp3, tmp4;
 
-       switch (f) {
 
-         case 0:
 
-           ps[12] = pi + 3;
 
-           ps[13] = pi + 4;
 
-           ps[14] = pi + 5;
 
-           ps[15] = pi + 6;
 
-           ps[8] = pi + 2;
 
-           ps[11] = pi + 7;
 
-           ps[4] = pi + 1;
 
-           ps[7] = pi + 8;
 
-           ps[0] = pi;
 
-           ps[1] = pi + 11;
 
-           ps[2] = pi + 10;
 
-           ps[3] = pi + 9;
 
-           cs[2] = ci + 1;
 
-           cs[3] = ci + 2;
 
-           cs[0] = ci;
 
-           cs[1] = ci + 3;
 
-           break;
 
-         case 1:
 
-           tmp1 = ps[12];
 
-           tmp2 = ps[13];
 
-           tmp3 = ps[14];
 
-           tmp4 = ps[15];
 
-           ps[12] = tmp4;
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = tmp3;
 
-           ps[11] = pi + 3;
 
-           ps[4] = tmp2;
 
-           ps[7] = pi + 4;
 
-           ps[0] = tmp1;
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           tmp1 = cs[2];
 
-           tmp2 = cs[3];
 
-           cs[2] = tmp2;
 
-           cs[3] = ci;
 
-           cs[0] = tmp1;
 
-           cs[1] = ci + 1;
 
-           break;
 
-         case 2:
 
-           tmp1 = ps[15];
 
-           tmp2 = ps[11];
 
-           ps[12] = ps[3];
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = ps[7];
 
-           ps[11] = pi + 3;
 
-           ps[4] = tmp2;
 
-           ps[7] = pi + 4;
 
-           ps[0] = tmp1;
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           tmp1 = cs[3];
 
-           cs[2] = cs[1];
 
-           cs[3] = ci;
 
-           cs[0] = tmp1;
 
-           cs[1] = ci + 1;
 
-           break;
 
-         case 3:
 
-           ps[12] = ps[0];
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = ps[1];
 
-           ps[11] = pi + 3;
 
-           ps[4] = ps[2];
 
-           ps[7] = pi + 4;
 
-           ps[0] = ps[3];
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           cs[2] = cs[0];
 
-           cs[3] = ci;
 
-           cs[0] = cs[1];
 
-           cs[1] = ci + 1;
 
-           break;
 
-       }
 
-       ps[5] = coords.length;
 
-       coords.push([(-4 * coords[ps[0]][0] - coords[ps[15]][0] + 6 * (coords[ps[4]][0] + coords[ps[1]][0]) - 2 * (coords[ps[12]][0] + coords[ps[3]][0]) + 3 * (coords[ps[13]][0] + coords[ps[7]][0])) / 9, (-4 * coords[ps[0]][1] - coords[ps[15]][1] + 6 * (coords[ps[4]][1] + coords[ps[1]][1]) - 2 * (coords[ps[12]][1] + coords[ps[3]][1]) + 3 * (coords[ps[13]][1] + coords[ps[7]][1])) / 9]);
 
-       ps[6] = coords.length;
 
-       coords.push([(-4 * coords[ps[3]][0] - coords[ps[12]][0] + 6 * (coords[ps[2]][0] + coords[ps[7]][0]) - 2 * (coords[ps[0]][0] + coords[ps[15]][0]) + 3 * (coords[ps[4]][0] + coords[ps[14]][0])) / 9, (-4 * coords[ps[3]][1] - coords[ps[12]][1] + 6 * (coords[ps[2]][1] + coords[ps[7]][1]) - 2 * (coords[ps[0]][1] + coords[ps[15]][1]) + 3 * (coords[ps[4]][1] + coords[ps[14]][1])) / 9]);
 
-       ps[9] = coords.length;
 
-       coords.push([(-4 * coords[ps[12]][0] - coords[ps[3]][0] + 6 * (coords[ps[8]][0] + coords[ps[13]][0]) - 2 * (coords[ps[0]][0] + coords[ps[15]][0]) + 3 * (coords[ps[11]][0] + coords[ps[1]][0])) / 9, (-4 * coords[ps[12]][1] - coords[ps[3]][1] + 6 * (coords[ps[8]][1] + coords[ps[13]][1]) - 2 * (coords[ps[0]][1] + coords[ps[15]][1]) + 3 * (coords[ps[11]][1] + coords[ps[1]][1])) / 9]);
 
-       ps[10] = coords.length;
 
-       coords.push([(-4 * coords[ps[15]][0] - coords[ps[0]][0] + 6 * (coords[ps[11]][0] + coords[ps[14]][0]) - 2 * (coords[ps[12]][0] + coords[ps[3]][0]) + 3 * (coords[ps[2]][0] + coords[ps[8]][0])) / 9, (-4 * coords[ps[15]][1] - coords[ps[0]][1] + 6 * (coords[ps[11]][1] + coords[ps[14]][1]) - 2 * (coords[ps[12]][1] + coords[ps[3]][1]) + 3 * (coords[ps[2]][1] + coords[ps[8]][1])) / 9]);
 
-       mesh.figures.push({
 
-         type: "patch",
 
-         coords: new Int32Array(ps),
 
-         colors: new Int32Array(cs)
 
-       });
 
-     }
 
-   }
 
-   function decodeType7Shading(mesh, reader) {
 
-     var coords = mesh.coords;
 
-     var colors = mesh.colors;
 
-     var ps = new Int32Array(16);
 
-     var cs = new Int32Array(4);
 
-     while (reader.hasData) {
 
-       var f = reader.readFlag();
 
-       if (!(0 <= f && f <= 3)) {
 
-         throw new _util.FormatError("Unknown type7 flag");
 
-       }
 
-       var i, ii;
 
-       var pi = coords.length;
 
-       for (i = 0, ii = f !== 0 ? 12 : 16; i < ii; i++) {
 
-         coords.push(reader.readCoordinate());
 
-       }
 
-       var ci = colors.length;
 
-       for (i = 0, ii = f !== 0 ? 2 : 4; i < ii; i++) {
 
-         colors.push(reader.readComponents());
 
-       }
 
-       var tmp1, tmp2, tmp3, tmp4;
 
-       switch (f) {
 
-         case 0:
 
-           ps[12] = pi + 3;
 
-           ps[13] = pi + 4;
 
-           ps[14] = pi + 5;
 
-           ps[15] = pi + 6;
 
-           ps[8] = pi + 2;
 
-           ps[9] = pi + 13;
 
-           ps[10] = pi + 14;
 
-           ps[11] = pi + 7;
 
-           ps[4] = pi + 1;
 
-           ps[5] = pi + 12;
 
-           ps[6] = pi + 15;
 
-           ps[7] = pi + 8;
 
-           ps[0] = pi;
 
-           ps[1] = pi + 11;
 
-           ps[2] = pi + 10;
 
-           ps[3] = pi + 9;
 
-           cs[2] = ci + 1;
 
-           cs[3] = ci + 2;
 
-           cs[0] = ci;
 
-           cs[1] = ci + 3;
 
-           break;
 
-         case 1:
 
-           tmp1 = ps[12];
 
-           tmp2 = ps[13];
 
-           tmp3 = ps[14];
 
-           tmp4 = ps[15];
 
-           ps[12] = tmp4;
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = tmp3;
 
-           ps[9] = pi + 9;
 
-           ps[10] = pi + 10;
 
-           ps[11] = pi + 3;
 
-           ps[4] = tmp2;
 
-           ps[5] = pi + 8;
 
-           ps[6] = pi + 11;
 
-           ps[7] = pi + 4;
 
-           ps[0] = tmp1;
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           tmp1 = cs[2];
 
-           tmp2 = cs[3];
 
-           cs[2] = tmp2;
 
-           cs[3] = ci;
 
-           cs[0] = tmp1;
 
-           cs[1] = ci + 1;
 
-           break;
 
-         case 2:
 
-           tmp1 = ps[15];
 
-           tmp2 = ps[11];
 
-           ps[12] = ps[3];
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = ps[7];
 
-           ps[9] = pi + 9;
 
-           ps[10] = pi + 10;
 
-           ps[11] = pi + 3;
 
-           ps[4] = tmp2;
 
-           ps[5] = pi + 8;
 
-           ps[6] = pi + 11;
 
-           ps[7] = pi + 4;
 
-           ps[0] = tmp1;
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           tmp1 = cs[3];
 
-           cs[2] = cs[1];
 
-           cs[3] = ci;
 
-           cs[0] = tmp1;
 
-           cs[1] = ci + 1;
 
-           break;
 
-         case 3:
 
-           ps[12] = ps[0];
 
-           ps[13] = pi + 0;
 
-           ps[14] = pi + 1;
 
-           ps[15] = pi + 2;
 
-           ps[8] = ps[1];
 
-           ps[9] = pi + 9;
 
-           ps[10] = pi + 10;
 
-           ps[11] = pi + 3;
 
-           ps[4] = ps[2];
 
-           ps[5] = pi + 8;
 
-           ps[6] = pi + 11;
 
-           ps[7] = pi + 4;
 
-           ps[0] = ps[3];
 
-           ps[1] = pi + 7;
 
-           ps[2] = pi + 6;
 
-           ps[3] = pi + 5;
 
-           cs[2] = cs[0];
 
-           cs[3] = ci;
 
-           cs[0] = cs[1];
 
-           cs[1] = ci + 1;
 
-           break;
 
-       }
 
-       mesh.figures.push({
 
-         type: "patch",
 
-         coords: new Int32Array(ps),
 
-         colors: new Int32Array(cs)
 
-       });
 
-     }
 
-   }
 
-   function updateBounds(mesh) {
 
-     var minX = mesh.coords[0][0],
 
-         minY = mesh.coords[0][1],
 
-         maxX = minX,
 
-         maxY = minY;
 
-     for (var i = 1, ii = mesh.coords.length; i < ii; i++) {
 
-       var x = mesh.coords[i][0],
 
-           y = mesh.coords[i][1];
 
-       minX = minX > x ? x : minX;
 
-       minY = minY > y ? y : minY;
 
-       maxX = maxX < x ? x : maxX;
 
-       maxY = maxY < y ? y : maxY;
 
-     }
 
-     mesh.bounds = [minX, minY, maxX, maxY];
 
-   }
 
-   function packData(mesh) {
 
-     var i, ii, j, jj;
 
-     var coords = mesh.coords;
 
-     var coordsPacked = new Float32Array(coords.length * 2);
 
-     for (i = 0, j = 0, ii = coords.length; i < ii; i++) {
 
-       var xy = coords[i];
 
-       coordsPacked[j++] = xy[0];
 
-       coordsPacked[j++] = xy[1];
 
-     }
 
-     mesh.coords = coordsPacked;
 
-     var colors = mesh.colors;
 
-     var colorsPacked = new Uint8Array(colors.length * 3);
 
-     for (i = 0, j = 0, ii = colors.length; i < ii; i++) {
 
-       var c = colors[i];
 
-       colorsPacked[j++] = c[0];
 
-       colorsPacked[j++] = c[1];
 
-       colorsPacked[j++] = c[2];
 
-     }
 
-     mesh.colors = colorsPacked;
 
-     var figures = mesh.figures;
 
-     for (i = 0, ii = figures.length; i < ii; i++) {
 
-       var figure = figures[i],
 
-           ps = figure.coords,
 
-           cs = figure.colors;
 
-       for (j = 0, jj = ps.length; j < jj; j++) {
 
-         ps[j] *= 2;
 
-         cs[j] *= 3;
 
-       }
 
-     }
 
-   }
 
-   function Mesh(stream, matrix, xref, res, pdfFunctionFactory) {
 
-     if (!(0, _primitives.isStream)(stream)) {
 
-       throw new _util.FormatError("Mesh data is not a stream");
 
-     }
 
-     var dict = stream.dict;
 
-     this.matrix = matrix;
 
-     this.shadingType = dict.get("ShadingType");
 
-     this.type = "Pattern";
 
-     const bbox = dict.getArray("BBox");
 
-     if (Array.isArray(bbox) && bbox.length === 4) {
 
-       this.bbox = _util.Util.normalizeRect(bbox);
 
-     } else {
 
-       this.bbox = null;
 
-     }
 
-     var cs = dict.get("ColorSpace", "CS");
 
-     cs = _colorspace.ColorSpace.parse(cs, xref, res, pdfFunctionFactory);
 
-     this.cs = cs;
 
-     this.background = dict.has("Background") ? cs.getRgb(dict.get("Background"), 0) : null;
 
-     var fnObj = dict.get("Function");
 
-     var fn = fnObj ? pdfFunctionFactory.createFromArray(fnObj) : null;
 
-     this.coords = [];
 
-     this.colors = [];
 
-     this.figures = [];
 
-     var decodeContext = {
 
-       bitsPerCoordinate: dict.get("BitsPerCoordinate"),
 
-       bitsPerComponent: dict.get("BitsPerComponent"),
 
-       bitsPerFlag: dict.get("BitsPerFlag"),
 
-       decode: dict.getArray("Decode"),
 
-       colorFn: fn,
 
-       colorSpace: cs,
 
-       numComps: fn ? 1 : cs.numComps
 
-     };
 
-     var reader = new MeshStreamReader(stream, decodeContext);
 
-     var patchMesh = false;
 
-     switch (this.shadingType) {
 
-       case ShadingType.FREE_FORM_MESH:
 
-         decodeType4Shading(this, reader);
 
-         break;
 
-       case ShadingType.LATTICE_FORM_MESH:
 
-         var verticesPerRow = dict.get("VerticesPerRow") | 0;
 
-         if (verticesPerRow < 2) {
 
-           throw new _util.FormatError("Invalid VerticesPerRow");
 
-         }
 
-         decodeType5Shading(this, reader, verticesPerRow);
 
-         break;
 
-       case ShadingType.COONS_PATCH_MESH:
 
-         decodeType6Shading(this, reader);
 
-         patchMesh = true;
 
-         break;
 
-       case ShadingType.TENSOR_PATCH_MESH:
 
-         decodeType7Shading(this, reader);
 
-         patchMesh = true;
 
-         break;
 
-       default:
 
-         (0, _util.unreachable)("Unsupported mesh type.");
 
-         break;
 
-     }
 
-     if (patchMesh) {
 
-       updateBounds(this);
 
-       for (var i = 0, ii = this.figures.length; i < ii; i++) {
 
-         buildFigureFromPatch(this, i);
 
-       }
 
-     }
 
-     updateBounds(this);
 
-     packData(this);
 
-   }
 
-   Mesh.prototype = {
 
-     getIR: function Mesh_getIR() {
 
-       return ["Mesh", this.shadingType, this.coords, this.colors, this.figures, this.bounds, this.matrix, this.bbox, this.background];
 
-     }
 
-   };
 
-   return Mesh;
 
- }();
 
- Shadings.Dummy = function DummyClosure() {
 
-   function Dummy() {
 
-     this.type = "Pattern";
 
-   }
 
-   Dummy.prototype = {
 
-     getIR: function Dummy_getIR() {
 
-       return ["Dummy"];
 
-     }
 
-   };
 
-   return Dummy;
 
- }();
 
- function getTilingPatternIR(operatorList, dict, args) {
 
-   const matrix = dict.getArray("Matrix");
 
-   const bbox = _util.Util.normalizeRect(dict.getArray("BBox"));
 
-   const xstep = dict.get("XStep");
 
-   const ystep = dict.get("YStep");
 
-   const paintType = dict.get("PaintType");
 
-   const tilingType = dict.get("TilingType");
 
-   if (bbox[2] - bbox[0] === 0 || bbox[3] - bbox[1] === 0) {
 
-     throw new _util.FormatError(`Invalid getTilingPatternIR /BBox array: [${bbox}].`);
 
-   }
 
-   return ["TilingPattern", args, operatorList, matrix, bbox, xstep, ystep, paintType, tilingType];
 
- }
 
- /***/ }),
 
- /* 37 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.bidi = bidi;
 
- var _util = __w_pdfjs_require__(2);
 
- var baseTypes = ["BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "S", "B", "S", "WS", "B", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "B", "B", "B", "S", "WS", "ON", "ON", "ET", "ET", "ET", "ON", "ON", "ON", "ON", "ON", "ES", "CS", "ES", "CS", "CS", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "CS", "ON", "ON", "ON", "ON", "ON", "ON", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "ON", "ON", "ON", "ON", "ON", "ON", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "ON", "ON", "ON", "ON", "BN", "BN", "BN", "BN", "BN", "BN", "B", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "BN", "CS", "ON", "ET", "ET", "ET", "ET", "ON", "ON", "ON", "ON", "L", "ON", "ON", "BN", "ON", "ON", "ET", "ET", "EN", "EN", "ON", "L", "ON", "ON", "ON", "EN", "L", "ON", "ON", "ON", "ON", "ON", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "ON", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "L", "ON", "L", "L", "L", "L", "L", "L", "L", "L"];
 
- var arabicTypes = ["AN", "AN", "AN", "AN", "AN", "AN", "ON", "ON", "AL", "ET", "ET", "AL", "CS", "AL", "ON", "ON", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "AL", "AL", "", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "AN", "AN", "AN", "AN", "AN", "AN", "AN", "AN", "AN", "AN", "ET", "AN", "AN", "AL", "AL", "AL", "NSM", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "AN", "ON", "NSM", "NSM", "NSM", "NSM", "NSM", "NSM", "AL", "AL", "NSM", "NSM", "ON", "NSM", "NSM", "NSM", "NSM", "AL", "AL", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "EN", "AL", "AL", "AL", "AL", "AL", "AL"];
 
- function isOdd(i) {
 
-   return (i & 1) !== 0;
 
- }
 
- function isEven(i) {
 
-   return (i & 1) === 0;
 
- }
 
- function findUnequal(arr, start, value) {
 
-   for (var j = start, jj = arr.length; j < jj; ++j) {
 
-     if (arr[j] !== value) {
 
-       return j;
 
-     }
 
-   }
 
-   return j;
 
- }
 
- function setValues(arr, start, end, value) {
 
-   for (var j = start; j < end; ++j) {
 
-     arr[j] = value;
 
-   }
 
- }
 
- function reverseValues(arr, start, end) {
 
-   for (var i = start, j = end - 1; i < j; ++i, --j) {
 
-     var temp = arr[i];
 
-     arr[i] = arr[j];
 
-     arr[j] = temp;
 
-   }
 
- }
 
- function createBidiText(str, isLTR, vertical = false) {
 
-   let dir = "ltr";
 
-   if (vertical) {
 
-     dir = "ttb";
 
-   } else if (!isLTR) {
 
-     dir = "rtl";
 
-   }
 
-   return {
 
-     str,
 
-     dir
 
-   };
 
- }
 
- var chars = [];
 
- var types = [];
 
- function bidi(str, startLevel, vertical) {
 
-   var isLTR = true;
 
-   var strLength = str.length;
 
-   if (strLength === 0 || vertical) {
 
-     return createBidiText(str, isLTR, vertical);
 
-   }
 
-   chars.length = strLength;
 
-   types.length = strLength;
 
-   var numBidi = 0;
 
-   var i, ii;
 
-   for (i = 0; i < strLength; ++i) {
 
-     chars[i] = str.charAt(i);
 
-     var charCode = str.charCodeAt(i);
 
-     var charType = "L";
 
-     if (charCode <= 0x00ff) {
 
-       charType = baseTypes[charCode];
 
-     } else if (0x0590 <= charCode && charCode <= 0x05f4) {
 
-       charType = "R";
 
-     } else if (0x0600 <= charCode && charCode <= 0x06ff) {
 
-       charType = arabicTypes[charCode & 0xff];
 
-       if (!charType) {
 
-         (0, _util.warn)("Bidi: invalid Unicode character " + charCode.toString(16));
 
-       }
 
-     } else if (0x0700 <= charCode && charCode <= 0x08ac) {
 
-       charType = "AL";
 
-     }
 
-     if (charType === "R" || charType === "AL" || charType === "AN") {
 
-       numBidi++;
 
-     }
 
-     types[i] = charType;
 
-   }
 
-   if (numBidi === 0) {
 
-     isLTR = true;
 
-     return createBidiText(str, isLTR);
 
-   }
 
-   if (startLevel === -1) {
 
-     if (numBidi / strLength < 0.3) {
 
-       isLTR = true;
 
-       startLevel = 0;
 
-     } else {
 
-       isLTR = false;
 
-       startLevel = 1;
 
-     }
 
-   }
 
-   var levels = [];
 
-   for (i = 0; i < strLength; ++i) {
 
-     levels[i] = startLevel;
 
-   }
 
-   var e = isOdd(startLevel) ? "R" : "L";
 
-   var sor = e;
 
-   var eor = sor;
 
-   var lastType = sor;
 
-   for (i = 0; i < strLength; ++i) {
 
-     if (types[i] === "NSM") {
 
-       types[i] = lastType;
 
-     } else {
 
-       lastType = types[i];
 
-     }
 
-   }
 
-   lastType = sor;
 
-   var t;
 
-   for (i = 0; i < strLength; ++i) {
 
-     t = types[i];
 
-     if (t === "EN") {
 
-       types[i] = lastType === "AL" ? "AN" : "EN";
 
-     } else if (t === "R" || t === "L" || t === "AL") {
 
-       lastType = t;
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     t = types[i];
 
-     if (t === "AL") {
 
-       types[i] = "R";
 
-     }
 
-   }
 
-   for (i = 1; i < strLength - 1; ++i) {
 
-     if (types[i] === "ES" && types[i - 1] === "EN" && types[i + 1] === "EN") {
 
-       types[i] = "EN";
 
-     }
 
-     if (types[i] === "CS" && (types[i - 1] === "EN" || types[i - 1] === "AN") && types[i + 1] === types[i - 1]) {
 
-       types[i] = types[i - 1];
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     if (types[i] === "EN") {
 
-       var j;
 
-       for (j = i - 1; j >= 0; --j) {
 
-         if (types[j] !== "ET") {
 
-           break;
 
-         }
 
-         types[j] = "EN";
 
-       }
 
-       for (j = i + 1; j < strLength; ++j) {
 
-         if (types[j] !== "ET") {
 
-           break;
 
-         }
 
-         types[j] = "EN";
 
-       }
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     t = types[i];
 
-     if (t === "WS" || t === "ES" || t === "ET" || t === "CS") {
 
-       types[i] = "ON";
 
-     }
 
-   }
 
-   lastType = sor;
 
-   for (i = 0; i < strLength; ++i) {
 
-     t = types[i];
 
-     if (t === "EN") {
 
-       types[i] = lastType === "L" ? "L" : "EN";
 
-     } else if (t === "R" || t === "L") {
 
-       lastType = t;
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     if (types[i] === "ON") {
 
-       var end = findUnequal(types, i + 1, "ON");
 
-       var before = sor;
 
-       if (i > 0) {
 
-         before = types[i - 1];
 
-       }
 
-       var after = eor;
 
-       if (end + 1 < strLength) {
 
-         after = types[end + 1];
 
-       }
 
-       if (before !== "L") {
 
-         before = "R";
 
-       }
 
-       if (after !== "L") {
 
-         after = "R";
 
-       }
 
-       if (before === after) {
 
-         setValues(types, i, end, before);
 
-       }
 
-       i = end - 1;
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     if (types[i] === "ON") {
 
-       types[i] = e;
 
-     }
 
-   }
 
-   for (i = 0; i < strLength; ++i) {
 
-     t = types[i];
 
-     if (isEven(levels[i])) {
 
-       if (t === "R") {
 
-         levels[i] += 1;
 
-       } else if (t === "AN" || t === "EN") {
 
-         levels[i] += 2;
 
-       }
 
-     } else {
 
-       if (t === "L" || t === "AN" || t === "EN") {
 
-         levels[i] += 1;
 
-       }
 
-     }
 
-   }
 
-   var highestLevel = -1;
 
-   var lowestOddLevel = 99;
 
-   var level;
 
-   for (i = 0, ii = levels.length; i < ii; ++i) {
 
-     level = levels[i];
 
-     if (highestLevel < level) {
 
-       highestLevel = level;
 
-     }
 
-     if (lowestOddLevel > level && isOdd(level)) {
 
-       lowestOddLevel = level;
 
-     }
 
-   }
 
-   for (level = highestLevel; level >= lowestOddLevel; --level) {
 
-     var start = -1;
 
-     for (i = 0, ii = levels.length; i < ii; ++i) {
 
-       if (levels[i] < level) {
 
-         if (start >= 0) {
 
-           reverseValues(chars, start, i);
 
-           start = -1;
 
-         }
 
-       } else if (start < 0) {
 
-         start = i;
 
-       }
 
-     }
 
-     if (start >= 0) {
 
-       reverseValues(chars, start, levels.length);
 
-     }
 
-   }
 
-   for (i = 0, ii = chars.length; i < ii; ++i) {
 
-     var ch = chars[i];
 
-     if (ch === "<" || ch === ">") {
 
-       chars[i] = "";
 
-     }
 
-   }
 
-   return createBidiText(chars.join(""), isLTR);
 
- }
 
- /***/ }),
 
- /* 38 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.getMetrics = void 0;
 
- var _core_utils = __w_pdfjs_require__(7);
 
- var getMetrics = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-   t["Courier"] = 600;
 
-   t["Courier-Bold"] = 600;
 
-   t["Courier-BoldOblique"] = 600;
 
-   t["Courier-Oblique"] = 600;
 
-   t["Helvetica"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 278;
 
-     t["exclam"] = 278;
 
-     t["quotedbl"] = 355;
 
-     t["numbersign"] = 556;
 
-     t["dollar"] = 556;
 
-     t["percent"] = 889;
 
-     t["ampersand"] = 667;
 
-     t["quoteright"] = 222;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 389;
 
-     t["plus"] = 584;
 
-     t["comma"] = 278;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 278;
 
-     t["slash"] = 278;
 
-     t["zero"] = 556;
 
-     t["one"] = 556;
 
-     t["two"] = 556;
 
-     t["three"] = 556;
 
-     t["four"] = 556;
 
-     t["five"] = 556;
 
-     t["six"] = 556;
 
-     t["seven"] = 556;
 
-     t["eight"] = 556;
 
-     t["nine"] = 556;
 
-     t["colon"] = 278;
 
-     t["semicolon"] = 278;
 
-     t["less"] = 584;
 
-     t["equal"] = 584;
 
-     t["greater"] = 584;
 
-     t["question"] = 556;
 
-     t["at"] = 1015;
 
-     t["A"] = 667;
 
-     t["B"] = 667;
 
-     t["C"] = 722;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 611;
 
-     t["G"] = 778;
 
-     t["H"] = 722;
 
-     t["I"] = 278;
 
-     t["J"] = 500;
 
-     t["K"] = 667;
 
-     t["L"] = 556;
 
-     t["M"] = 833;
 
-     t["N"] = 722;
 
-     t["O"] = 778;
 
-     t["P"] = 667;
 
-     t["Q"] = 778;
 
-     t["R"] = 722;
 
-     t["S"] = 667;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 667;
 
-     t["W"] = 944;
 
-     t["X"] = 667;
 
-     t["Y"] = 667;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 278;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 278;
 
-     t["asciicircum"] = 469;
 
-     t["underscore"] = 556;
 
-     t["quoteleft"] = 222;
 
-     t["a"] = 556;
 
-     t["b"] = 556;
 
-     t["c"] = 500;
 
-     t["d"] = 556;
 
-     t["e"] = 556;
 
-     t["f"] = 278;
 
-     t["g"] = 556;
 
-     t["h"] = 556;
 
-     t["i"] = 222;
 
-     t["j"] = 222;
 
-     t["k"] = 500;
 
-     t["l"] = 222;
 
-     t["m"] = 833;
 
-     t["n"] = 556;
 
-     t["o"] = 556;
 
-     t["p"] = 556;
 
-     t["q"] = 556;
 
-     t["r"] = 333;
 
-     t["s"] = 500;
 
-     t["t"] = 278;
 
-     t["u"] = 556;
 
-     t["v"] = 500;
 
-     t["w"] = 722;
 
-     t["x"] = 500;
 
-     t["y"] = 500;
 
-     t["z"] = 500;
 
-     t["braceleft"] = 334;
 
-     t["bar"] = 260;
 
-     t["braceright"] = 334;
 
-     t["asciitilde"] = 584;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 556;
 
-     t["sterling"] = 556;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 556;
 
-     t["florin"] = 556;
 
-     t["section"] = 556;
 
-     t["currency"] = 556;
 
-     t["quotesingle"] = 191;
 
-     t["quotedblleft"] = 333;
 
-     t["guillemotleft"] = 556;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 500;
 
-     t["fl"] = 500;
 
-     t["endash"] = 556;
 
-     t["dagger"] = 556;
 
-     t["daggerdbl"] = 556;
 
-     t["periodcentered"] = 278;
 
-     t["paragraph"] = 537;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 222;
 
-     t["quotedblbase"] = 333;
 
-     t["quotedblright"] = 333;
 
-     t["guillemotright"] = 556;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 611;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 1000;
 
-     t["ordfeminine"] = 370;
 
-     t["Lslash"] = 556;
 
-     t["Oslash"] = 778;
 
-     t["OE"] = 1000;
 
-     t["ordmasculine"] = 365;
 
-     t["ae"] = 889;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 222;
 
-     t["oslash"] = 611;
 
-     t["oe"] = 944;
 
-     t["germandbls"] = 611;
 
-     t["Idieresis"] = 278;
 
-     t["eacute"] = 556;
 
-     t["abreve"] = 556;
 
-     t["uhungarumlaut"] = 556;
 
-     t["ecaron"] = 556;
 
-     t["Ydieresis"] = 667;
 
-     t["divide"] = 584;
 
-     t["Yacute"] = 667;
 
-     t["Acircumflex"] = 667;
 
-     t["aacute"] = 556;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 500;
 
-     t["scommaaccent"] = 500;
 
-     t["ecircumflex"] = 556;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 556;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 556;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 737;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 500;
 
-     t["aring"] = 556;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 222;
 
-     t["agrave"] = 556;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 722;
 
-     t["atilde"] = 556;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 500;
 
-     t["scedilla"] = 500;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 471;
 
-     t["Rcaron"] = 722;
 
-     t["Gcommaaccent"] = 778;
 
-     t["ucircumflex"] = 556;
 
-     t["acircumflex"] = 556;
 
-     t["Amacron"] = 667;
 
-     t["rcaron"] = 333;
 
-     t["ccedilla"] = 500;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 667;
 
-     t["Omacron"] = 778;
 
-     t["Racute"] = 722;
 
-     t["Sacute"] = 667;
 
-     t["dcaron"] = 643;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 556;
 
-     t["threesuperior"] = 333;
 
-     t["Ograve"] = 778;
 
-     t["Agrave"] = 667;
 
-     t["Abreve"] = 667;
 
-     t["multiply"] = 584;
 
-     t["uacute"] = 556;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 476;
 
-     t["ydieresis"] = 500;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 556;
 
-     t["edieresis"] = 556;
 
-     t["cacute"] = 500;
 
-     t["nacute"] = 556;
 
-     t["umacron"] = 556;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 278;
 
-     t["plusminus"] = 584;
 
-     t["brokenbar"] = 260;
 
-     t["registered"] = 737;
 
-     t["Gbreve"] = 778;
 
-     t["Idotaccent"] = 278;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 333;
 
-     t["omacron"] = 556;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 722;
 
-     t["lcommaaccent"] = 222;
 
-     t["tcaron"] = 317;
 
-     t["eogonek"] = 556;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 667;
 
-     t["Adieresis"] = 667;
 
-     t["egrave"] = 556;
 
-     t["zacute"] = 500;
 
-     t["iogonek"] = 222;
 
-     t["Oacute"] = 778;
 
-     t["oacute"] = 556;
 
-     t["amacron"] = 556;
 
-     t["sacute"] = 500;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 778;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 556;
 
-     t["twosuperior"] = 333;
 
-     t["Odieresis"] = 778;
 
-     t["mu"] = 556;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 556;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 556;
 
-     t["threequarters"] = 834;
 
-     t["Scedilla"] = 667;
 
-     t["lcaron"] = 299;
 
-     t["Kcommaaccent"] = 667;
 
-     t["Lacute"] = 556;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 556;
 
-     t["Igrave"] = 278;
 
-     t["Imacron"] = 278;
 
-     t["Lcaron"] = 556;
 
-     t["onehalf"] = 834;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 556;
 
-     t["ntilde"] = 556;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 556;
 
-     t["gbreve"] = 556;
 
-     t["onequarter"] = 834;
 
-     t["Scaron"] = 667;
 
-     t["Scommaaccent"] = 667;
 
-     t["Ohungarumlaut"] = 778;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 556;
 
-     t["Ccaron"] = 722;
 
-     t["ugrave"] = 556;
 
-     t["radical"] = 453;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 333;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 556;
 
-     t["Rcommaaccent"] = 722;
 
-     t["Lcommaaccent"] = 556;
 
-     t["Atilde"] = 667;
 
-     t["Aogonek"] = 667;
 
-     t["Aring"] = 667;
 
-     t["Otilde"] = 778;
 
-     t["zdotaccent"] = 500;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 278;
 
-     t["kcommaaccent"] = 500;
 
-     t["minus"] = 584;
 
-     t["Icircumflex"] = 278;
 
-     t["ncaron"] = 556;
 
-     t["tcommaaccent"] = 278;
 
-     t["logicalnot"] = 584;
 
-     t["odieresis"] = 556;
 
-     t["udieresis"] = 556;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 556;
 
-     t["eth"] = 556;
 
-     t["zcaron"] = 500;
 
-     t["ncommaaccent"] = 556;
 
-     t["onesuperior"] = 333;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 556;
 
-   });
 
-   t["Helvetica-Bold"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 278;
 
-     t["exclam"] = 333;
 
-     t["quotedbl"] = 474;
 
-     t["numbersign"] = 556;
 
-     t["dollar"] = 556;
 
-     t["percent"] = 889;
 
-     t["ampersand"] = 722;
 
-     t["quoteright"] = 278;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 389;
 
-     t["plus"] = 584;
 
-     t["comma"] = 278;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 278;
 
-     t["slash"] = 278;
 
-     t["zero"] = 556;
 
-     t["one"] = 556;
 
-     t["two"] = 556;
 
-     t["three"] = 556;
 
-     t["four"] = 556;
 
-     t["five"] = 556;
 
-     t["six"] = 556;
 
-     t["seven"] = 556;
 
-     t["eight"] = 556;
 
-     t["nine"] = 556;
 
-     t["colon"] = 333;
 
-     t["semicolon"] = 333;
 
-     t["less"] = 584;
 
-     t["equal"] = 584;
 
-     t["greater"] = 584;
 
-     t["question"] = 611;
 
-     t["at"] = 975;
 
-     t["A"] = 722;
 
-     t["B"] = 722;
 
-     t["C"] = 722;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 611;
 
-     t["G"] = 778;
 
-     t["H"] = 722;
 
-     t["I"] = 278;
 
-     t["J"] = 556;
 
-     t["K"] = 722;
 
-     t["L"] = 611;
 
-     t["M"] = 833;
 
-     t["N"] = 722;
 
-     t["O"] = 778;
 
-     t["P"] = 667;
 
-     t["Q"] = 778;
 
-     t["R"] = 722;
 
-     t["S"] = 667;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 667;
 
-     t["W"] = 944;
 
-     t["X"] = 667;
 
-     t["Y"] = 667;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 333;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 333;
 
-     t["asciicircum"] = 584;
 
-     t["underscore"] = 556;
 
-     t["quoteleft"] = 278;
 
-     t["a"] = 556;
 
-     t["b"] = 611;
 
-     t["c"] = 556;
 
-     t["d"] = 611;
 
-     t["e"] = 556;
 
-     t["f"] = 333;
 
-     t["g"] = 611;
 
-     t["h"] = 611;
 
-     t["i"] = 278;
 
-     t["j"] = 278;
 
-     t["k"] = 556;
 
-     t["l"] = 278;
 
-     t["m"] = 889;
 
-     t["n"] = 611;
 
-     t["o"] = 611;
 
-     t["p"] = 611;
 
-     t["q"] = 611;
 
-     t["r"] = 389;
 
-     t["s"] = 556;
 
-     t["t"] = 333;
 
-     t["u"] = 611;
 
-     t["v"] = 556;
 
-     t["w"] = 778;
 
-     t["x"] = 556;
 
-     t["y"] = 556;
 
-     t["z"] = 500;
 
-     t["braceleft"] = 389;
 
-     t["bar"] = 280;
 
-     t["braceright"] = 389;
 
-     t["asciitilde"] = 584;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 556;
 
-     t["sterling"] = 556;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 556;
 
-     t["florin"] = 556;
 
-     t["section"] = 556;
 
-     t["currency"] = 556;
 
-     t["quotesingle"] = 238;
 
-     t["quotedblleft"] = 500;
 
-     t["guillemotleft"] = 556;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 611;
 
-     t["fl"] = 611;
 
-     t["endash"] = 556;
 
-     t["dagger"] = 556;
 
-     t["daggerdbl"] = 556;
 
-     t["periodcentered"] = 278;
 
-     t["paragraph"] = 556;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 278;
 
-     t["quotedblbase"] = 500;
 
-     t["quotedblright"] = 500;
 
-     t["guillemotright"] = 556;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 611;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 1000;
 
-     t["ordfeminine"] = 370;
 
-     t["Lslash"] = 611;
 
-     t["Oslash"] = 778;
 
-     t["OE"] = 1000;
 
-     t["ordmasculine"] = 365;
 
-     t["ae"] = 889;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 611;
 
-     t["oe"] = 944;
 
-     t["germandbls"] = 611;
 
-     t["Idieresis"] = 278;
 
-     t["eacute"] = 556;
 
-     t["abreve"] = 556;
 
-     t["uhungarumlaut"] = 611;
 
-     t["ecaron"] = 556;
 
-     t["Ydieresis"] = 667;
 
-     t["divide"] = 584;
 
-     t["Yacute"] = 667;
 
-     t["Acircumflex"] = 722;
 
-     t["aacute"] = 556;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 556;
 
-     t["scommaaccent"] = 556;
 
-     t["ecircumflex"] = 556;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 556;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 611;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 737;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 556;
 
-     t["aring"] = 556;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 556;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 722;
 
-     t["atilde"] = 556;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 556;
 
-     t["scedilla"] = 556;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 494;
 
-     t["Rcaron"] = 722;
 
-     t["Gcommaaccent"] = 778;
 
-     t["ucircumflex"] = 611;
 
-     t["acircumflex"] = 556;
 
-     t["Amacron"] = 722;
 
-     t["rcaron"] = 389;
 
-     t["ccedilla"] = 556;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 667;
 
-     t["Omacron"] = 778;
 
-     t["Racute"] = 722;
 
-     t["Sacute"] = 667;
 
-     t["dcaron"] = 743;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 611;
 
-     t["threesuperior"] = 333;
 
-     t["Ograve"] = 778;
 
-     t["Agrave"] = 722;
 
-     t["Abreve"] = 722;
 
-     t["multiply"] = 584;
 
-     t["uacute"] = 611;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 494;
 
-     t["ydieresis"] = 556;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 556;
 
-     t["edieresis"] = 556;
 
-     t["cacute"] = 556;
 
-     t["nacute"] = 611;
 
-     t["umacron"] = 611;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 278;
 
-     t["plusminus"] = 584;
 
-     t["brokenbar"] = 280;
 
-     t["registered"] = 737;
 
-     t["Gbreve"] = 778;
 
-     t["Idotaccent"] = 278;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 389;
 
-     t["omacron"] = 611;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 722;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 389;
 
-     t["eogonek"] = 556;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 722;
 
-     t["Adieresis"] = 722;
 
-     t["egrave"] = 556;
 
-     t["zacute"] = 500;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 778;
 
-     t["oacute"] = 611;
 
-     t["amacron"] = 556;
 
-     t["sacute"] = 556;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 778;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 611;
 
-     t["twosuperior"] = 333;
 
-     t["Odieresis"] = 778;
 
-     t["mu"] = 611;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 611;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 611;
 
-     t["threequarters"] = 834;
 
-     t["Scedilla"] = 667;
 
-     t["lcaron"] = 400;
 
-     t["Kcommaaccent"] = 722;
 
-     t["Lacute"] = 611;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 556;
 
-     t["Igrave"] = 278;
 
-     t["Imacron"] = 278;
 
-     t["Lcaron"] = 611;
 
-     t["onehalf"] = 834;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 611;
 
-     t["ntilde"] = 611;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 556;
 
-     t["gbreve"] = 611;
 
-     t["onequarter"] = 834;
 
-     t["Scaron"] = 667;
 
-     t["Scommaaccent"] = 667;
 
-     t["Ohungarumlaut"] = 778;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 611;
 
-     t["Ccaron"] = 722;
 
-     t["ugrave"] = 611;
 
-     t["radical"] = 549;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 389;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 611;
 
-     t["Rcommaaccent"] = 722;
 
-     t["Lcommaaccent"] = 611;
 
-     t["Atilde"] = 722;
 
-     t["Aogonek"] = 722;
 
-     t["Aring"] = 722;
 
-     t["Otilde"] = 778;
 
-     t["zdotaccent"] = 500;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 278;
 
-     t["kcommaaccent"] = 556;
 
-     t["minus"] = 584;
 
-     t["Icircumflex"] = 278;
 
-     t["ncaron"] = 611;
 
-     t["tcommaaccent"] = 333;
 
-     t["logicalnot"] = 584;
 
-     t["odieresis"] = 611;
 
-     t["udieresis"] = 611;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 611;
 
-     t["eth"] = 611;
 
-     t["zcaron"] = 500;
 
-     t["ncommaaccent"] = 611;
 
-     t["onesuperior"] = 333;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 556;
 
-   });
 
-   t["Helvetica-BoldOblique"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 278;
 
-     t["exclam"] = 333;
 
-     t["quotedbl"] = 474;
 
-     t["numbersign"] = 556;
 
-     t["dollar"] = 556;
 
-     t["percent"] = 889;
 
-     t["ampersand"] = 722;
 
-     t["quoteright"] = 278;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 389;
 
-     t["plus"] = 584;
 
-     t["comma"] = 278;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 278;
 
-     t["slash"] = 278;
 
-     t["zero"] = 556;
 
-     t["one"] = 556;
 
-     t["two"] = 556;
 
-     t["three"] = 556;
 
-     t["four"] = 556;
 
-     t["five"] = 556;
 
-     t["six"] = 556;
 
-     t["seven"] = 556;
 
-     t["eight"] = 556;
 
-     t["nine"] = 556;
 
-     t["colon"] = 333;
 
-     t["semicolon"] = 333;
 
-     t["less"] = 584;
 
-     t["equal"] = 584;
 
-     t["greater"] = 584;
 
-     t["question"] = 611;
 
-     t["at"] = 975;
 
-     t["A"] = 722;
 
-     t["B"] = 722;
 
-     t["C"] = 722;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 611;
 
-     t["G"] = 778;
 
-     t["H"] = 722;
 
-     t["I"] = 278;
 
-     t["J"] = 556;
 
-     t["K"] = 722;
 
-     t["L"] = 611;
 
-     t["M"] = 833;
 
-     t["N"] = 722;
 
-     t["O"] = 778;
 
-     t["P"] = 667;
 
-     t["Q"] = 778;
 
-     t["R"] = 722;
 
-     t["S"] = 667;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 667;
 
-     t["W"] = 944;
 
-     t["X"] = 667;
 
-     t["Y"] = 667;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 333;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 333;
 
-     t["asciicircum"] = 584;
 
-     t["underscore"] = 556;
 
-     t["quoteleft"] = 278;
 
-     t["a"] = 556;
 
-     t["b"] = 611;
 
-     t["c"] = 556;
 
-     t["d"] = 611;
 
-     t["e"] = 556;
 
-     t["f"] = 333;
 
-     t["g"] = 611;
 
-     t["h"] = 611;
 
-     t["i"] = 278;
 
-     t["j"] = 278;
 
-     t["k"] = 556;
 
-     t["l"] = 278;
 
-     t["m"] = 889;
 
-     t["n"] = 611;
 
-     t["o"] = 611;
 
-     t["p"] = 611;
 
-     t["q"] = 611;
 
-     t["r"] = 389;
 
-     t["s"] = 556;
 
-     t["t"] = 333;
 
-     t["u"] = 611;
 
-     t["v"] = 556;
 
-     t["w"] = 778;
 
-     t["x"] = 556;
 
-     t["y"] = 556;
 
-     t["z"] = 500;
 
-     t["braceleft"] = 389;
 
-     t["bar"] = 280;
 
-     t["braceright"] = 389;
 
-     t["asciitilde"] = 584;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 556;
 
-     t["sterling"] = 556;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 556;
 
-     t["florin"] = 556;
 
-     t["section"] = 556;
 
-     t["currency"] = 556;
 
-     t["quotesingle"] = 238;
 
-     t["quotedblleft"] = 500;
 
-     t["guillemotleft"] = 556;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 611;
 
-     t["fl"] = 611;
 
-     t["endash"] = 556;
 
-     t["dagger"] = 556;
 
-     t["daggerdbl"] = 556;
 
-     t["periodcentered"] = 278;
 
-     t["paragraph"] = 556;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 278;
 
-     t["quotedblbase"] = 500;
 
-     t["quotedblright"] = 500;
 
-     t["guillemotright"] = 556;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 611;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 1000;
 
-     t["ordfeminine"] = 370;
 
-     t["Lslash"] = 611;
 
-     t["Oslash"] = 778;
 
-     t["OE"] = 1000;
 
-     t["ordmasculine"] = 365;
 
-     t["ae"] = 889;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 611;
 
-     t["oe"] = 944;
 
-     t["germandbls"] = 611;
 
-     t["Idieresis"] = 278;
 
-     t["eacute"] = 556;
 
-     t["abreve"] = 556;
 
-     t["uhungarumlaut"] = 611;
 
-     t["ecaron"] = 556;
 
-     t["Ydieresis"] = 667;
 
-     t["divide"] = 584;
 
-     t["Yacute"] = 667;
 
-     t["Acircumflex"] = 722;
 
-     t["aacute"] = 556;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 556;
 
-     t["scommaaccent"] = 556;
 
-     t["ecircumflex"] = 556;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 556;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 611;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 737;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 556;
 
-     t["aring"] = 556;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 556;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 722;
 
-     t["atilde"] = 556;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 556;
 
-     t["scedilla"] = 556;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 494;
 
-     t["Rcaron"] = 722;
 
-     t["Gcommaaccent"] = 778;
 
-     t["ucircumflex"] = 611;
 
-     t["acircumflex"] = 556;
 
-     t["Amacron"] = 722;
 
-     t["rcaron"] = 389;
 
-     t["ccedilla"] = 556;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 667;
 
-     t["Omacron"] = 778;
 
-     t["Racute"] = 722;
 
-     t["Sacute"] = 667;
 
-     t["dcaron"] = 743;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 611;
 
-     t["threesuperior"] = 333;
 
-     t["Ograve"] = 778;
 
-     t["Agrave"] = 722;
 
-     t["Abreve"] = 722;
 
-     t["multiply"] = 584;
 
-     t["uacute"] = 611;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 494;
 
-     t["ydieresis"] = 556;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 556;
 
-     t["edieresis"] = 556;
 
-     t["cacute"] = 556;
 
-     t["nacute"] = 611;
 
-     t["umacron"] = 611;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 278;
 
-     t["plusminus"] = 584;
 
-     t["brokenbar"] = 280;
 
-     t["registered"] = 737;
 
-     t["Gbreve"] = 778;
 
-     t["Idotaccent"] = 278;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 389;
 
-     t["omacron"] = 611;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 722;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 389;
 
-     t["eogonek"] = 556;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 722;
 
-     t["Adieresis"] = 722;
 
-     t["egrave"] = 556;
 
-     t["zacute"] = 500;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 778;
 
-     t["oacute"] = 611;
 
-     t["amacron"] = 556;
 
-     t["sacute"] = 556;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 778;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 611;
 
-     t["twosuperior"] = 333;
 
-     t["Odieresis"] = 778;
 
-     t["mu"] = 611;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 611;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 611;
 
-     t["threequarters"] = 834;
 
-     t["Scedilla"] = 667;
 
-     t["lcaron"] = 400;
 
-     t["Kcommaaccent"] = 722;
 
-     t["Lacute"] = 611;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 556;
 
-     t["Igrave"] = 278;
 
-     t["Imacron"] = 278;
 
-     t["Lcaron"] = 611;
 
-     t["onehalf"] = 834;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 611;
 
-     t["ntilde"] = 611;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 556;
 
-     t["gbreve"] = 611;
 
-     t["onequarter"] = 834;
 
-     t["Scaron"] = 667;
 
-     t["Scommaaccent"] = 667;
 
-     t["Ohungarumlaut"] = 778;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 611;
 
-     t["Ccaron"] = 722;
 
-     t["ugrave"] = 611;
 
-     t["radical"] = 549;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 389;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 611;
 
-     t["Rcommaaccent"] = 722;
 
-     t["Lcommaaccent"] = 611;
 
-     t["Atilde"] = 722;
 
-     t["Aogonek"] = 722;
 
-     t["Aring"] = 722;
 
-     t["Otilde"] = 778;
 
-     t["zdotaccent"] = 500;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 278;
 
-     t["kcommaaccent"] = 556;
 
-     t["minus"] = 584;
 
-     t["Icircumflex"] = 278;
 
-     t["ncaron"] = 611;
 
-     t["tcommaaccent"] = 333;
 
-     t["logicalnot"] = 584;
 
-     t["odieresis"] = 611;
 
-     t["udieresis"] = 611;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 611;
 
-     t["eth"] = 611;
 
-     t["zcaron"] = 500;
 
-     t["ncommaaccent"] = 611;
 
-     t["onesuperior"] = 333;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 556;
 
-   });
 
-   t["Helvetica-Oblique"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 278;
 
-     t["exclam"] = 278;
 
-     t["quotedbl"] = 355;
 
-     t["numbersign"] = 556;
 
-     t["dollar"] = 556;
 
-     t["percent"] = 889;
 
-     t["ampersand"] = 667;
 
-     t["quoteright"] = 222;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 389;
 
-     t["plus"] = 584;
 
-     t["comma"] = 278;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 278;
 
-     t["slash"] = 278;
 
-     t["zero"] = 556;
 
-     t["one"] = 556;
 
-     t["two"] = 556;
 
-     t["three"] = 556;
 
-     t["four"] = 556;
 
-     t["five"] = 556;
 
-     t["six"] = 556;
 
-     t["seven"] = 556;
 
-     t["eight"] = 556;
 
-     t["nine"] = 556;
 
-     t["colon"] = 278;
 
-     t["semicolon"] = 278;
 
-     t["less"] = 584;
 
-     t["equal"] = 584;
 
-     t["greater"] = 584;
 
-     t["question"] = 556;
 
-     t["at"] = 1015;
 
-     t["A"] = 667;
 
-     t["B"] = 667;
 
-     t["C"] = 722;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 611;
 
-     t["G"] = 778;
 
-     t["H"] = 722;
 
-     t["I"] = 278;
 
-     t["J"] = 500;
 
-     t["K"] = 667;
 
-     t["L"] = 556;
 
-     t["M"] = 833;
 
-     t["N"] = 722;
 
-     t["O"] = 778;
 
-     t["P"] = 667;
 
-     t["Q"] = 778;
 
-     t["R"] = 722;
 
-     t["S"] = 667;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 667;
 
-     t["W"] = 944;
 
-     t["X"] = 667;
 
-     t["Y"] = 667;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 278;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 278;
 
-     t["asciicircum"] = 469;
 
-     t["underscore"] = 556;
 
-     t["quoteleft"] = 222;
 
-     t["a"] = 556;
 
-     t["b"] = 556;
 
-     t["c"] = 500;
 
-     t["d"] = 556;
 
-     t["e"] = 556;
 
-     t["f"] = 278;
 
-     t["g"] = 556;
 
-     t["h"] = 556;
 
-     t["i"] = 222;
 
-     t["j"] = 222;
 
-     t["k"] = 500;
 
-     t["l"] = 222;
 
-     t["m"] = 833;
 
-     t["n"] = 556;
 
-     t["o"] = 556;
 
-     t["p"] = 556;
 
-     t["q"] = 556;
 
-     t["r"] = 333;
 
-     t["s"] = 500;
 
-     t["t"] = 278;
 
-     t["u"] = 556;
 
-     t["v"] = 500;
 
-     t["w"] = 722;
 
-     t["x"] = 500;
 
-     t["y"] = 500;
 
-     t["z"] = 500;
 
-     t["braceleft"] = 334;
 
-     t["bar"] = 260;
 
-     t["braceright"] = 334;
 
-     t["asciitilde"] = 584;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 556;
 
-     t["sterling"] = 556;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 556;
 
-     t["florin"] = 556;
 
-     t["section"] = 556;
 
-     t["currency"] = 556;
 
-     t["quotesingle"] = 191;
 
-     t["quotedblleft"] = 333;
 
-     t["guillemotleft"] = 556;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 500;
 
-     t["fl"] = 500;
 
-     t["endash"] = 556;
 
-     t["dagger"] = 556;
 
-     t["daggerdbl"] = 556;
 
-     t["periodcentered"] = 278;
 
-     t["paragraph"] = 537;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 222;
 
-     t["quotedblbase"] = 333;
 
-     t["quotedblright"] = 333;
 
-     t["guillemotright"] = 556;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 611;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 1000;
 
-     t["ordfeminine"] = 370;
 
-     t["Lslash"] = 556;
 
-     t["Oslash"] = 778;
 
-     t["OE"] = 1000;
 
-     t["ordmasculine"] = 365;
 
-     t["ae"] = 889;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 222;
 
-     t["oslash"] = 611;
 
-     t["oe"] = 944;
 
-     t["germandbls"] = 611;
 
-     t["Idieresis"] = 278;
 
-     t["eacute"] = 556;
 
-     t["abreve"] = 556;
 
-     t["uhungarumlaut"] = 556;
 
-     t["ecaron"] = 556;
 
-     t["Ydieresis"] = 667;
 
-     t["divide"] = 584;
 
-     t["Yacute"] = 667;
 
-     t["Acircumflex"] = 667;
 
-     t["aacute"] = 556;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 500;
 
-     t["scommaaccent"] = 500;
 
-     t["ecircumflex"] = 556;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 556;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 556;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 737;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 500;
 
-     t["aring"] = 556;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 222;
 
-     t["agrave"] = 556;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 722;
 
-     t["atilde"] = 556;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 500;
 
-     t["scedilla"] = 500;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 471;
 
-     t["Rcaron"] = 722;
 
-     t["Gcommaaccent"] = 778;
 
-     t["ucircumflex"] = 556;
 
-     t["acircumflex"] = 556;
 
-     t["Amacron"] = 667;
 
-     t["rcaron"] = 333;
 
-     t["ccedilla"] = 500;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 667;
 
-     t["Omacron"] = 778;
 
-     t["Racute"] = 722;
 
-     t["Sacute"] = 667;
 
-     t["dcaron"] = 643;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 556;
 
-     t["threesuperior"] = 333;
 
-     t["Ograve"] = 778;
 
-     t["Agrave"] = 667;
 
-     t["Abreve"] = 667;
 
-     t["multiply"] = 584;
 
-     t["uacute"] = 556;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 476;
 
-     t["ydieresis"] = 500;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 556;
 
-     t["edieresis"] = 556;
 
-     t["cacute"] = 500;
 
-     t["nacute"] = 556;
 
-     t["umacron"] = 556;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 278;
 
-     t["plusminus"] = 584;
 
-     t["brokenbar"] = 260;
 
-     t["registered"] = 737;
 
-     t["Gbreve"] = 778;
 
-     t["Idotaccent"] = 278;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 333;
 
-     t["omacron"] = 556;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 722;
 
-     t["lcommaaccent"] = 222;
 
-     t["tcaron"] = 317;
 
-     t["eogonek"] = 556;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 667;
 
-     t["Adieresis"] = 667;
 
-     t["egrave"] = 556;
 
-     t["zacute"] = 500;
 
-     t["iogonek"] = 222;
 
-     t["Oacute"] = 778;
 
-     t["oacute"] = 556;
 
-     t["amacron"] = 556;
 
-     t["sacute"] = 500;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 778;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 556;
 
-     t["twosuperior"] = 333;
 
-     t["Odieresis"] = 778;
 
-     t["mu"] = 556;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 556;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 556;
 
-     t["threequarters"] = 834;
 
-     t["Scedilla"] = 667;
 
-     t["lcaron"] = 299;
 
-     t["Kcommaaccent"] = 667;
 
-     t["Lacute"] = 556;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 556;
 
-     t["Igrave"] = 278;
 
-     t["Imacron"] = 278;
 
-     t["Lcaron"] = 556;
 
-     t["onehalf"] = 834;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 556;
 
-     t["ntilde"] = 556;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 556;
 
-     t["gbreve"] = 556;
 
-     t["onequarter"] = 834;
 
-     t["Scaron"] = 667;
 
-     t["Scommaaccent"] = 667;
 
-     t["Ohungarumlaut"] = 778;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 556;
 
-     t["Ccaron"] = 722;
 
-     t["ugrave"] = 556;
 
-     t["radical"] = 453;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 333;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 556;
 
-     t["Rcommaaccent"] = 722;
 
-     t["Lcommaaccent"] = 556;
 
-     t["Atilde"] = 667;
 
-     t["Aogonek"] = 667;
 
-     t["Aring"] = 667;
 
-     t["Otilde"] = 778;
 
-     t["zdotaccent"] = 500;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 278;
 
-     t["kcommaaccent"] = 500;
 
-     t["minus"] = 584;
 
-     t["Icircumflex"] = 278;
 
-     t["ncaron"] = 556;
 
-     t["tcommaaccent"] = 278;
 
-     t["logicalnot"] = 584;
 
-     t["odieresis"] = 556;
 
-     t["udieresis"] = 556;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 556;
 
-     t["eth"] = 556;
 
-     t["zcaron"] = 500;
 
-     t["ncommaaccent"] = 556;
 
-     t["onesuperior"] = 333;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 556;
 
-   });
 
-   t["Symbol"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 250;
 
-     t["exclam"] = 333;
 
-     t["universal"] = 713;
 
-     t["numbersign"] = 500;
 
-     t["existential"] = 549;
 
-     t["percent"] = 833;
 
-     t["ampersand"] = 778;
 
-     t["suchthat"] = 439;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asteriskmath"] = 500;
 
-     t["plus"] = 549;
 
-     t["comma"] = 250;
 
-     t["minus"] = 549;
 
-     t["period"] = 250;
 
-     t["slash"] = 278;
 
-     t["zero"] = 500;
 
-     t["one"] = 500;
 
-     t["two"] = 500;
 
-     t["three"] = 500;
 
-     t["four"] = 500;
 
-     t["five"] = 500;
 
-     t["six"] = 500;
 
-     t["seven"] = 500;
 
-     t["eight"] = 500;
 
-     t["nine"] = 500;
 
-     t["colon"] = 278;
 
-     t["semicolon"] = 278;
 
-     t["less"] = 549;
 
-     t["equal"] = 549;
 
-     t["greater"] = 549;
 
-     t["question"] = 444;
 
-     t["congruent"] = 549;
 
-     t["Alpha"] = 722;
 
-     t["Beta"] = 667;
 
-     t["Chi"] = 722;
 
-     t["Delta"] = 612;
 
-     t["Epsilon"] = 611;
 
-     t["Phi"] = 763;
 
-     t["Gamma"] = 603;
 
-     t["Eta"] = 722;
 
-     t["Iota"] = 333;
 
-     t["theta1"] = 631;
 
-     t["Kappa"] = 722;
 
-     t["Lambda"] = 686;
 
-     t["Mu"] = 889;
 
-     t["Nu"] = 722;
 
-     t["Omicron"] = 722;
 
-     t["Pi"] = 768;
 
-     t["Theta"] = 741;
 
-     t["Rho"] = 556;
 
-     t["Sigma"] = 592;
 
-     t["Tau"] = 611;
 
-     t["Upsilon"] = 690;
 
-     t["sigma1"] = 439;
 
-     t["Omega"] = 768;
 
-     t["Xi"] = 645;
 
-     t["Psi"] = 795;
 
-     t["Zeta"] = 611;
 
-     t["bracketleft"] = 333;
 
-     t["therefore"] = 863;
 
-     t["bracketright"] = 333;
 
-     t["perpendicular"] = 658;
 
-     t["underscore"] = 500;
 
-     t["radicalex"] = 500;
 
-     t["alpha"] = 631;
 
-     t["beta"] = 549;
 
-     t["chi"] = 549;
 
-     t["delta"] = 494;
 
-     t["epsilon"] = 439;
 
-     t["phi"] = 521;
 
-     t["gamma"] = 411;
 
-     t["eta"] = 603;
 
-     t["iota"] = 329;
 
-     t["phi1"] = 603;
 
-     t["kappa"] = 549;
 
-     t["lambda"] = 549;
 
-     t["mu"] = 576;
 
-     t["nu"] = 521;
 
-     t["omicron"] = 549;
 
-     t["pi"] = 549;
 
-     t["theta"] = 521;
 
-     t["rho"] = 549;
 
-     t["sigma"] = 603;
 
-     t["tau"] = 439;
 
-     t["upsilon"] = 576;
 
-     t["omega1"] = 713;
 
-     t["omega"] = 686;
 
-     t["xi"] = 493;
 
-     t["psi"] = 686;
 
-     t["zeta"] = 494;
 
-     t["braceleft"] = 480;
 
-     t["bar"] = 200;
 
-     t["braceright"] = 480;
 
-     t["similar"] = 549;
 
-     t["Euro"] = 750;
 
-     t["Upsilon1"] = 620;
 
-     t["minute"] = 247;
 
-     t["lessequal"] = 549;
 
-     t["fraction"] = 167;
 
-     t["infinity"] = 713;
 
-     t["florin"] = 500;
 
-     t["club"] = 753;
 
-     t["diamond"] = 753;
 
-     t["heart"] = 753;
 
-     t["spade"] = 753;
 
-     t["arrowboth"] = 1042;
 
-     t["arrowleft"] = 987;
 
-     t["arrowup"] = 603;
 
-     t["arrowright"] = 987;
 
-     t["arrowdown"] = 603;
 
-     t["degree"] = 400;
 
-     t["plusminus"] = 549;
 
-     t["second"] = 411;
 
-     t["greaterequal"] = 549;
 
-     t["multiply"] = 549;
 
-     t["proportional"] = 713;
 
-     t["partialdiff"] = 494;
 
-     t["bullet"] = 460;
 
-     t["divide"] = 549;
 
-     t["notequal"] = 549;
 
-     t["equivalence"] = 549;
 
-     t["approxequal"] = 549;
 
-     t["ellipsis"] = 1000;
 
-     t["arrowvertex"] = 603;
 
-     t["arrowhorizex"] = 1000;
 
-     t["carriagereturn"] = 658;
 
-     t["aleph"] = 823;
 
-     t["Ifraktur"] = 686;
 
-     t["Rfraktur"] = 795;
 
-     t["weierstrass"] = 987;
 
-     t["circlemultiply"] = 768;
 
-     t["circleplus"] = 768;
 
-     t["emptyset"] = 823;
 
-     t["intersection"] = 768;
 
-     t["union"] = 768;
 
-     t["propersuperset"] = 713;
 
-     t["reflexsuperset"] = 713;
 
-     t["notsubset"] = 713;
 
-     t["propersubset"] = 713;
 
-     t["reflexsubset"] = 713;
 
-     t["element"] = 713;
 
-     t["notelement"] = 713;
 
-     t["angle"] = 768;
 
-     t["gradient"] = 713;
 
-     t["registerserif"] = 790;
 
-     t["copyrightserif"] = 790;
 
-     t["trademarkserif"] = 890;
 
-     t["product"] = 823;
 
-     t["radical"] = 549;
 
-     t["dotmath"] = 250;
 
-     t["logicalnot"] = 713;
 
-     t["logicaland"] = 603;
 
-     t["logicalor"] = 603;
 
-     t["arrowdblboth"] = 1042;
 
-     t["arrowdblleft"] = 987;
 
-     t["arrowdblup"] = 603;
 
-     t["arrowdblright"] = 987;
 
-     t["arrowdbldown"] = 603;
 
-     t["lozenge"] = 494;
 
-     t["angleleft"] = 329;
 
-     t["registersans"] = 790;
 
-     t["copyrightsans"] = 790;
 
-     t["trademarksans"] = 786;
 
-     t["summation"] = 713;
 
-     t["parenlefttp"] = 384;
 
-     t["parenleftex"] = 384;
 
-     t["parenleftbt"] = 384;
 
-     t["bracketlefttp"] = 384;
 
-     t["bracketleftex"] = 384;
 
-     t["bracketleftbt"] = 384;
 
-     t["bracelefttp"] = 494;
 
-     t["braceleftmid"] = 494;
 
-     t["braceleftbt"] = 494;
 
-     t["braceex"] = 494;
 
-     t["angleright"] = 329;
 
-     t["integral"] = 274;
 
-     t["integraltp"] = 686;
 
-     t["integralex"] = 686;
 
-     t["integralbt"] = 686;
 
-     t["parenrighttp"] = 384;
 
-     t["parenrightex"] = 384;
 
-     t["parenrightbt"] = 384;
 
-     t["bracketrighttp"] = 384;
 
-     t["bracketrightex"] = 384;
 
-     t["bracketrightbt"] = 384;
 
-     t["bracerighttp"] = 494;
 
-     t["bracerightmid"] = 494;
 
-     t["bracerightbt"] = 494;
 
-     t["apple"] = 790;
 
-   });
 
-   t["Times-Roman"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 250;
 
-     t["exclam"] = 333;
 
-     t["quotedbl"] = 408;
 
-     t["numbersign"] = 500;
 
-     t["dollar"] = 500;
 
-     t["percent"] = 833;
 
-     t["ampersand"] = 778;
 
-     t["quoteright"] = 333;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 500;
 
-     t["plus"] = 564;
 
-     t["comma"] = 250;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 250;
 
-     t["slash"] = 278;
 
-     t["zero"] = 500;
 
-     t["one"] = 500;
 
-     t["two"] = 500;
 
-     t["three"] = 500;
 
-     t["four"] = 500;
 
-     t["five"] = 500;
 
-     t["six"] = 500;
 
-     t["seven"] = 500;
 
-     t["eight"] = 500;
 
-     t["nine"] = 500;
 
-     t["colon"] = 278;
 
-     t["semicolon"] = 278;
 
-     t["less"] = 564;
 
-     t["equal"] = 564;
 
-     t["greater"] = 564;
 
-     t["question"] = 444;
 
-     t["at"] = 921;
 
-     t["A"] = 722;
 
-     t["B"] = 667;
 
-     t["C"] = 667;
 
-     t["D"] = 722;
 
-     t["E"] = 611;
 
-     t["F"] = 556;
 
-     t["G"] = 722;
 
-     t["H"] = 722;
 
-     t["I"] = 333;
 
-     t["J"] = 389;
 
-     t["K"] = 722;
 
-     t["L"] = 611;
 
-     t["M"] = 889;
 
-     t["N"] = 722;
 
-     t["O"] = 722;
 
-     t["P"] = 556;
 
-     t["Q"] = 722;
 
-     t["R"] = 667;
 
-     t["S"] = 556;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 722;
 
-     t["W"] = 944;
 
-     t["X"] = 722;
 
-     t["Y"] = 722;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 333;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 333;
 
-     t["asciicircum"] = 469;
 
-     t["underscore"] = 500;
 
-     t["quoteleft"] = 333;
 
-     t["a"] = 444;
 
-     t["b"] = 500;
 
-     t["c"] = 444;
 
-     t["d"] = 500;
 
-     t["e"] = 444;
 
-     t["f"] = 333;
 
-     t["g"] = 500;
 
-     t["h"] = 500;
 
-     t["i"] = 278;
 
-     t["j"] = 278;
 
-     t["k"] = 500;
 
-     t["l"] = 278;
 
-     t["m"] = 778;
 
-     t["n"] = 500;
 
-     t["o"] = 500;
 
-     t["p"] = 500;
 
-     t["q"] = 500;
 
-     t["r"] = 333;
 
-     t["s"] = 389;
 
-     t["t"] = 278;
 
-     t["u"] = 500;
 
-     t["v"] = 500;
 
-     t["w"] = 722;
 
-     t["x"] = 500;
 
-     t["y"] = 500;
 
-     t["z"] = 444;
 
-     t["braceleft"] = 480;
 
-     t["bar"] = 200;
 
-     t["braceright"] = 480;
 
-     t["asciitilde"] = 541;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 500;
 
-     t["sterling"] = 500;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 500;
 
-     t["florin"] = 500;
 
-     t["section"] = 500;
 
-     t["currency"] = 500;
 
-     t["quotesingle"] = 180;
 
-     t["quotedblleft"] = 444;
 
-     t["guillemotleft"] = 500;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 556;
 
-     t["fl"] = 556;
 
-     t["endash"] = 500;
 
-     t["dagger"] = 500;
 
-     t["daggerdbl"] = 500;
 
-     t["periodcentered"] = 250;
 
-     t["paragraph"] = 453;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 333;
 
-     t["quotedblbase"] = 444;
 
-     t["quotedblright"] = 444;
 
-     t["guillemotright"] = 500;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 444;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 889;
 
-     t["ordfeminine"] = 276;
 
-     t["Lslash"] = 611;
 
-     t["Oslash"] = 722;
 
-     t["OE"] = 889;
 
-     t["ordmasculine"] = 310;
 
-     t["ae"] = 667;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 500;
 
-     t["oe"] = 722;
 
-     t["germandbls"] = 500;
 
-     t["Idieresis"] = 333;
 
-     t["eacute"] = 444;
 
-     t["abreve"] = 444;
 
-     t["uhungarumlaut"] = 500;
 
-     t["ecaron"] = 444;
 
-     t["Ydieresis"] = 722;
 
-     t["divide"] = 564;
 
-     t["Yacute"] = 722;
 
-     t["Acircumflex"] = 722;
 
-     t["aacute"] = 444;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 500;
 
-     t["scommaaccent"] = 389;
 
-     t["ecircumflex"] = 444;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 444;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 500;
 
-     t["Edieresis"] = 611;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 760;
 
-     t["Emacron"] = 611;
 
-     t["ccaron"] = 444;
 
-     t["aring"] = 444;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 444;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 667;
 
-     t["atilde"] = 444;
 
-     t["Edotaccent"] = 611;
 
-     t["scaron"] = 389;
 
-     t["scedilla"] = 389;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 471;
 
-     t["Rcaron"] = 667;
 
-     t["Gcommaaccent"] = 722;
 
-     t["ucircumflex"] = 500;
 
-     t["acircumflex"] = 444;
 
-     t["Amacron"] = 722;
 
-     t["rcaron"] = 333;
 
-     t["ccedilla"] = 444;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 556;
 
-     t["Omacron"] = 722;
 
-     t["Racute"] = 667;
 
-     t["Sacute"] = 556;
 
-     t["dcaron"] = 588;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 500;
 
-     t["threesuperior"] = 300;
 
-     t["Ograve"] = 722;
 
-     t["Agrave"] = 722;
 
-     t["Abreve"] = 722;
 
-     t["multiply"] = 564;
 
-     t["uacute"] = 500;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 476;
 
-     t["ydieresis"] = 500;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 611;
 
-     t["adieresis"] = 444;
 
-     t["edieresis"] = 444;
 
-     t["cacute"] = 444;
 
-     t["nacute"] = 500;
 
-     t["umacron"] = 500;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 333;
 
-     t["plusminus"] = 564;
 
-     t["brokenbar"] = 200;
 
-     t["registered"] = 760;
 
-     t["Gbreve"] = 722;
 
-     t["Idotaccent"] = 333;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 611;
 
-     t["racute"] = 333;
 
-     t["omacron"] = 500;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 667;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 326;
 
-     t["eogonek"] = 444;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 722;
 
-     t["Adieresis"] = 722;
 
-     t["egrave"] = 444;
 
-     t["zacute"] = 444;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 722;
 
-     t["oacute"] = 500;
 
-     t["amacron"] = 444;
 
-     t["sacute"] = 389;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 722;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 500;
 
-     t["twosuperior"] = 300;
 
-     t["Odieresis"] = 722;
 
-     t["mu"] = 500;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 500;
 
-     t["Eogonek"] = 611;
 
-     t["dcroat"] = 500;
 
-     t["threequarters"] = 750;
 
-     t["Scedilla"] = 556;
 
-     t["lcaron"] = 344;
 
-     t["Kcommaaccent"] = 722;
 
-     t["Lacute"] = 611;
 
-     t["trademark"] = 980;
 
-     t["edotaccent"] = 444;
 
-     t["Igrave"] = 333;
 
-     t["Imacron"] = 333;
 
-     t["Lcaron"] = 611;
 
-     t["onehalf"] = 750;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 500;
 
-     t["ntilde"] = 500;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 611;
 
-     t["emacron"] = 444;
 
-     t["gbreve"] = 500;
 
-     t["onequarter"] = 750;
 
-     t["Scaron"] = 556;
 
-     t["Scommaaccent"] = 556;
 
-     t["Ohungarumlaut"] = 722;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 500;
 
-     t["Ccaron"] = 667;
 
-     t["ugrave"] = 500;
 
-     t["radical"] = 453;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 333;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 500;
 
-     t["Rcommaaccent"] = 667;
 
-     t["Lcommaaccent"] = 611;
 
-     t["Atilde"] = 722;
 
-     t["Aogonek"] = 722;
 
-     t["Aring"] = 722;
 
-     t["Otilde"] = 722;
 
-     t["zdotaccent"] = 444;
 
-     t["Ecaron"] = 611;
 
-     t["Iogonek"] = 333;
 
-     t["kcommaaccent"] = 500;
 
-     t["minus"] = 564;
 
-     t["Icircumflex"] = 333;
 
-     t["ncaron"] = 500;
 
-     t["tcommaaccent"] = 278;
 
-     t["logicalnot"] = 564;
 
-     t["odieresis"] = 500;
 
-     t["udieresis"] = 500;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 500;
 
-     t["eth"] = 500;
 
-     t["zcaron"] = 444;
 
-     t["ncommaaccent"] = 500;
 
-     t["onesuperior"] = 300;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 500;
 
-   });
 
-   t["Times-Bold"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 250;
 
-     t["exclam"] = 333;
 
-     t["quotedbl"] = 555;
 
-     t["numbersign"] = 500;
 
-     t["dollar"] = 500;
 
-     t["percent"] = 1000;
 
-     t["ampersand"] = 833;
 
-     t["quoteright"] = 333;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 500;
 
-     t["plus"] = 570;
 
-     t["comma"] = 250;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 250;
 
-     t["slash"] = 278;
 
-     t["zero"] = 500;
 
-     t["one"] = 500;
 
-     t["two"] = 500;
 
-     t["three"] = 500;
 
-     t["four"] = 500;
 
-     t["five"] = 500;
 
-     t["six"] = 500;
 
-     t["seven"] = 500;
 
-     t["eight"] = 500;
 
-     t["nine"] = 500;
 
-     t["colon"] = 333;
 
-     t["semicolon"] = 333;
 
-     t["less"] = 570;
 
-     t["equal"] = 570;
 
-     t["greater"] = 570;
 
-     t["question"] = 500;
 
-     t["at"] = 930;
 
-     t["A"] = 722;
 
-     t["B"] = 667;
 
-     t["C"] = 722;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 611;
 
-     t["G"] = 778;
 
-     t["H"] = 778;
 
-     t["I"] = 389;
 
-     t["J"] = 500;
 
-     t["K"] = 778;
 
-     t["L"] = 667;
 
-     t["M"] = 944;
 
-     t["N"] = 722;
 
-     t["O"] = 778;
 
-     t["P"] = 611;
 
-     t["Q"] = 778;
 
-     t["R"] = 722;
 
-     t["S"] = 556;
 
-     t["T"] = 667;
 
-     t["U"] = 722;
 
-     t["V"] = 722;
 
-     t["W"] = 1000;
 
-     t["X"] = 722;
 
-     t["Y"] = 722;
 
-     t["Z"] = 667;
 
-     t["bracketleft"] = 333;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 333;
 
-     t["asciicircum"] = 581;
 
-     t["underscore"] = 500;
 
-     t["quoteleft"] = 333;
 
-     t["a"] = 500;
 
-     t["b"] = 556;
 
-     t["c"] = 444;
 
-     t["d"] = 556;
 
-     t["e"] = 444;
 
-     t["f"] = 333;
 
-     t["g"] = 500;
 
-     t["h"] = 556;
 
-     t["i"] = 278;
 
-     t["j"] = 333;
 
-     t["k"] = 556;
 
-     t["l"] = 278;
 
-     t["m"] = 833;
 
-     t["n"] = 556;
 
-     t["o"] = 500;
 
-     t["p"] = 556;
 
-     t["q"] = 556;
 
-     t["r"] = 444;
 
-     t["s"] = 389;
 
-     t["t"] = 333;
 
-     t["u"] = 556;
 
-     t["v"] = 500;
 
-     t["w"] = 722;
 
-     t["x"] = 500;
 
-     t["y"] = 500;
 
-     t["z"] = 444;
 
-     t["braceleft"] = 394;
 
-     t["bar"] = 220;
 
-     t["braceright"] = 394;
 
-     t["asciitilde"] = 520;
 
-     t["exclamdown"] = 333;
 
-     t["cent"] = 500;
 
-     t["sterling"] = 500;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 500;
 
-     t["florin"] = 500;
 
-     t["section"] = 500;
 
-     t["currency"] = 500;
 
-     t["quotesingle"] = 278;
 
-     t["quotedblleft"] = 500;
 
-     t["guillemotleft"] = 500;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 556;
 
-     t["fl"] = 556;
 
-     t["endash"] = 500;
 
-     t["dagger"] = 500;
 
-     t["daggerdbl"] = 500;
 
-     t["periodcentered"] = 250;
 
-     t["paragraph"] = 540;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 333;
 
-     t["quotedblbase"] = 500;
 
-     t["quotedblright"] = 500;
 
-     t["guillemotright"] = 500;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 500;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 1000;
 
-     t["ordfeminine"] = 300;
 
-     t["Lslash"] = 667;
 
-     t["Oslash"] = 778;
 
-     t["OE"] = 1000;
 
-     t["ordmasculine"] = 330;
 
-     t["ae"] = 722;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 500;
 
-     t["oe"] = 722;
 
-     t["germandbls"] = 556;
 
-     t["Idieresis"] = 389;
 
-     t["eacute"] = 444;
 
-     t["abreve"] = 500;
 
-     t["uhungarumlaut"] = 556;
 
-     t["ecaron"] = 444;
 
-     t["Ydieresis"] = 722;
 
-     t["divide"] = 570;
 
-     t["Yacute"] = 722;
 
-     t["Acircumflex"] = 722;
 
-     t["aacute"] = 500;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 500;
 
-     t["scommaaccent"] = 389;
 
-     t["ecircumflex"] = 444;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 500;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 556;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 747;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 444;
 
-     t["aring"] = 500;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 500;
 
-     t["Tcommaaccent"] = 667;
 
-     t["Cacute"] = 722;
 
-     t["atilde"] = 500;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 389;
 
-     t["scedilla"] = 389;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 494;
 
-     t["Rcaron"] = 722;
 
-     t["Gcommaaccent"] = 778;
 
-     t["ucircumflex"] = 556;
 
-     t["acircumflex"] = 500;
 
-     t["Amacron"] = 722;
 
-     t["rcaron"] = 444;
 
-     t["ccedilla"] = 444;
 
-     t["Zdotaccent"] = 667;
 
-     t["Thorn"] = 611;
 
-     t["Omacron"] = 778;
 
-     t["Racute"] = 722;
 
-     t["Sacute"] = 556;
 
-     t["dcaron"] = 672;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 556;
 
-     t["threesuperior"] = 300;
 
-     t["Ograve"] = 778;
 
-     t["Agrave"] = 722;
 
-     t["Abreve"] = 722;
 
-     t["multiply"] = 570;
 
-     t["uacute"] = 556;
 
-     t["Tcaron"] = 667;
 
-     t["partialdiff"] = 494;
 
-     t["ydieresis"] = 500;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 500;
 
-     t["edieresis"] = 444;
 
-     t["cacute"] = 444;
 
-     t["nacute"] = 556;
 
-     t["umacron"] = 556;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 389;
 
-     t["plusminus"] = 570;
 
-     t["brokenbar"] = 220;
 
-     t["registered"] = 747;
 
-     t["Gbreve"] = 778;
 
-     t["Idotaccent"] = 389;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 444;
 
-     t["omacron"] = 500;
 
-     t["Zacute"] = 667;
 
-     t["Zcaron"] = 667;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 722;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 416;
 
-     t["eogonek"] = 444;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 722;
 
-     t["Adieresis"] = 722;
 
-     t["egrave"] = 444;
 
-     t["zacute"] = 444;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 778;
 
-     t["oacute"] = 500;
 
-     t["amacron"] = 500;
 
-     t["sacute"] = 389;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 778;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 556;
 
-     t["twosuperior"] = 300;
 
-     t["Odieresis"] = 778;
 
-     t["mu"] = 556;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 500;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 556;
 
-     t["threequarters"] = 750;
 
-     t["Scedilla"] = 556;
 
-     t["lcaron"] = 394;
 
-     t["Kcommaaccent"] = 778;
 
-     t["Lacute"] = 667;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 444;
 
-     t["Igrave"] = 389;
 
-     t["Imacron"] = 389;
 
-     t["Lcaron"] = 667;
 
-     t["onehalf"] = 750;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 500;
 
-     t["ntilde"] = 556;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 444;
 
-     t["gbreve"] = 500;
 
-     t["onequarter"] = 750;
 
-     t["Scaron"] = 556;
 
-     t["Scommaaccent"] = 556;
 
-     t["Ohungarumlaut"] = 778;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 500;
 
-     t["Ccaron"] = 722;
 
-     t["ugrave"] = 556;
 
-     t["radical"] = 549;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 444;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 500;
 
-     t["Rcommaaccent"] = 722;
 
-     t["Lcommaaccent"] = 667;
 
-     t["Atilde"] = 722;
 
-     t["Aogonek"] = 722;
 
-     t["Aring"] = 722;
 
-     t["Otilde"] = 778;
 
-     t["zdotaccent"] = 444;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 389;
 
-     t["kcommaaccent"] = 556;
 
-     t["minus"] = 570;
 
-     t["Icircumflex"] = 389;
 
-     t["ncaron"] = 556;
 
-     t["tcommaaccent"] = 333;
 
-     t["logicalnot"] = 570;
 
-     t["odieresis"] = 500;
 
-     t["udieresis"] = 556;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 500;
 
-     t["eth"] = 500;
 
-     t["zcaron"] = 444;
 
-     t["ncommaaccent"] = 556;
 
-     t["onesuperior"] = 300;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 500;
 
-   });
 
-   t["Times-BoldItalic"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 250;
 
-     t["exclam"] = 389;
 
-     t["quotedbl"] = 555;
 
-     t["numbersign"] = 500;
 
-     t["dollar"] = 500;
 
-     t["percent"] = 833;
 
-     t["ampersand"] = 778;
 
-     t["quoteright"] = 333;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 500;
 
-     t["plus"] = 570;
 
-     t["comma"] = 250;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 250;
 
-     t["slash"] = 278;
 
-     t["zero"] = 500;
 
-     t["one"] = 500;
 
-     t["two"] = 500;
 
-     t["three"] = 500;
 
-     t["four"] = 500;
 
-     t["five"] = 500;
 
-     t["six"] = 500;
 
-     t["seven"] = 500;
 
-     t["eight"] = 500;
 
-     t["nine"] = 500;
 
-     t["colon"] = 333;
 
-     t["semicolon"] = 333;
 
-     t["less"] = 570;
 
-     t["equal"] = 570;
 
-     t["greater"] = 570;
 
-     t["question"] = 500;
 
-     t["at"] = 832;
 
-     t["A"] = 667;
 
-     t["B"] = 667;
 
-     t["C"] = 667;
 
-     t["D"] = 722;
 
-     t["E"] = 667;
 
-     t["F"] = 667;
 
-     t["G"] = 722;
 
-     t["H"] = 778;
 
-     t["I"] = 389;
 
-     t["J"] = 500;
 
-     t["K"] = 667;
 
-     t["L"] = 611;
 
-     t["M"] = 889;
 
-     t["N"] = 722;
 
-     t["O"] = 722;
 
-     t["P"] = 611;
 
-     t["Q"] = 722;
 
-     t["R"] = 667;
 
-     t["S"] = 556;
 
-     t["T"] = 611;
 
-     t["U"] = 722;
 
-     t["V"] = 667;
 
-     t["W"] = 889;
 
-     t["X"] = 667;
 
-     t["Y"] = 611;
 
-     t["Z"] = 611;
 
-     t["bracketleft"] = 333;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 333;
 
-     t["asciicircum"] = 570;
 
-     t["underscore"] = 500;
 
-     t["quoteleft"] = 333;
 
-     t["a"] = 500;
 
-     t["b"] = 500;
 
-     t["c"] = 444;
 
-     t["d"] = 500;
 
-     t["e"] = 444;
 
-     t["f"] = 333;
 
-     t["g"] = 500;
 
-     t["h"] = 556;
 
-     t["i"] = 278;
 
-     t["j"] = 278;
 
-     t["k"] = 500;
 
-     t["l"] = 278;
 
-     t["m"] = 778;
 
-     t["n"] = 556;
 
-     t["o"] = 500;
 
-     t["p"] = 500;
 
-     t["q"] = 500;
 
-     t["r"] = 389;
 
-     t["s"] = 389;
 
-     t["t"] = 278;
 
-     t["u"] = 556;
 
-     t["v"] = 444;
 
-     t["w"] = 667;
 
-     t["x"] = 500;
 
-     t["y"] = 444;
 
-     t["z"] = 389;
 
-     t["braceleft"] = 348;
 
-     t["bar"] = 220;
 
-     t["braceright"] = 348;
 
-     t["asciitilde"] = 570;
 
-     t["exclamdown"] = 389;
 
-     t["cent"] = 500;
 
-     t["sterling"] = 500;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 500;
 
-     t["florin"] = 500;
 
-     t["section"] = 500;
 
-     t["currency"] = 500;
 
-     t["quotesingle"] = 278;
 
-     t["quotedblleft"] = 500;
 
-     t["guillemotleft"] = 500;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 556;
 
-     t["fl"] = 556;
 
-     t["endash"] = 500;
 
-     t["dagger"] = 500;
 
-     t["daggerdbl"] = 500;
 
-     t["periodcentered"] = 250;
 
-     t["paragraph"] = 500;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 333;
 
-     t["quotedblbase"] = 500;
 
-     t["quotedblright"] = 500;
 
-     t["guillemotright"] = 500;
 
-     t["ellipsis"] = 1000;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 500;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 1000;
 
-     t["AE"] = 944;
 
-     t["ordfeminine"] = 266;
 
-     t["Lslash"] = 611;
 
-     t["Oslash"] = 722;
 
-     t["OE"] = 944;
 
-     t["ordmasculine"] = 300;
 
-     t["ae"] = 722;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 500;
 
-     t["oe"] = 722;
 
-     t["germandbls"] = 500;
 
-     t["Idieresis"] = 389;
 
-     t["eacute"] = 444;
 
-     t["abreve"] = 500;
 
-     t["uhungarumlaut"] = 556;
 
-     t["ecaron"] = 444;
 
-     t["Ydieresis"] = 611;
 
-     t["divide"] = 570;
 
-     t["Yacute"] = 611;
 
-     t["Acircumflex"] = 667;
 
-     t["aacute"] = 500;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 444;
 
-     t["scommaaccent"] = 389;
 
-     t["ecircumflex"] = 444;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 500;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 556;
 
-     t["Edieresis"] = 667;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 747;
 
-     t["Emacron"] = 667;
 
-     t["ccaron"] = 444;
 
-     t["aring"] = 500;
 
-     t["Ncommaaccent"] = 722;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 500;
 
-     t["Tcommaaccent"] = 611;
 
-     t["Cacute"] = 667;
 
-     t["atilde"] = 500;
 
-     t["Edotaccent"] = 667;
 
-     t["scaron"] = 389;
 
-     t["scedilla"] = 389;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 494;
 
-     t["Rcaron"] = 667;
 
-     t["Gcommaaccent"] = 722;
 
-     t["ucircumflex"] = 556;
 
-     t["acircumflex"] = 500;
 
-     t["Amacron"] = 667;
 
-     t["rcaron"] = 389;
 
-     t["ccedilla"] = 444;
 
-     t["Zdotaccent"] = 611;
 
-     t["Thorn"] = 611;
 
-     t["Omacron"] = 722;
 
-     t["Racute"] = 667;
 
-     t["Sacute"] = 556;
 
-     t["dcaron"] = 608;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 556;
 
-     t["threesuperior"] = 300;
 
-     t["Ograve"] = 722;
 
-     t["Agrave"] = 667;
 
-     t["Abreve"] = 667;
 
-     t["multiply"] = 570;
 
-     t["uacute"] = 556;
 
-     t["Tcaron"] = 611;
 
-     t["partialdiff"] = 494;
 
-     t["ydieresis"] = 444;
 
-     t["Nacute"] = 722;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 667;
 
-     t["adieresis"] = 500;
 
-     t["edieresis"] = 444;
 
-     t["cacute"] = 444;
 
-     t["nacute"] = 556;
 
-     t["umacron"] = 556;
 
-     t["Ncaron"] = 722;
 
-     t["Iacute"] = 389;
 
-     t["plusminus"] = 570;
 
-     t["brokenbar"] = 220;
 
-     t["registered"] = 747;
 
-     t["Gbreve"] = 722;
 
-     t["Idotaccent"] = 389;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 667;
 
-     t["racute"] = 389;
 
-     t["omacron"] = 500;
 
-     t["Zacute"] = 611;
 
-     t["Zcaron"] = 611;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 667;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 366;
 
-     t["eogonek"] = 444;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 667;
 
-     t["Adieresis"] = 667;
 
-     t["egrave"] = 444;
 
-     t["zacute"] = 389;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 722;
 
-     t["oacute"] = 500;
 
-     t["amacron"] = 500;
 
-     t["sacute"] = 389;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 722;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 500;
 
-     t["twosuperior"] = 300;
 
-     t["Odieresis"] = 722;
 
-     t["mu"] = 576;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 500;
 
-     t["Eogonek"] = 667;
 
-     t["dcroat"] = 500;
 
-     t["threequarters"] = 750;
 
-     t["Scedilla"] = 556;
 
-     t["lcaron"] = 382;
 
-     t["Kcommaaccent"] = 667;
 
-     t["Lacute"] = 611;
 
-     t["trademark"] = 1000;
 
-     t["edotaccent"] = 444;
 
-     t["Igrave"] = 389;
 
-     t["Imacron"] = 389;
 
-     t["Lcaron"] = 611;
 
-     t["onehalf"] = 750;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 500;
 
-     t["ntilde"] = 556;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 667;
 
-     t["emacron"] = 444;
 
-     t["gbreve"] = 500;
 
-     t["onequarter"] = 750;
 
-     t["Scaron"] = 556;
 
-     t["Scommaaccent"] = 556;
 
-     t["Ohungarumlaut"] = 722;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 500;
 
-     t["Ccaron"] = 667;
 
-     t["ugrave"] = 556;
 
-     t["radical"] = 549;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 389;
 
-     t["Ntilde"] = 722;
 
-     t["otilde"] = 500;
 
-     t["Rcommaaccent"] = 667;
 
-     t["Lcommaaccent"] = 611;
 
-     t["Atilde"] = 667;
 
-     t["Aogonek"] = 667;
 
-     t["Aring"] = 667;
 
-     t["Otilde"] = 722;
 
-     t["zdotaccent"] = 389;
 
-     t["Ecaron"] = 667;
 
-     t["Iogonek"] = 389;
 
-     t["kcommaaccent"] = 500;
 
-     t["minus"] = 606;
 
-     t["Icircumflex"] = 389;
 
-     t["ncaron"] = 556;
 
-     t["tcommaaccent"] = 278;
 
-     t["logicalnot"] = 606;
 
-     t["odieresis"] = 500;
 
-     t["udieresis"] = 556;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 500;
 
-     t["eth"] = 500;
 
-     t["zcaron"] = 389;
 
-     t["ncommaaccent"] = 556;
 
-     t["onesuperior"] = 300;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 500;
 
-   });
 
-   t["Times-Italic"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 250;
 
-     t["exclam"] = 333;
 
-     t["quotedbl"] = 420;
 
-     t["numbersign"] = 500;
 
-     t["dollar"] = 500;
 
-     t["percent"] = 833;
 
-     t["ampersand"] = 778;
 
-     t["quoteright"] = 333;
 
-     t["parenleft"] = 333;
 
-     t["parenright"] = 333;
 
-     t["asterisk"] = 500;
 
-     t["plus"] = 675;
 
-     t["comma"] = 250;
 
-     t["hyphen"] = 333;
 
-     t["period"] = 250;
 
-     t["slash"] = 278;
 
-     t["zero"] = 500;
 
-     t["one"] = 500;
 
-     t["two"] = 500;
 
-     t["three"] = 500;
 
-     t["four"] = 500;
 
-     t["five"] = 500;
 
-     t["six"] = 500;
 
-     t["seven"] = 500;
 
-     t["eight"] = 500;
 
-     t["nine"] = 500;
 
-     t["colon"] = 333;
 
-     t["semicolon"] = 333;
 
-     t["less"] = 675;
 
-     t["equal"] = 675;
 
-     t["greater"] = 675;
 
-     t["question"] = 500;
 
-     t["at"] = 920;
 
-     t["A"] = 611;
 
-     t["B"] = 611;
 
-     t["C"] = 667;
 
-     t["D"] = 722;
 
-     t["E"] = 611;
 
-     t["F"] = 611;
 
-     t["G"] = 722;
 
-     t["H"] = 722;
 
-     t["I"] = 333;
 
-     t["J"] = 444;
 
-     t["K"] = 667;
 
-     t["L"] = 556;
 
-     t["M"] = 833;
 
-     t["N"] = 667;
 
-     t["O"] = 722;
 
-     t["P"] = 611;
 
-     t["Q"] = 722;
 
-     t["R"] = 611;
 
-     t["S"] = 500;
 
-     t["T"] = 556;
 
-     t["U"] = 722;
 
-     t["V"] = 611;
 
-     t["W"] = 833;
 
-     t["X"] = 611;
 
-     t["Y"] = 556;
 
-     t["Z"] = 556;
 
-     t["bracketleft"] = 389;
 
-     t["backslash"] = 278;
 
-     t["bracketright"] = 389;
 
-     t["asciicircum"] = 422;
 
-     t["underscore"] = 500;
 
-     t["quoteleft"] = 333;
 
-     t["a"] = 500;
 
-     t["b"] = 500;
 
-     t["c"] = 444;
 
-     t["d"] = 500;
 
-     t["e"] = 444;
 
-     t["f"] = 278;
 
-     t["g"] = 500;
 
-     t["h"] = 500;
 
-     t["i"] = 278;
 
-     t["j"] = 278;
 
-     t["k"] = 444;
 
-     t["l"] = 278;
 
-     t["m"] = 722;
 
-     t["n"] = 500;
 
-     t["o"] = 500;
 
-     t["p"] = 500;
 
-     t["q"] = 500;
 
-     t["r"] = 389;
 
-     t["s"] = 389;
 
-     t["t"] = 278;
 
-     t["u"] = 500;
 
-     t["v"] = 444;
 
-     t["w"] = 667;
 
-     t["x"] = 444;
 
-     t["y"] = 444;
 
-     t["z"] = 389;
 
-     t["braceleft"] = 400;
 
-     t["bar"] = 275;
 
-     t["braceright"] = 400;
 
-     t["asciitilde"] = 541;
 
-     t["exclamdown"] = 389;
 
-     t["cent"] = 500;
 
-     t["sterling"] = 500;
 
-     t["fraction"] = 167;
 
-     t["yen"] = 500;
 
-     t["florin"] = 500;
 
-     t["section"] = 500;
 
-     t["currency"] = 500;
 
-     t["quotesingle"] = 214;
 
-     t["quotedblleft"] = 556;
 
-     t["guillemotleft"] = 500;
 
-     t["guilsinglleft"] = 333;
 
-     t["guilsinglright"] = 333;
 
-     t["fi"] = 500;
 
-     t["fl"] = 500;
 
-     t["endash"] = 500;
 
-     t["dagger"] = 500;
 
-     t["daggerdbl"] = 500;
 
-     t["periodcentered"] = 250;
 
-     t["paragraph"] = 523;
 
-     t["bullet"] = 350;
 
-     t["quotesinglbase"] = 333;
 
-     t["quotedblbase"] = 556;
 
-     t["quotedblright"] = 556;
 
-     t["guillemotright"] = 500;
 
-     t["ellipsis"] = 889;
 
-     t["perthousand"] = 1000;
 
-     t["questiondown"] = 500;
 
-     t["grave"] = 333;
 
-     t["acute"] = 333;
 
-     t["circumflex"] = 333;
 
-     t["tilde"] = 333;
 
-     t["macron"] = 333;
 
-     t["breve"] = 333;
 
-     t["dotaccent"] = 333;
 
-     t["dieresis"] = 333;
 
-     t["ring"] = 333;
 
-     t["cedilla"] = 333;
 
-     t["hungarumlaut"] = 333;
 
-     t["ogonek"] = 333;
 
-     t["caron"] = 333;
 
-     t["emdash"] = 889;
 
-     t["AE"] = 889;
 
-     t["ordfeminine"] = 276;
 
-     t["Lslash"] = 556;
 
-     t["Oslash"] = 722;
 
-     t["OE"] = 944;
 
-     t["ordmasculine"] = 310;
 
-     t["ae"] = 667;
 
-     t["dotlessi"] = 278;
 
-     t["lslash"] = 278;
 
-     t["oslash"] = 500;
 
-     t["oe"] = 667;
 
-     t["germandbls"] = 500;
 
-     t["Idieresis"] = 333;
 
-     t["eacute"] = 444;
 
-     t["abreve"] = 500;
 
-     t["uhungarumlaut"] = 500;
 
-     t["ecaron"] = 444;
 
-     t["Ydieresis"] = 556;
 
-     t["divide"] = 675;
 
-     t["Yacute"] = 556;
 
-     t["Acircumflex"] = 611;
 
-     t["aacute"] = 500;
 
-     t["Ucircumflex"] = 722;
 
-     t["yacute"] = 444;
 
-     t["scommaaccent"] = 389;
 
-     t["ecircumflex"] = 444;
 
-     t["Uring"] = 722;
 
-     t["Udieresis"] = 722;
 
-     t["aogonek"] = 500;
 
-     t["Uacute"] = 722;
 
-     t["uogonek"] = 500;
 
-     t["Edieresis"] = 611;
 
-     t["Dcroat"] = 722;
 
-     t["commaaccent"] = 250;
 
-     t["copyright"] = 760;
 
-     t["Emacron"] = 611;
 
-     t["ccaron"] = 444;
 
-     t["aring"] = 500;
 
-     t["Ncommaaccent"] = 667;
 
-     t["lacute"] = 278;
 
-     t["agrave"] = 500;
 
-     t["Tcommaaccent"] = 556;
 
-     t["Cacute"] = 667;
 
-     t["atilde"] = 500;
 
-     t["Edotaccent"] = 611;
 
-     t["scaron"] = 389;
 
-     t["scedilla"] = 389;
 
-     t["iacute"] = 278;
 
-     t["lozenge"] = 471;
 
-     t["Rcaron"] = 611;
 
-     t["Gcommaaccent"] = 722;
 
-     t["ucircumflex"] = 500;
 
-     t["acircumflex"] = 500;
 
-     t["Amacron"] = 611;
 
-     t["rcaron"] = 389;
 
-     t["ccedilla"] = 444;
 
-     t["Zdotaccent"] = 556;
 
-     t["Thorn"] = 611;
 
-     t["Omacron"] = 722;
 
-     t["Racute"] = 611;
 
-     t["Sacute"] = 500;
 
-     t["dcaron"] = 544;
 
-     t["Umacron"] = 722;
 
-     t["uring"] = 500;
 
-     t["threesuperior"] = 300;
 
-     t["Ograve"] = 722;
 
-     t["Agrave"] = 611;
 
-     t["Abreve"] = 611;
 
-     t["multiply"] = 675;
 
-     t["uacute"] = 500;
 
-     t["Tcaron"] = 556;
 
-     t["partialdiff"] = 476;
 
-     t["ydieresis"] = 444;
 
-     t["Nacute"] = 667;
 
-     t["icircumflex"] = 278;
 
-     t["Ecircumflex"] = 611;
 
-     t["adieresis"] = 500;
 
-     t["edieresis"] = 444;
 
-     t["cacute"] = 444;
 
-     t["nacute"] = 500;
 
-     t["umacron"] = 500;
 
-     t["Ncaron"] = 667;
 
-     t["Iacute"] = 333;
 
-     t["plusminus"] = 675;
 
-     t["brokenbar"] = 275;
 
-     t["registered"] = 760;
 
-     t["Gbreve"] = 722;
 
-     t["Idotaccent"] = 333;
 
-     t["summation"] = 600;
 
-     t["Egrave"] = 611;
 
-     t["racute"] = 389;
 
-     t["omacron"] = 500;
 
-     t["Zacute"] = 556;
 
-     t["Zcaron"] = 556;
 
-     t["greaterequal"] = 549;
 
-     t["Eth"] = 722;
 
-     t["Ccedilla"] = 667;
 
-     t["lcommaaccent"] = 278;
 
-     t["tcaron"] = 300;
 
-     t["eogonek"] = 444;
 
-     t["Uogonek"] = 722;
 
-     t["Aacute"] = 611;
 
-     t["Adieresis"] = 611;
 
-     t["egrave"] = 444;
 
-     t["zacute"] = 389;
 
-     t["iogonek"] = 278;
 
-     t["Oacute"] = 722;
 
-     t["oacute"] = 500;
 
-     t["amacron"] = 500;
 
-     t["sacute"] = 389;
 
-     t["idieresis"] = 278;
 
-     t["Ocircumflex"] = 722;
 
-     t["Ugrave"] = 722;
 
-     t["Delta"] = 612;
 
-     t["thorn"] = 500;
 
-     t["twosuperior"] = 300;
 
-     t["Odieresis"] = 722;
 
-     t["mu"] = 500;
 
-     t["igrave"] = 278;
 
-     t["ohungarumlaut"] = 500;
 
-     t["Eogonek"] = 611;
 
-     t["dcroat"] = 500;
 
-     t["threequarters"] = 750;
 
-     t["Scedilla"] = 500;
 
-     t["lcaron"] = 300;
 
-     t["Kcommaaccent"] = 667;
 
-     t["Lacute"] = 556;
 
-     t["trademark"] = 980;
 
-     t["edotaccent"] = 444;
 
-     t["Igrave"] = 333;
 
-     t["Imacron"] = 333;
 
-     t["Lcaron"] = 611;
 
-     t["onehalf"] = 750;
 
-     t["lessequal"] = 549;
 
-     t["ocircumflex"] = 500;
 
-     t["ntilde"] = 500;
 
-     t["Uhungarumlaut"] = 722;
 
-     t["Eacute"] = 611;
 
-     t["emacron"] = 444;
 
-     t["gbreve"] = 500;
 
-     t["onequarter"] = 750;
 
-     t["Scaron"] = 500;
 
-     t["Scommaaccent"] = 500;
 
-     t["Ohungarumlaut"] = 722;
 
-     t["degree"] = 400;
 
-     t["ograve"] = 500;
 
-     t["Ccaron"] = 667;
 
-     t["ugrave"] = 500;
 
-     t["radical"] = 453;
 
-     t["Dcaron"] = 722;
 
-     t["rcommaaccent"] = 389;
 
-     t["Ntilde"] = 667;
 
-     t["otilde"] = 500;
 
-     t["Rcommaaccent"] = 611;
 
-     t["Lcommaaccent"] = 556;
 
-     t["Atilde"] = 611;
 
-     t["Aogonek"] = 611;
 
-     t["Aring"] = 611;
 
-     t["Otilde"] = 722;
 
-     t["zdotaccent"] = 389;
 
-     t["Ecaron"] = 611;
 
-     t["Iogonek"] = 333;
 
-     t["kcommaaccent"] = 444;
 
-     t["minus"] = 675;
 
-     t["Icircumflex"] = 333;
 
-     t["ncaron"] = 500;
 
-     t["tcommaaccent"] = 278;
 
-     t["logicalnot"] = 675;
 
-     t["odieresis"] = 500;
 
-     t["udieresis"] = 500;
 
-     t["notequal"] = 549;
 
-     t["gcommaaccent"] = 500;
 
-     t["eth"] = 500;
 
-     t["zcaron"] = 389;
 
-     t["ncommaaccent"] = 500;
 
-     t["onesuperior"] = 300;
 
-     t["imacron"] = 278;
 
-     t["Euro"] = 500;
 
-   });
 
-   t["ZapfDingbats"] = (0, _core_utils.getLookupTableFactory)(function (t) {
 
-     t["space"] = 278;
 
-     t["a1"] = 974;
 
-     t["a2"] = 961;
 
-     t["a202"] = 974;
 
-     t["a3"] = 980;
 
-     t["a4"] = 719;
 
-     t["a5"] = 789;
 
-     t["a119"] = 790;
 
-     t["a118"] = 791;
 
-     t["a117"] = 690;
 
-     t["a11"] = 960;
 
-     t["a12"] = 939;
 
-     t["a13"] = 549;
 
-     t["a14"] = 855;
 
-     t["a15"] = 911;
 
-     t["a16"] = 933;
 
-     t["a105"] = 911;
 
-     t["a17"] = 945;
 
-     t["a18"] = 974;
 
-     t["a19"] = 755;
 
-     t["a20"] = 846;
 
-     t["a21"] = 762;
 
-     t["a22"] = 761;
 
-     t["a23"] = 571;
 
-     t["a24"] = 677;
 
-     t["a25"] = 763;
 
-     t["a26"] = 760;
 
-     t["a27"] = 759;
 
-     t["a28"] = 754;
 
-     t["a6"] = 494;
 
-     t["a7"] = 552;
 
-     t["a8"] = 537;
 
-     t["a9"] = 577;
 
-     t["a10"] = 692;
 
-     t["a29"] = 786;
 
-     t["a30"] = 788;
 
-     t["a31"] = 788;
 
-     t["a32"] = 790;
 
-     t["a33"] = 793;
 
-     t["a34"] = 794;
 
-     t["a35"] = 816;
 
-     t["a36"] = 823;
 
-     t["a37"] = 789;
 
-     t["a38"] = 841;
 
-     t["a39"] = 823;
 
-     t["a40"] = 833;
 
-     t["a41"] = 816;
 
-     t["a42"] = 831;
 
-     t["a43"] = 923;
 
-     t["a44"] = 744;
 
-     t["a45"] = 723;
 
-     t["a46"] = 749;
 
-     t["a47"] = 790;
 
-     t["a48"] = 792;
 
-     t["a49"] = 695;
 
-     t["a50"] = 776;
 
-     t["a51"] = 768;
 
-     t["a52"] = 792;
 
-     t["a53"] = 759;
 
-     t["a54"] = 707;
 
-     t["a55"] = 708;
 
-     t["a56"] = 682;
 
-     t["a57"] = 701;
 
-     t["a58"] = 826;
 
-     t["a59"] = 815;
 
-     t["a60"] = 789;
 
-     t["a61"] = 789;
 
-     t["a62"] = 707;
 
-     t["a63"] = 687;
 
-     t["a64"] = 696;
 
-     t["a65"] = 689;
 
-     t["a66"] = 786;
 
-     t["a67"] = 787;
 
-     t["a68"] = 713;
 
-     t["a69"] = 791;
 
-     t["a70"] = 785;
 
-     t["a71"] = 791;
 
-     t["a72"] = 873;
 
-     t["a73"] = 761;
 
-     t["a74"] = 762;
 
-     t["a203"] = 762;
 
-     t["a75"] = 759;
 
-     t["a204"] = 759;
 
-     t["a76"] = 892;
 
-     t["a77"] = 892;
 
-     t["a78"] = 788;
 
-     t["a79"] = 784;
 
-     t["a81"] = 438;
 
-     t["a82"] = 138;
 
-     t["a83"] = 277;
 
-     t["a84"] = 415;
 
-     t["a97"] = 392;
 
-     t["a98"] = 392;
 
-     t["a99"] = 668;
 
-     t["a100"] = 668;
 
-     t["a89"] = 390;
 
-     t["a90"] = 390;
 
-     t["a93"] = 317;
 
-     t["a94"] = 317;
 
-     t["a91"] = 276;
 
-     t["a92"] = 276;
 
-     t["a205"] = 509;
 
-     t["a85"] = 509;
 
-     t["a206"] = 410;
 
-     t["a86"] = 410;
 
-     t["a87"] = 234;
 
-     t["a88"] = 234;
 
-     t["a95"] = 334;
 
-     t["a96"] = 334;
 
-     t["a101"] = 732;
 
-     t["a102"] = 544;
 
-     t["a103"] = 544;
 
-     t["a104"] = 910;
 
-     t["a106"] = 667;
 
-     t["a107"] = 760;
 
-     t["a108"] = 760;
 
-     t["a112"] = 776;
 
-     t["a111"] = 595;
 
-     t["a110"] = 694;
 
-     t["a109"] = 626;
 
-     t["a120"] = 788;
 
-     t["a121"] = 788;
 
-     t["a122"] = 788;
 
-     t["a123"] = 788;
 
-     t["a124"] = 788;
 
-     t["a125"] = 788;
 
-     t["a126"] = 788;
 
-     t["a127"] = 788;
 
-     t["a128"] = 788;
 
-     t["a129"] = 788;
 
-     t["a130"] = 788;
 
-     t["a131"] = 788;
 
-     t["a132"] = 788;
 
-     t["a133"] = 788;
 
-     t["a134"] = 788;
 
-     t["a135"] = 788;
 
-     t["a136"] = 788;
 
-     t["a137"] = 788;
 
-     t["a138"] = 788;
 
-     t["a139"] = 788;
 
-     t["a140"] = 788;
 
-     t["a141"] = 788;
 
-     t["a142"] = 788;
 
-     t["a143"] = 788;
 
-     t["a144"] = 788;
 
-     t["a145"] = 788;
 
-     t["a146"] = 788;
 
-     t["a147"] = 788;
 
-     t["a148"] = 788;
 
-     t["a149"] = 788;
 
-     t["a150"] = 788;
 
-     t["a151"] = 788;
 
-     t["a152"] = 788;
 
-     t["a153"] = 788;
 
-     t["a154"] = 788;
 
-     t["a155"] = 788;
 
-     t["a156"] = 788;
 
-     t["a157"] = 788;
 
-     t["a158"] = 788;
 
-     t["a159"] = 788;
 
-     t["a160"] = 894;
 
-     t["a161"] = 838;
 
-     t["a163"] = 1016;
 
-     t["a164"] = 458;
 
-     t["a196"] = 748;
 
-     t["a165"] = 924;
 
-     t["a192"] = 748;
 
-     t["a166"] = 918;
 
-     t["a167"] = 927;
 
-     t["a168"] = 928;
 
-     t["a169"] = 928;
 
-     t["a170"] = 834;
 
-     t["a171"] = 873;
 
-     t["a172"] = 828;
 
-     t["a173"] = 924;
 
-     t["a162"] = 924;
 
-     t["a174"] = 917;
 
-     t["a175"] = 930;
 
-     t["a176"] = 931;
 
-     t["a177"] = 463;
 
-     t["a178"] = 883;
 
-     t["a179"] = 836;
 
-     t["a193"] = 836;
 
-     t["a180"] = 867;
 
-     t["a199"] = 867;
 
-     t["a181"] = 696;
 
-     t["a200"] = 696;
 
-     t["a182"] = 874;
 
-     t["a201"] = 874;
 
-     t["a183"] = 760;
 
-     t["a184"] = 946;
 
-     t["a197"] = 771;
 
-     t["a185"] = 865;
 
-     t["a194"] = 771;
 
-     t["a198"] = 888;
 
-     t["a186"] = 967;
 
-     t["a195"] = 888;
 
-     t["a187"] = 831;
 
-     t["a188"] = 873;
 
-     t["a189"] = 927;
 
-     t["a190"] = 970;
 
-     t["a191"] = 918;
 
-   });
 
- });
 
- exports.getMetrics = getMetrics;
 
- /***/ }),
 
- /* 39 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.isPDFFunction = isPDFFunction;
 
- exports.PostScriptCompiler = exports.PostScriptEvaluator = exports.PDFFunctionFactory = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _ps_parser = __w_pdfjs_require__(40);
 
- class PDFFunctionFactory {
 
-   constructor({
 
-     xref,
 
-     isEvalSupported = true
 
-   }) {
 
-     this.xref = xref;
 
-     this.isEvalSupported = isEvalSupported !== false;
 
-   }
 
-   create(fn) {
 
-     return PDFFunction.parse({
 
-       xref: this.xref,
 
-       isEvalSupported: this.isEvalSupported,
 
-       fn
 
-     });
 
-   }
 
-   createFromArray(fnObj) {
 
-     return PDFFunction.parseArray({
 
-       xref: this.xref,
 
-       isEvalSupported: this.isEvalSupported,
 
-       fnObj
 
-     });
 
-   }
 
- }
 
- exports.PDFFunctionFactory = PDFFunctionFactory;
 
- function toNumberArray(arr) {
 
-   if (!Array.isArray(arr)) {
 
-     return null;
 
-   }
 
-   const length = arr.length;
 
-   for (let i = 0; i < length; i++) {
 
-     if (typeof arr[i] !== "number") {
 
-       const result = new Array(length);
 
-       for (let i = 0; i < length; i++) {
 
-         result[i] = +arr[i];
 
-       }
 
-       return result;
 
-     }
 
-   }
 
-   return arr;
 
- }
 
- var PDFFunction = function PDFFunctionClosure() {
 
-   const CONSTRUCT_SAMPLED = 0;
 
-   const CONSTRUCT_INTERPOLATED = 2;
 
-   const CONSTRUCT_STICHED = 3;
 
-   const CONSTRUCT_POSTSCRIPT = 4;
 
-   return {
 
-     getSampleArray(size, outputSize, bps, stream) {
 
-       var i, ii;
 
-       var length = 1;
 
-       for (i = 0, ii = size.length; i < ii; i++) {
 
-         length *= size[i];
 
-       }
 
-       length *= outputSize;
 
-       var array = new Array(length);
 
-       var codeSize = 0;
 
-       var codeBuf = 0;
 
-       var sampleMul = 1.0 / (2.0 ** bps - 1);
 
-       var strBytes = stream.getBytes((length * bps + 7) / 8);
 
-       var strIdx = 0;
 
-       for (i = 0; i < length; i++) {
 
-         while (codeSize < bps) {
 
-           codeBuf <<= 8;
 
-           codeBuf |= strBytes[strIdx++];
 
-           codeSize += 8;
 
-         }
 
-         codeSize -= bps;
 
-         array[i] = (codeBuf >> codeSize) * sampleMul;
 
-         codeBuf &= (1 << codeSize) - 1;
 
-       }
 
-       return array;
 
-     },
 
-     getIR({
 
-       xref,
 
-       isEvalSupported,
 
-       fn
 
-     }) {
 
-       var dict = fn.dict;
 
-       if (!dict) {
 
-         dict = fn;
 
-       }
 
-       var types = [this.constructSampled, null, this.constructInterpolated, this.constructStiched, this.constructPostScript];
 
-       var typeNum = dict.get("FunctionType");
 
-       var typeFn = types[typeNum];
 
-       if (!typeFn) {
 
-         throw new _util.FormatError("Unknown type of function");
 
-       }
 
-       return typeFn.call(this, {
 
-         xref,
 
-         isEvalSupported,
 
-         fn,
 
-         dict
 
-       });
 
-     },
 
-     fromIR({
 
-       xref,
 
-       isEvalSupported,
 
-       IR
 
-     }) {
 
-       var type = IR[0];
 
-       switch (type) {
 
-         case CONSTRUCT_SAMPLED:
 
-           return this.constructSampledFromIR({
 
-             xref,
 
-             isEvalSupported,
 
-             IR
 
-           });
 
-         case CONSTRUCT_INTERPOLATED:
 
-           return this.constructInterpolatedFromIR({
 
-             xref,
 
-             isEvalSupported,
 
-             IR
 
-           });
 
-         case CONSTRUCT_STICHED:
 
-           return this.constructStichedFromIR({
 
-             xref,
 
-             isEvalSupported,
 
-             IR
 
-           });
 
-         default:
 
-           return this.constructPostScriptFromIR({
 
-             xref,
 
-             isEvalSupported,
 
-             IR
 
-           });
 
-       }
 
-     },
 
-     parse({
 
-       xref,
 
-       isEvalSupported,
 
-       fn
 
-     }) {
 
-       const IR = this.getIR({
 
-         xref,
 
-         isEvalSupported,
 
-         fn
 
-       });
 
-       return this.fromIR({
 
-         xref,
 
-         isEvalSupported,
 
-         IR
 
-       });
 
-     },
 
-     parseArray({
 
-       xref,
 
-       isEvalSupported,
 
-       fnObj
 
-     }) {
 
-       if (!Array.isArray(fnObj)) {
 
-         return this.parse({
 
-           xref,
 
-           isEvalSupported,
 
-           fn: fnObj
 
-         });
 
-       }
 
-       var fnArray = [];
 
-       for (var j = 0, jj = fnObj.length; j < jj; j++) {
 
-         fnArray.push(this.parse({
 
-           xref,
 
-           isEvalSupported,
 
-           fn: xref.fetchIfRef(fnObj[j])
 
-         }));
 
-       }
 
-       return function (src, srcOffset, dest, destOffset) {
 
-         for (var i = 0, ii = fnArray.length; i < ii; i++) {
 
-           fnArray[i](src, srcOffset, dest, destOffset + i);
 
-         }
 
-       };
 
-     },
 
-     constructSampled({
 
-       xref,
 
-       isEvalSupported,
 
-       fn,
 
-       dict
 
-     }) {
 
-       function toMultiArray(arr) {
 
-         var inputLength = arr.length;
 
-         var out = [];
 
-         var index = 0;
 
-         for (var i = 0; i < inputLength; i += 2) {
 
-           out[index] = [arr[i], arr[i + 1]];
 
-           ++index;
 
-         }
 
-         return out;
 
-       }
 
-       var domain = toNumberArray(dict.getArray("Domain"));
 
-       var range = toNumberArray(dict.getArray("Range"));
 
-       if (!domain || !range) {
 
-         throw new _util.FormatError("No domain or range");
 
-       }
 
-       var inputSize = domain.length / 2;
 
-       var outputSize = range.length / 2;
 
-       domain = toMultiArray(domain);
 
-       range = toMultiArray(range);
 
-       var size = toNumberArray(dict.getArray("Size"));
 
-       var bps = dict.get("BitsPerSample");
 
-       var order = dict.get("Order") || 1;
 
-       if (order !== 1) {
 
-         (0, _util.info)("No support for cubic spline interpolation: " + order);
 
-       }
 
-       var encode = toNumberArray(dict.getArray("Encode"));
 
-       if (!encode) {
 
-         encode = [];
 
-         for (var i = 0; i < inputSize; ++i) {
 
-           encode.push([0, size[i] - 1]);
 
-         }
 
-       } else {
 
-         encode = toMultiArray(encode);
 
-       }
 
-       var decode = toNumberArray(dict.getArray("Decode"));
 
-       if (!decode) {
 
-         decode = range;
 
-       } else {
 
-         decode = toMultiArray(decode);
 
-       }
 
-       var samples = this.getSampleArray(size, outputSize, bps, fn);
 
-       return [CONSTRUCT_SAMPLED, inputSize, domain, encode, decode, samples, size, outputSize, 2 ** bps - 1, range];
 
-     },
 
-     constructSampledFromIR({
 
-       xref,
 
-       isEvalSupported,
 
-       IR
 
-     }) {
 
-       function interpolate(x, xmin, xmax, ymin, ymax) {
 
-         return ymin + (x - xmin) * ((ymax - ymin) / (xmax - xmin));
 
-       }
 
-       return function constructSampledFromIRResult(src, srcOffset, dest, destOffset) {
 
-         var m = IR[1];
 
-         var domain = IR[2];
 
-         var encode = IR[3];
 
-         var decode = IR[4];
 
-         var samples = IR[5];
 
-         var size = IR[6];
 
-         var n = IR[7];
 
-         var range = IR[9];
 
-         var cubeVertices = 1 << m;
 
-         var cubeN = new Float64Array(cubeVertices);
 
-         var cubeVertex = new Uint32Array(cubeVertices);
 
-         var i, j;
 
-         for (j = 0; j < cubeVertices; j++) {
 
-           cubeN[j] = 1;
 
-         }
 
-         var k = n,
 
-             pos = 1;
 
-         for (i = 0; i < m; ++i) {
 
-           var domain_2i = domain[i][0];
 
-           var domain_2i_1 = domain[i][1];
 
-           var xi = Math.min(Math.max(src[srcOffset + i], domain_2i), domain_2i_1);
 
-           var e = interpolate(xi, domain_2i, domain_2i_1, encode[i][0], encode[i][1]);
 
-           var size_i = size[i];
 
-           e = Math.min(Math.max(e, 0), size_i - 1);
 
-           var e0 = e < size_i - 1 ? Math.floor(e) : e - 1;
 
-           var n0 = e0 + 1 - e;
 
-           var n1 = e - e0;
 
-           var offset0 = e0 * k;
 
-           var offset1 = offset0 + k;
 
-           for (j = 0; j < cubeVertices; j++) {
 
-             if (j & pos) {
 
-               cubeN[j] *= n1;
 
-               cubeVertex[j] += offset1;
 
-             } else {
 
-               cubeN[j] *= n0;
 
-               cubeVertex[j] += offset0;
 
-             }
 
-           }
 
-           k *= size_i;
 
-           pos <<= 1;
 
-         }
 
-         for (j = 0; j < n; ++j) {
 
-           var rj = 0;
 
-           for (i = 0; i < cubeVertices; i++) {
 
-             rj += samples[cubeVertex[i] + j] * cubeN[i];
 
-           }
 
-           rj = interpolate(rj, 0, 1, decode[j][0], decode[j][1]);
 
-           dest[destOffset + j] = Math.min(Math.max(rj, range[j][0]), range[j][1]);
 
-         }
 
-       };
 
-     },
 
-     constructInterpolated({
 
-       xref,
 
-       isEvalSupported,
 
-       fn,
 
-       dict
 
-     }) {
 
-       var c0 = toNumberArray(dict.getArray("C0")) || [0];
 
-       var c1 = toNumberArray(dict.getArray("C1")) || [1];
 
-       var n = dict.get("N");
 
-       var length = c0.length;
 
-       var diff = [];
 
-       for (var i = 0; i < length; ++i) {
 
-         diff.push(c1[i] - c0[i]);
 
-       }
 
-       return [CONSTRUCT_INTERPOLATED, c0, diff, n];
 
-     },
 
-     constructInterpolatedFromIR({
 
-       xref,
 
-       isEvalSupported,
 
-       IR
 
-     }) {
 
-       var c0 = IR[1];
 
-       var diff = IR[2];
 
-       var n = IR[3];
 
-       var length = diff.length;
 
-       return function constructInterpolatedFromIRResult(src, srcOffset, dest, destOffset) {
 
-         var x = n === 1 ? src[srcOffset] : src[srcOffset] ** n;
 
-         for (var j = 0; j < length; ++j) {
 
-           dest[destOffset + j] = c0[j] + x * diff[j];
 
-         }
 
-       };
 
-     },
 
-     constructStiched({
 
-       xref,
 
-       isEvalSupported,
 
-       fn,
 
-       dict
 
-     }) {
 
-       var domain = toNumberArray(dict.getArray("Domain"));
 
-       if (!domain) {
 
-         throw new _util.FormatError("No domain");
 
-       }
 
-       var inputSize = domain.length / 2;
 
-       if (inputSize !== 1) {
 
-         throw new _util.FormatError("Bad domain for stiched function");
 
-       }
 
-       var fnRefs = dict.get("Functions");
 
-       var fns = [];
 
-       for (var i = 0, ii = fnRefs.length; i < ii; ++i) {
 
-         fns.push(this.parse({
 
-           xref,
 
-           isEvalSupported,
 
-           fn: xref.fetchIfRef(fnRefs[i])
 
-         }));
 
-       }
 
-       var bounds = toNumberArray(dict.getArray("Bounds"));
 
-       var encode = toNumberArray(dict.getArray("Encode"));
 
-       return [CONSTRUCT_STICHED, domain, bounds, encode, fns];
 
-     },
 
-     constructStichedFromIR({
 
-       xref,
 
-       isEvalSupported,
 
-       IR
 
-     }) {
 
-       var domain = IR[1];
 
-       var bounds = IR[2];
 
-       var encode = IR[3];
 
-       var fns = IR[4];
 
-       var tmpBuf = new Float32Array(1);
 
-       return function constructStichedFromIRResult(src, srcOffset, dest, destOffset) {
 
-         var clip = function constructStichedFromIRClip(v, min, max) {
 
-           if (v > max) {
 
-             v = max;
 
-           } else if (v < min) {
 
-             v = min;
 
-           }
 
-           return v;
 
-         };
 
-         var v = clip(src[srcOffset], domain[0], domain[1]);
 
-         for (var i = 0, ii = bounds.length; i < ii; ++i) {
 
-           if (v < bounds[i]) {
 
-             break;
 
-           }
 
-         }
 
-         var dmin = domain[0];
 
-         if (i > 0) {
 
-           dmin = bounds[i - 1];
 
-         }
 
-         var dmax = domain[1];
 
-         if (i < bounds.length) {
 
-           dmax = bounds[i];
 
-         }
 
-         var rmin = encode[2 * i];
 
-         var rmax = encode[2 * i + 1];
 
-         tmpBuf[0] = dmin === dmax ? rmin : rmin + (v - dmin) * (rmax - rmin) / (dmax - dmin);
 
-         fns[i](tmpBuf, 0, dest, destOffset);
 
-       };
 
-     },
 
-     constructPostScript({
 
-       xref,
 
-       isEvalSupported,
 
-       fn,
 
-       dict
 
-     }) {
 
-       var domain = toNumberArray(dict.getArray("Domain"));
 
-       var range = toNumberArray(dict.getArray("Range"));
 
-       if (!domain) {
 
-         throw new _util.FormatError("No domain.");
 
-       }
 
-       if (!range) {
 
-         throw new _util.FormatError("No range.");
 
-       }
 
-       var lexer = new _ps_parser.PostScriptLexer(fn);
 
-       var parser = new _ps_parser.PostScriptParser(lexer);
 
-       var code = parser.parse();
 
-       return [CONSTRUCT_POSTSCRIPT, domain, range, code];
 
-     },
 
-     constructPostScriptFromIR({
 
-       xref,
 
-       isEvalSupported,
 
-       IR
 
-     }) {
 
-       var domain = IR[1];
 
-       var range = IR[2];
 
-       var code = IR[3];
 
-       if (isEvalSupported && _util.IsEvalSupportedCached.value) {
 
-         const compiled = new PostScriptCompiler().compile(code, domain, range);
 
-         if (compiled) {
 
-           return new Function("src", "srcOffset", "dest", "destOffset", compiled);
 
-         }
 
-       }
 
-       (0, _util.info)("Unable to compile PS function");
 
-       var numOutputs = range.length >> 1;
 
-       var numInputs = domain.length >> 1;
 
-       var evaluator = new PostScriptEvaluator(code);
 
-       var cache = Object.create(null);
 
-       var MAX_CACHE_SIZE = 2048 * 4;
 
-       var cache_available = MAX_CACHE_SIZE;
 
-       var tmpBuf = new Float32Array(numInputs);
 
-       return function constructPostScriptFromIRResult(src, srcOffset, dest, destOffset) {
 
-         var i, value;
 
-         var key = "";
 
-         var input = tmpBuf;
 
-         for (i = 0; i < numInputs; i++) {
 
-           value = src[srcOffset + i];
 
-           input[i] = value;
 
-           key += value + "_";
 
-         }
 
-         var cachedValue = cache[key];
 
-         if (cachedValue !== undefined) {
 
-           dest.set(cachedValue, destOffset);
 
-           return;
 
-         }
 
-         var output = new Float32Array(numOutputs);
 
-         var stack = evaluator.execute(input);
 
-         var stackIndex = stack.length - numOutputs;
 
-         for (i = 0; i < numOutputs; i++) {
 
-           value = stack[stackIndex + i];
 
-           var bound = range[i * 2];
 
-           if (value < bound) {
 
-             value = bound;
 
-           } else {
 
-             bound = range[i * 2 + 1];
 
-             if (value > bound) {
 
-               value = bound;
 
-             }
 
-           }
 
-           output[i] = value;
 
-         }
 
-         if (cache_available > 0) {
 
-           cache_available--;
 
-           cache[key] = output;
 
-         }
 
-         dest.set(output, destOffset);
 
-       };
 
-     }
 
-   };
 
- }();
 
- function isPDFFunction(v) {
 
-   var fnDict;
 
-   if (typeof v !== "object") {
 
-     return false;
 
-   } else if ((0, _primitives.isDict)(v)) {
 
-     fnDict = v;
 
-   } else if ((0, _primitives.isStream)(v)) {
 
-     fnDict = v.dict;
 
-   } else {
 
-     return false;
 
-   }
 
-   return fnDict.has("FunctionType");
 
- }
 
- var PostScriptStack = function PostScriptStackClosure() {
 
-   var MAX_STACK_SIZE = 100;
 
-   function PostScriptStack(initialStack) {
 
-     this.stack = !initialStack ? [] : Array.prototype.slice.call(initialStack, 0);
 
-   }
 
-   PostScriptStack.prototype = {
 
-     push: function PostScriptStack_push(value) {
 
-       if (this.stack.length >= MAX_STACK_SIZE) {
 
-         throw new Error("PostScript function stack overflow.");
 
-       }
 
-       this.stack.push(value);
 
-     },
 
-     pop: function PostScriptStack_pop() {
 
-       if (this.stack.length <= 0) {
 
-         throw new Error("PostScript function stack underflow.");
 
-       }
 
-       return this.stack.pop();
 
-     },
 
-     copy: function PostScriptStack_copy(n) {
 
-       if (this.stack.length + n >= MAX_STACK_SIZE) {
 
-         throw new Error("PostScript function stack overflow.");
 
-       }
 
-       var stack = this.stack;
 
-       for (var i = stack.length - n, j = n - 1; j >= 0; j--, i++) {
 
-         stack.push(stack[i]);
 
-       }
 
-     },
 
-     index: function PostScriptStack_index(n) {
 
-       this.push(this.stack[this.stack.length - n - 1]);
 
-     },
 
-     roll: function PostScriptStack_roll(n, p) {
 
-       var stack = this.stack;
 
-       var l = stack.length - n;
 
-       var r = stack.length - 1,
 
-           c = l + (p - Math.floor(p / n) * n),
 
-           i,
 
-           j,
 
-           t;
 
-       for (i = l, j = r; i < j; i++, j--) {
 
-         t = stack[i];
 
-         stack[i] = stack[j];
 
-         stack[j] = t;
 
-       }
 
-       for (i = l, j = c - 1; i < j; i++, j--) {
 
-         t = stack[i];
 
-         stack[i] = stack[j];
 
-         stack[j] = t;
 
-       }
 
-       for (i = c, j = r; i < j; i++, j--) {
 
-         t = stack[i];
 
-         stack[i] = stack[j];
 
-         stack[j] = t;
 
-       }
 
-     }
 
-   };
 
-   return PostScriptStack;
 
- }();
 
- var PostScriptEvaluator = function PostScriptEvaluatorClosure() {
 
-   function PostScriptEvaluator(operators) {
 
-     this.operators = operators;
 
-   }
 
-   PostScriptEvaluator.prototype = {
 
-     execute: function PostScriptEvaluator_execute(initialStack) {
 
-       var stack = new PostScriptStack(initialStack);
 
-       var counter = 0;
 
-       var operators = this.operators;
 
-       var length = operators.length;
 
-       var operator, a, b;
 
-       while (counter < length) {
 
-         operator = operators[counter++];
 
-         if (typeof operator === "number") {
 
-           stack.push(operator);
 
-           continue;
 
-         }
 
-         switch (operator) {
 
-           case "jz":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             if (!a) {
 
-               counter = b;
 
-             }
 
-             break;
 
-           case "j":
 
-             a = stack.pop();
 
-             counter = a;
 
-             break;
 
-           case "abs":
 
-             a = stack.pop();
 
-             stack.push(Math.abs(a));
 
-             break;
 
-           case "add":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a + b);
 
-             break;
 
-           case "and":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             if ((0, _util.isBool)(a) && (0, _util.isBool)(b)) {
 
-               stack.push(a && b);
 
-             } else {
 
-               stack.push(a & b);
 
-             }
 
-             break;
 
-           case "atan":
 
-             a = stack.pop();
 
-             stack.push(Math.atan(a));
 
-             break;
 
-           case "bitshift":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             if (a > 0) {
 
-               stack.push(a << b);
 
-             } else {
 
-               stack.push(a >> b);
 
-             }
 
-             break;
 
-           case "ceiling":
 
-             a = stack.pop();
 
-             stack.push(Math.ceil(a));
 
-             break;
 
-           case "copy":
 
-             a = stack.pop();
 
-             stack.copy(a);
 
-             break;
 
-           case "cos":
 
-             a = stack.pop();
 
-             stack.push(Math.cos(a));
 
-             break;
 
-           case "cvi":
 
-             a = stack.pop() | 0;
 
-             stack.push(a);
 
-             break;
 
-           case "cvr":
 
-             break;
 
-           case "div":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a / b);
 
-             break;
 
-           case "dup":
 
-             stack.copy(1);
 
-             break;
 
-           case "eq":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a === b);
 
-             break;
 
-           case "exch":
 
-             stack.roll(2, 1);
 
-             break;
 
-           case "exp":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a ** b);
 
-             break;
 
-           case "false":
 
-             stack.push(false);
 
-             break;
 
-           case "floor":
 
-             a = stack.pop();
 
-             stack.push(Math.floor(a));
 
-             break;
 
-           case "ge":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a >= b);
 
-             break;
 
-           case "gt":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a > b);
 
-             break;
 
-           case "idiv":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a / b | 0);
 
-             break;
 
-           case "index":
 
-             a = stack.pop();
 
-             stack.index(a);
 
-             break;
 
-           case "le":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a <= b);
 
-             break;
 
-           case "ln":
 
-             a = stack.pop();
 
-             stack.push(Math.log(a));
 
-             break;
 
-           case "log":
 
-             a = stack.pop();
 
-             stack.push(Math.log(a) / Math.LN10);
 
-             break;
 
-           case "lt":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a < b);
 
-             break;
 
-           case "mod":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a % b);
 
-             break;
 
-           case "mul":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a * b);
 
-             break;
 
-           case "ne":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a !== b);
 
-             break;
 
-           case "neg":
 
-             a = stack.pop();
 
-             stack.push(-a);
 
-             break;
 
-           case "not":
 
-             a = stack.pop();
 
-             if ((0, _util.isBool)(a)) {
 
-               stack.push(!a);
 
-             } else {
 
-               stack.push(~a);
 
-             }
 
-             break;
 
-           case "or":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             if ((0, _util.isBool)(a) && (0, _util.isBool)(b)) {
 
-               stack.push(a || b);
 
-             } else {
 
-               stack.push(a | b);
 
-             }
 
-             break;
 
-           case "pop":
 
-             stack.pop();
 
-             break;
 
-           case "roll":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.roll(a, b);
 
-             break;
 
-           case "round":
 
-             a = stack.pop();
 
-             stack.push(Math.round(a));
 
-             break;
 
-           case "sin":
 
-             a = stack.pop();
 
-             stack.push(Math.sin(a));
 
-             break;
 
-           case "sqrt":
 
-             a = stack.pop();
 
-             stack.push(Math.sqrt(a));
 
-             break;
 
-           case "sub":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             stack.push(a - b);
 
-             break;
 
-           case "true":
 
-             stack.push(true);
 
-             break;
 
-           case "truncate":
 
-             a = stack.pop();
 
-             a = a < 0 ? Math.ceil(a) : Math.floor(a);
 
-             stack.push(a);
 
-             break;
 
-           case "xor":
 
-             b = stack.pop();
 
-             a = stack.pop();
 
-             if ((0, _util.isBool)(a) && (0, _util.isBool)(b)) {
 
-               stack.push(a !== b);
 
-             } else {
 
-               stack.push(a ^ b);
 
-             }
 
-             break;
 
-           default:
 
-             throw new _util.FormatError(`Unknown operator ${operator}`);
 
-         }
 
-       }
 
-       return stack.stack;
 
-     }
 
-   };
 
-   return PostScriptEvaluator;
 
- }();
 
- exports.PostScriptEvaluator = PostScriptEvaluator;
 
- var PostScriptCompiler = function PostScriptCompilerClosure() {
 
-   function AstNode(type) {
 
-     this.type = type;
 
-   }
 
-   AstNode.prototype.visit = function (visitor) {
 
-     (0, _util.unreachable)("abstract method");
 
-   };
 
-   function AstArgument(index, min, max) {
 
-     AstNode.call(this, "args");
 
-     this.index = index;
 
-     this.min = min;
 
-     this.max = max;
 
-   }
 
-   AstArgument.prototype = Object.create(AstNode.prototype);
 
-   AstArgument.prototype.visit = function (visitor) {
 
-     visitor.visitArgument(this);
 
-   };
 
-   function AstLiteral(number) {
 
-     AstNode.call(this, "literal");
 
-     this.number = number;
 
-     this.min = number;
 
-     this.max = number;
 
-   }
 
-   AstLiteral.prototype = Object.create(AstNode.prototype);
 
-   AstLiteral.prototype.visit = function (visitor) {
 
-     visitor.visitLiteral(this);
 
-   };
 
-   function AstBinaryOperation(op, arg1, arg2, min, max) {
 
-     AstNode.call(this, "binary");
 
-     this.op = op;
 
-     this.arg1 = arg1;
 
-     this.arg2 = arg2;
 
-     this.min = min;
 
-     this.max = max;
 
-   }
 
-   AstBinaryOperation.prototype = Object.create(AstNode.prototype);
 
-   AstBinaryOperation.prototype.visit = function (visitor) {
 
-     visitor.visitBinaryOperation(this);
 
-   };
 
-   function AstMin(arg, max) {
 
-     AstNode.call(this, "max");
 
-     this.arg = arg;
 
-     this.min = arg.min;
 
-     this.max = max;
 
-   }
 
-   AstMin.prototype = Object.create(AstNode.prototype);
 
-   AstMin.prototype.visit = function (visitor) {
 
-     visitor.visitMin(this);
 
-   };
 
-   function AstVariable(index, min, max) {
 
-     AstNode.call(this, "var");
 
-     this.index = index;
 
-     this.min = min;
 
-     this.max = max;
 
-   }
 
-   AstVariable.prototype = Object.create(AstNode.prototype);
 
-   AstVariable.prototype.visit = function (visitor) {
 
-     visitor.visitVariable(this);
 
-   };
 
-   function AstVariableDefinition(variable, arg) {
 
-     AstNode.call(this, "definition");
 
-     this.variable = variable;
 
-     this.arg = arg;
 
-   }
 
-   AstVariableDefinition.prototype = Object.create(AstNode.prototype);
 
-   AstVariableDefinition.prototype.visit = function (visitor) {
 
-     visitor.visitVariableDefinition(this);
 
-   };
 
-   function ExpressionBuilderVisitor() {
 
-     this.parts = [];
 
-   }
 
-   ExpressionBuilderVisitor.prototype = {
 
-     visitArgument(arg) {
 
-       this.parts.push("Math.max(", arg.min, ", Math.min(", arg.max, ", src[srcOffset + ", arg.index, "]))");
 
-     },
 
-     visitVariable(variable) {
 
-       this.parts.push("v", variable.index);
 
-     },
 
-     visitLiteral(literal) {
 
-       this.parts.push(literal.number);
 
-     },
 
-     visitBinaryOperation(operation) {
 
-       this.parts.push("(");
 
-       operation.arg1.visit(this);
 
-       this.parts.push(" ", operation.op, " ");
 
-       operation.arg2.visit(this);
 
-       this.parts.push(")");
 
-     },
 
-     visitVariableDefinition(definition) {
 
-       this.parts.push("var ");
 
-       definition.variable.visit(this);
 
-       this.parts.push(" = ");
 
-       definition.arg.visit(this);
 
-       this.parts.push(";");
 
-     },
 
-     visitMin(max) {
 
-       this.parts.push("Math.min(");
 
-       max.arg.visit(this);
 
-       this.parts.push(", ", max.max, ")");
 
-     },
 
-     toString() {
 
-       return this.parts.join("");
 
-     }
 
-   };
 
-   function buildAddOperation(num1, num2) {
 
-     if (num2.type === "literal" && num2.number === 0) {
 
-       return num1;
 
-     }
 
-     if (num1.type === "literal" && num1.number === 0) {
 
-       return num2;
 
-     }
 
-     if (num2.type === "literal" && num1.type === "literal") {
 
-       return new AstLiteral(num1.number + num2.number);
 
-     }
 
-     return new AstBinaryOperation("+", num1, num2, num1.min + num2.min, num1.max + num2.max);
 
-   }
 
-   function buildMulOperation(num1, num2) {
 
-     if (num2.type === "literal") {
 
-       if (num2.number === 0) {
 
-         return new AstLiteral(0);
 
-       } else if (num2.number === 1) {
 
-         return num1;
 
-       } else if (num1.type === "literal") {
 
-         return new AstLiteral(num1.number * num2.number);
 
-       }
 
-     }
 
-     if (num1.type === "literal") {
 
-       if (num1.number === 0) {
 
-         return new AstLiteral(0);
 
-       } else if (num1.number === 1) {
 
-         return num2;
 
-       }
 
-     }
 
-     var min = Math.min(num1.min * num2.min, num1.min * num2.max, num1.max * num2.min, num1.max * num2.max);
 
-     var max = Math.max(num1.min * num2.min, num1.min * num2.max, num1.max * num2.min, num1.max * num2.max);
 
-     return new AstBinaryOperation("*", num1, num2, min, max);
 
-   }
 
-   function buildSubOperation(num1, num2) {
 
-     if (num2.type === "literal") {
 
-       if (num2.number === 0) {
 
-         return num1;
 
-       } else if (num1.type === "literal") {
 
-         return new AstLiteral(num1.number - num2.number);
 
-       }
 
-     }
 
-     if (num2.type === "binary" && num2.op === "-" && num1.type === "literal" && num1.number === 1 && num2.arg1.type === "literal" && num2.arg1.number === 1) {
 
-       return num2.arg2;
 
-     }
 
-     return new AstBinaryOperation("-", num1, num2, num1.min - num2.max, num1.max - num2.min);
 
-   }
 
-   function buildMinOperation(num1, max) {
 
-     if (num1.min >= max) {
 
-       return new AstLiteral(max);
 
-     } else if (num1.max <= max) {
 
-       return num1;
 
-     }
 
-     return new AstMin(num1, max);
 
-   }
 
-   function PostScriptCompiler() {}
 
-   PostScriptCompiler.prototype = {
 
-     compile: function PostScriptCompiler_compile(code, domain, range) {
 
-       var stack = [];
 
-       var i, ii;
 
-       var instructions = [];
 
-       var inputSize = domain.length >> 1,
 
-           outputSize = range.length >> 1;
 
-       var lastRegister = 0;
 
-       var n, j;
 
-       var num1, num2, ast1, ast2, tmpVar, item;
 
-       for (i = 0; i < inputSize; i++) {
 
-         stack.push(new AstArgument(i, domain[i * 2], domain[i * 2 + 1]));
 
-       }
 
-       for (i = 0, ii = code.length; i < ii; i++) {
 
-         item = code[i];
 
-         if (typeof item === "number") {
 
-           stack.push(new AstLiteral(item));
 
-           continue;
 
-         }
 
-         switch (item) {
 
-           case "add":
 
-             if (stack.length < 2) {
 
-               return null;
 
-             }
 
-             num2 = stack.pop();
 
-             num1 = stack.pop();
 
-             stack.push(buildAddOperation(num1, num2));
 
-             break;
 
-           case "cvr":
 
-             if (stack.length < 1) {
 
-               return null;
 
-             }
 
-             break;
 
-           case "mul":
 
-             if (stack.length < 2) {
 
-               return null;
 
-             }
 
-             num2 = stack.pop();
 
-             num1 = stack.pop();
 
-             stack.push(buildMulOperation(num1, num2));
 
-             break;
 
-           case "sub":
 
-             if (stack.length < 2) {
 
-               return null;
 
-             }
 
-             num2 = stack.pop();
 
-             num1 = stack.pop();
 
-             stack.push(buildSubOperation(num1, num2));
 
-             break;
 
-           case "exch":
 
-             if (stack.length < 2) {
 
-               return null;
 
-             }
 
-             ast1 = stack.pop();
 
-             ast2 = stack.pop();
 
-             stack.push(ast1, ast2);
 
-             break;
 
-           case "pop":
 
-             if (stack.length < 1) {
 
-               return null;
 
-             }
 
-             stack.pop();
 
-             break;
 
-           case "index":
 
-             if (stack.length < 1) {
 
-               return null;
 
-             }
 
-             num1 = stack.pop();
 
-             if (num1.type !== "literal") {
 
-               return null;
 
-             }
 
-             n = num1.number;
 
-             if (n < 0 || !Number.isInteger(n) || stack.length < n) {
 
-               return null;
 
-             }
 
-             ast1 = stack[stack.length - n - 1];
 
-             if (ast1.type === "literal" || ast1.type === "var") {
 
-               stack.push(ast1);
 
-               break;
 
-             }
 
-             tmpVar = new AstVariable(lastRegister++, ast1.min, ast1.max);
 
-             stack[stack.length - n - 1] = tmpVar;
 
-             stack.push(tmpVar);
 
-             instructions.push(new AstVariableDefinition(tmpVar, ast1));
 
-             break;
 
-           case "dup":
 
-             if (stack.length < 1) {
 
-               return null;
 
-             }
 
-             if (typeof code[i + 1] === "number" && code[i + 2] === "gt" && code[i + 3] === i + 7 && code[i + 4] === "jz" && code[i + 5] === "pop" && code[i + 6] === code[i + 1]) {
 
-               num1 = stack.pop();
 
-               stack.push(buildMinOperation(num1, code[i + 1]));
 
-               i += 6;
 
-               break;
 
-             }
 
-             ast1 = stack[stack.length - 1];
 
-             if (ast1.type === "literal" || ast1.type === "var") {
 
-               stack.push(ast1);
 
-               break;
 
-             }
 
-             tmpVar = new AstVariable(lastRegister++, ast1.min, ast1.max);
 
-             stack[stack.length - 1] = tmpVar;
 
-             stack.push(tmpVar);
 
-             instructions.push(new AstVariableDefinition(tmpVar, ast1));
 
-             break;
 
-           case "roll":
 
-             if (stack.length < 2) {
 
-               return null;
 
-             }
 
-             num2 = stack.pop();
 
-             num1 = stack.pop();
 
-             if (num2.type !== "literal" || num1.type !== "literal") {
 
-               return null;
 
-             }
 
-             j = num2.number;
 
-             n = num1.number;
 
-             if (n <= 0 || !Number.isInteger(n) || !Number.isInteger(j) || stack.length < n) {
 
-               return null;
 
-             }
 
-             j = (j % n + n) % n;
 
-             if (j === 0) {
 
-               break;
 
-             }
 
-             Array.prototype.push.apply(stack, stack.splice(stack.length - n, n - j));
 
-             break;
 
-           default:
 
-             return null;
 
-         }
 
-       }
 
-       if (stack.length !== outputSize) {
 
-         return null;
 
-       }
 
-       var result = [];
 
-       instructions.forEach(function (instruction) {
 
-         var statementBuilder = new ExpressionBuilderVisitor();
 
-         instruction.visit(statementBuilder);
 
-         result.push(statementBuilder.toString());
 
-       });
 
-       stack.forEach(function (expr, i) {
 
-         var statementBuilder = new ExpressionBuilderVisitor();
 
-         expr.visit(statementBuilder);
 
-         var min = range[i * 2],
 
-             max = range[i * 2 + 1];
 
-         var out = [statementBuilder.toString()];
 
-         if (min > expr.min) {
 
-           out.unshift("Math.max(", min, ", ");
 
-           out.push(")");
 
-         }
 
-         if (max < expr.max) {
 
-           out.unshift("Math.min(", max, ", ");
 
-           out.push(")");
 
-         }
 
-         out.unshift("dest[destOffset + ", i, "] = ");
 
-         out.push(";");
 
-         result.push(out.join(""));
 
-       });
 
-       return result.join("\n");
 
-     }
 
-   };
 
-   return PostScriptCompiler;
 
- }();
 
- exports.PostScriptCompiler = PostScriptCompiler;
 
- /***/ }),
 
- /* 40 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.PostScriptParser = exports.PostScriptLexer = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _core_utils = __w_pdfjs_require__(7);
 
- class PostScriptParser {
 
-   constructor(lexer) {
 
-     this.lexer = lexer;
 
-     this.operators = [];
 
-     this.token = null;
 
-     this.prev = null;
 
-   }
 
-   nextToken() {
 
-     this.prev = this.token;
 
-     this.token = this.lexer.getToken();
 
-   }
 
-   accept(type) {
 
-     if (this.token.type === type) {
 
-       this.nextToken();
 
-       return true;
 
-     }
 
-     return false;
 
-   }
 
-   expect(type) {
 
-     if (this.accept(type)) {
 
-       return true;
 
-     }
 
-     throw new _util.FormatError(`Unexpected symbol: found ${this.token.type} expected ${type}.`);
 
-   }
 
-   parse() {
 
-     this.nextToken();
 
-     this.expect(PostScriptTokenTypes.LBRACE);
 
-     this.parseBlock();
 
-     this.expect(PostScriptTokenTypes.RBRACE);
 
-     return this.operators;
 
-   }
 
-   parseBlock() {
 
-     while (true) {
 
-       if (this.accept(PostScriptTokenTypes.NUMBER)) {
 
-         this.operators.push(this.prev.value);
 
-       } else if (this.accept(PostScriptTokenTypes.OPERATOR)) {
 
-         this.operators.push(this.prev.value);
 
-       } else if (this.accept(PostScriptTokenTypes.LBRACE)) {
 
-         this.parseCondition();
 
-       } else {
 
-         return;
 
-       }
 
-     }
 
-   }
 
-   parseCondition() {
 
-     const conditionLocation = this.operators.length;
 
-     this.operators.push(null, null);
 
-     this.parseBlock();
 
-     this.expect(PostScriptTokenTypes.RBRACE);
 
-     if (this.accept(PostScriptTokenTypes.IF)) {
 
-       this.operators[conditionLocation] = this.operators.length;
 
-       this.operators[conditionLocation + 1] = "jz";
 
-     } else if (this.accept(PostScriptTokenTypes.LBRACE)) {
 
-       const jumpLocation = this.operators.length;
 
-       this.operators.push(null, null);
 
-       const endOfTrue = this.operators.length;
 
-       this.parseBlock();
 
-       this.expect(PostScriptTokenTypes.RBRACE);
 
-       this.expect(PostScriptTokenTypes.IFELSE);
 
-       this.operators[jumpLocation] = this.operators.length;
 
-       this.operators[jumpLocation + 1] = "j";
 
-       this.operators[conditionLocation] = endOfTrue;
 
-       this.operators[conditionLocation + 1] = "jz";
 
-     } else {
 
-       throw new _util.FormatError("PS Function: error parsing conditional.");
 
-     }
 
-   }
 
- }
 
- exports.PostScriptParser = PostScriptParser;
 
- const PostScriptTokenTypes = {
 
-   LBRACE: 0,
 
-   RBRACE: 1,
 
-   NUMBER: 2,
 
-   OPERATOR: 3,
 
-   IF: 4,
 
-   IFELSE: 5
 
- };
 
- const PostScriptToken = function PostScriptTokenClosure() {
 
-   const opCache = Object.create(null);
 
-   class PostScriptToken {
 
-     constructor(type, value) {
 
-       this.type = type;
 
-       this.value = value;
 
-     }
 
-     static getOperator(op) {
 
-       const opValue = opCache[op];
 
-       if (opValue) {
 
-         return opValue;
 
-       }
 
-       return opCache[op] = new PostScriptToken(PostScriptTokenTypes.OPERATOR, op);
 
-     }
 
-     static get LBRACE() {
 
-       return (0, _util.shadow)(this, "LBRACE", new PostScriptToken(PostScriptTokenTypes.LBRACE, "{"));
 
-     }
 
-     static get RBRACE() {
 
-       return (0, _util.shadow)(this, "RBRACE", new PostScriptToken(PostScriptTokenTypes.RBRACE, "}"));
 
-     }
 
-     static get IF() {
 
-       return (0, _util.shadow)(this, "IF", new PostScriptToken(PostScriptTokenTypes.IF, "IF"));
 
-     }
 
-     static get IFELSE() {
 
-       return (0, _util.shadow)(this, "IFELSE", new PostScriptToken(PostScriptTokenTypes.IFELSE, "IFELSE"));
 
-     }
 
-   }
 
-   return PostScriptToken;
 
- }();
 
- class PostScriptLexer {
 
-   constructor(stream) {
 
-     this.stream = stream;
 
-     this.nextChar();
 
-     this.strBuf = [];
 
-   }
 
-   nextChar() {
 
-     return this.currentChar = this.stream.getByte();
 
-   }
 
-   getToken() {
 
-     let comment = false;
 
-     let ch = this.currentChar;
 
-     while (true) {
 
-       if (ch < 0) {
 
-         return _primitives.EOF;
 
-       }
 
-       if (comment) {
 
-         if (ch === 0x0a || ch === 0x0d) {
 
-           comment = false;
 
-         }
 
-       } else if (ch === 0x25) {
 
-         comment = true;
 
-       } else if (!(0, _core_utils.isWhiteSpace)(ch)) {
 
-         break;
 
-       }
 
-       ch = this.nextChar();
 
-     }
 
-     switch (ch | 0) {
 
-       case 0x30:
 
-       case 0x31:
 
-       case 0x32:
 
-       case 0x33:
 
-       case 0x34:
 
-       case 0x35:
 
-       case 0x36:
 
-       case 0x37:
 
-       case 0x38:
 
-       case 0x39:
 
-       case 0x2b:
 
-       case 0x2d:
 
-       case 0x2e:
 
-         return new PostScriptToken(PostScriptTokenTypes.NUMBER, this.getNumber());
 
-       case 0x7b:
 
-         this.nextChar();
 
-         return PostScriptToken.LBRACE;
 
-       case 0x7d:
 
-         this.nextChar();
 
-         return PostScriptToken.RBRACE;
 
-     }
 
-     const strBuf = this.strBuf;
 
-     strBuf.length = 0;
 
-     strBuf[0] = String.fromCharCode(ch);
 
-     while ((ch = this.nextChar()) >= 0 && (ch >= 0x41 && ch <= 0x5a || ch >= 0x61 && ch <= 0x7a)) {
 
-       strBuf.push(String.fromCharCode(ch));
 
-     }
 
-     const str = strBuf.join("");
 
-     switch (str.toLowerCase()) {
 
-       case "if":
 
-         return PostScriptToken.IF;
 
-       case "ifelse":
 
-         return PostScriptToken.IFELSE;
 
-       default:
 
-         return PostScriptToken.getOperator(str);
 
-     }
 
-   }
 
-   getNumber() {
 
-     let ch = this.currentChar;
 
-     const strBuf = this.strBuf;
 
-     strBuf.length = 0;
 
-     strBuf[0] = String.fromCharCode(ch);
 
-     while ((ch = this.nextChar()) >= 0) {
 
-       if (ch >= 0x30 && ch <= 0x39 || ch === 0x2d || ch === 0x2e) {
 
-         strBuf.push(String.fromCharCode(ch));
 
-       } else {
 
-         break;
 
-       }
 
-     }
 
-     const value = parseFloat(strBuf.join(""));
 
-     if (isNaN(value)) {
 
-       throw new _util.FormatError(`Invalid floating point number: ${value}`);
 
-     }
 
-     return value;
 
-   }
 
- }
 
- exports.PostScriptLexer = PostScriptLexer;
 
- /***/ }),
 
- /* 41 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.MurmurHash3_64 = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- const SEED = 0xc3d2e1f0;
 
- const MASK_HIGH = 0xffff0000;
 
- const MASK_LOW = 0xffff;
 
- class MurmurHash3_64 {
 
-   constructor(seed) {
 
-     this.h1 = seed ? seed & 0xffffffff : SEED;
 
-     this.h2 = seed ? seed & 0xffffffff : SEED;
 
-   }
 
-   update(input) {
 
-     let data, length;
 
-     if ((0, _util.isString)(input)) {
 
-       data = new Uint8Array(input.length * 2);
 
-       length = 0;
 
-       for (let i = 0, ii = input.length; i < ii; i++) {
 
-         const code = input.charCodeAt(i);
 
-         if (code <= 0xff) {
 
-           data[length++] = code;
 
-         } else {
 
-           data[length++] = code >>> 8;
 
-           data[length++] = code & 0xff;
 
-         }
 
-       }
 
-     } else if ((0, _util.isArrayBuffer)(input)) {
 
-       data = input;
 
-       length = data.byteLength;
 
-     } else {
 
-       throw new Error("Wrong data format in MurmurHash3_64_update. " + "Input must be a string or array.");
 
-     }
 
-     const blockCounts = length >> 2;
 
-     const tailLength = length - blockCounts * 4;
 
-     const dataUint32 = new Uint32Array(data.buffer, 0, blockCounts);
 
-     let k1 = 0,
 
-         k2 = 0;
 
-     let h1 = this.h1,
 
-         h2 = this.h2;
 
-     const C1 = 0xcc9e2d51,
 
-           C2 = 0x1b873593;
 
-     const C1_LOW = C1 & MASK_LOW,
 
-           C2_LOW = C2 & MASK_LOW;
 
-     for (let i = 0; i < blockCounts; i++) {
 
-       if (i & 1) {
 
-         k1 = dataUint32[i];
 
-         k1 = k1 * C1 & MASK_HIGH | k1 * C1_LOW & MASK_LOW;
 
-         k1 = k1 << 15 | k1 >>> 17;
 
-         k1 = k1 * C2 & MASK_HIGH | k1 * C2_LOW & MASK_LOW;
 
-         h1 ^= k1;
 
-         h1 = h1 << 13 | h1 >>> 19;
 
-         h1 = h1 * 5 + 0xe6546b64;
 
-       } else {
 
-         k2 = dataUint32[i];
 
-         k2 = k2 * C1 & MASK_HIGH | k2 * C1_LOW & MASK_LOW;
 
-         k2 = k2 << 15 | k2 >>> 17;
 
-         k2 = k2 * C2 & MASK_HIGH | k2 * C2_LOW & MASK_LOW;
 
-         h2 ^= k2;
 
-         h2 = h2 << 13 | h2 >>> 19;
 
-         h2 = h2 * 5 + 0xe6546b64;
 
-       }
 
-     }
 
-     k1 = 0;
 
-     switch (tailLength) {
 
-       case 3:
 
-         k1 ^= data[blockCounts * 4 + 2] << 16;
 
-       case 2:
 
-         k1 ^= data[blockCounts * 4 + 1] << 8;
 
-       case 1:
 
-         k1 ^= data[blockCounts * 4];
 
-         k1 = k1 * C1 & MASK_HIGH | k1 * C1_LOW & MASK_LOW;
 
-         k1 = k1 << 15 | k1 >>> 17;
 
-         k1 = k1 * C2 & MASK_HIGH | k1 * C2_LOW & MASK_LOW;
 
-         if (blockCounts & 1) {
 
-           h1 ^= k1;
 
-         } else {
 
-           h2 ^= k1;
 
-         }
 
-     }
 
-     this.h1 = h1;
 
-     this.h2 = h2;
 
-   }
 
-   hexdigest() {
 
-     let h1 = this.h1,
 
-         h2 = this.h2;
 
-     h1 ^= h2 >>> 1;
 
-     h1 = h1 * 0xed558ccd & MASK_HIGH | h1 * 0x8ccd & MASK_LOW;
 
-     h2 = h2 * 0xff51afd7 & MASK_HIGH | ((h2 << 16 | h1 >>> 16) * 0xafd7ed55 & MASK_HIGH) >>> 16;
 
-     h1 ^= h2 >>> 1;
 
-     h1 = h1 * 0x1a85ec53 & MASK_HIGH | h1 * 0xec53 & MASK_LOW;
 
-     h2 = h2 * 0xc4ceb9fe & MASK_HIGH | ((h2 << 16 | h1 >>> 16) * 0xb9fe1a85 & MASK_HIGH) >>> 16;
 
-     h1 ^= h2 >>> 1;
 
-     const hex1 = (h1 >>> 0).toString(16),
 
-           hex2 = (h2 >>> 0).toString(16);
 
-     return hex1.padStart(8, "0") + hex2.padStart(8, "0");
 
-   }
 
- }
 
- exports.MurmurHash3_64 = MurmurHash3_64;
 
- /***/ }),
 
- /* 42 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.NativeImageDecoder = void 0;
 
- var _colorspace = __w_pdfjs_require__(22);
 
- var _jpeg_stream = __w_pdfjs_require__(17);
 
- var _stream = __w_pdfjs_require__(11);
 
- class NativeImageDecoder {
 
-   constructor({
 
-     xref,
 
-     resources,
 
-     handler,
 
-     forceDataSchema = false,
 
-     pdfFunctionFactory
 
-   }) {
 
-     this.xref = xref;
 
-     this.resources = resources;
 
-     this.handler = handler;
 
-     this.forceDataSchema = forceDataSchema;
 
-     this.pdfFunctionFactory = pdfFunctionFactory;
 
-   }
 
-   canDecode(image) {
 
-     return image instanceof _jpeg_stream.JpegStream && NativeImageDecoder.isDecodable(image, this.xref, this.resources, this.pdfFunctionFactory) && image.maybeValidDimensions;
 
-   }
 
-   decode(image) {
 
-     const dict = image.dict;
 
-     let colorSpace = dict.get("ColorSpace", "CS");
 
-     colorSpace = _colorspace.ColorSpace.parse(colorSpace, this.xref, this.resources, this.pdfFunctionFactory);
 
-     return this.handler.sendWithPromise("JpegDecode", [image.getIR(this.forceDataSchema), colorSpace.numComps]).then(function ({
 
-       data,
 
-       width,
 
-       height
 
-     }) {
 
-       return new _stream.Stream(data, 0, data.length, dict);
 
-     });
 
-   }
 
-   static isSupported(image, xref, res, pdfFunctionFactory) {
 
-     const dict = image.dict;
 
-     if (dict.has("DecodeParms") || dict.has("DP")) {
 
-       return false;
 
-     }
 
-     const cs = _colorspace.ColorSpace.parse(dict.get("ColorSpace", "CS"), xref, res, pdfFunctionFactory);
 
-     return (cs.name === "DeviceGray" || cs.name === "DeviceRGB") && cs.isDefaultDecode(dict.getArray("Decode", "D"));
 
-   }
 
-   static isDecodable(image, xref, res, pdfFunctionFactory) {
 
-     const dict = image.dict;
 
-     if (dict.has("DecodeParms") || dict.has("DP")) {
 
-       return false;
 
-     }
 
-     const cs = _colorspace.ColorSpace.parse(dict.get("ColorSpace", "CS"), xref, res, pdfFunctionFactory);
 
-     const bpc = dict.get("BitsPerComponent", "BPC") || 1;
 
-     return (cs.numComps === 1 || cs.numComps === 3) && cs.isDefaultDecode(dict.getArray("Decode", "D"), bpc);
 
-   }
 
- }
 
- exports.NativeImageDecoder = NativeImageDecoder;
 
- /***/ }),
 
- /* 43 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.PDFImage = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- var _primitives = __w_pdfjs_require__(4);
 
- var _colorspace = __w_pdfjs_require__(22);
 
- var _stream = __w_pdfjs_require__(11);
 
- var _jpeg_stream = __w_pdfjs_require__(17);
 
- var _jpx = __w_pdfjs_require__(20);
 
- var PDFImage = function PDFImageClosure() {
 
-   function handleImageData(image, nativeDecoder) {
 
-     if (nativeDecoder && nativeDecoder.canDecode(image)) {
 
-       return nativeDecoder.decode(image).catch(reason => {
 
-         (0, _util.warn)("Native image decoding failed -- trying to recover: " + (reason && reason.message));
 
-         return image;
 
-       });
 
-     }
 
-     return Promise.resolve(image);
 
-   }
 
-   function decodeAndClamp(value, addend, coefficient, max) {
 
-     value = addend + value * coefficient;
 
-     if (value < 0) {
 
-       value = 0;
 
-     } else if (value > max) {
 
-       value = max;
 
-     }
 
-     return value;
 
-   }
 
-   function resizeImageMask(src, bpc, w1, h1, w2, h2) {
 
-     var length = w2 * h2;
 
-     let dest;
 
-     if (bpc <= 8) {
 
-       dest = new Uint8Array(length);
 
-     } else if (bpc <= 16) {
 
-       dest = new Uint16Array(length);
 
-     } else {
 
-       dest = new Uint32Array(length);
 
-     }
 
-     var xRatio = w1 / w2;
 
-     var yRatio = h1 / h2;
 
-     var i,
 
-         j,
 
-         py,
 
-         newIndex = 0,
 
-         oldIndex;
 
-     var xScaled = new Uint16Array(w2);
 
-     var w1Scanline = w1;
 
-     for (i = 0; i < w2; i++) {
 
-       xScaled[i] = Math.floor(i * xRatio);
 
-     }
 
-     for (i = 0; i < h2; i++) {
 
-       py = Math.floor(i * yRatio) * w1Scanline;
 
-       for (j = 0; j < w2; j++) {
 
-         oldIndex = py + xScaled[j];
 
-         dest[newIndex++] = src[oldIndex];
 
-       }
 
-     }
 
-     return dest;
 
-   }
 
-   function PDFImage({
 
-     xref,
 
-     res,
 
-     image,
 
-     isInline = false,
 
-     smask = null,
 
-     mask = null,
 
-     isMask = false,
 
-     pdfFunctionFactory
 
-   }) {
 
-     this.image = image;
 
-     var dict = image.dict;
 
-     const filter = dict.get("Filter");
 
-     if ((0, _primitives.isName)(filter)) {
 
-       switch (filter.name) {
 
-         case "JPXDecode":
 
-           var jpxImage = new _jpx.JpxImage();
 
-           jpxImage.parseImageProperties(image.stream);
 
-           image.stream.reset();
 
-           image.width = jpxImage.width;
 
-           image.height = jpxImage.height;
 
-           image.bitsPerComponent = jpxImage.bitsPerComponent;
 
-           image.numComps = jpxImage.componentsCount;
 
-           break;
 
-         case "JBIG2Decode":
 
-           image.bitsPerComponent = 1;
 
-           image.numComps = 1;
 
-           break;
 
-       }
 
-     }
 
-     let width = dict.get("Width", "W");
 
-     let height = dict.get("Height", "H");
 
-     if (Number.isInteger(image.width) && image.width > 0 && Number.isInteger(image.height) && image.height > 0 && (image.width !== width || image.height !== height)) {
 
-       (0, _util.warn)("PDFImage - using the Width/Height of the image data, " + "rather than the image dictionary.");
 
-       width = image.width;
 
-       height = image.height;
 
-     }
 
-     if (width < 1 || height < 1) {
 
-       throw new _util.FormatError(`Invalid image width: ${width} or height: ${height}`);
 
-     }
 
-     this.width = width;
 
-     this.height = height;
 
-     this.interpolate = dict.get("Interpolate", "I") || false;
 
-     this.imageMask = dict.get("ImageMask", "IM") || false;
 
-     this.matte = dict.get("Matte") || false;
 
-     var bitsPerComponent = image.bitsPerComponent;
 
-     if (!bitsPerComponent) {
 
-       bitsPerComponent = dict.get("BitsPerComponent", "BPC");
 
-       if (!bitsPerComponent) {
 
-         if (this.imageMask) {
 
-           bitsPerComponent = 1;
 
-         } else {
 
-           throw new _util.FormatError(`Bits per component missing in image: ${this.imageMask}`);
 
-         }
 
-       }
 
-     }
 
-     this.bpc = bitsPerComponent;
 
-     if (!this.imageMask) {
 
-       var colorSpace = dict.get("ColorSpace", "CS");
 
-       if (!colorSpace) {
 
-         (0, _util.info)("JPX images (which do not require color spaces)");
 
-         switch (image.numComps) {
 
-           case 1:
 
-             colorSpace = _primitives.Name.get("DeviceGray");
 
-             break;
 
-           case 3:
 
-             colorSpace = _primitives.Name.get("DeviceRGB");
 
-             break;
 
-           case 4:
 
-             colorSpace = _primitives.Name.get("DeviceCMYK");
 
-             break;
 
-           default:
 
-             throw new Error(`JPX images with ${image.numComps} ` + "color components not supported.");
 
-         }
 
-       }
 
-       const resources = isInline ? res : null;
 
-       this.colorSpace = _colorspace.ColorSpace.parse(colorSpace, xref, resources, pdfFunctionFactory);
 
-       this.numComps = this.colorSpace.numComps;
 
-     }
 
-     this.decode = dict.getArray("Decode", "D");
 
-     this.needsDecode = false;
 
-     if (this.decode && (this.colorSpace && !this.colorSpace.isDefaultDecode(this.decode, bitsPerComponent) || isMask && !_colorspace.ColorSpace.isDefaultDecode(this.decode, 1))) {
 
-       this.needsDecode = true;
 
-       var max = (1 << bitsPerComponent) - 1;
 
-       this.decodeCoefficients = [];
 
-       this.decodeAddends = [];
 
-       const isIndexed = this.colorSpace && this.colorSpace.name === "Indexed";
 
-       for (var i = 0, j = 0; i < this.decode.length; i += 2, ++j) {
 
-         var dmin = this.decode[i];
 
-         var dmax = this.decode[i + 1];
 
-         this.decodeCoefficients[j] = isIndexed ? (dmax - dmin) / max : dmax - dmin;
 
-         this.decodeAddends[j] = isIndexed ? dmin : max * dmin;
 
-       }
 
-     }
 
-     if (smask) {
 
-       this.smask = new PDFImage({
 
-         xref,
 
-         res,
 
-         image: smask,
 
-         isInline,
 
-         pdfFunctionFactory
 
-       });
 
-     } else if (mask) {
 
-       if ((0, _primitives.isStream)(mask)) {
 
-         var maskDict = mask.dict,
 
-             imageMask = maskDict.get("ImageMask", "IM");
 
-         if (!imageMask) {
 
-           (0, _util.warn)("Ignoring /Mask in image without /ImageMask.");
 
-         } else {
 
-           this.mask = new PDFImage({
 
-             xref,
 
-             res,
 
-             image: mask,
 
-             isInline,
 
-             isMask: true,
 
-             pdfFunctionFactory
 
-           });
 
-         }
 
-       } else {
 
-         this.mask = mask;
 
-       }
 
-     }
 
-   }
 
-   PDFImage.buildImage = function ({
 
-     handler,
 
-     xref,
 
-     res,
 
-     image,
 
-     isInline = false,
 
-     nativeDecoder = null,
 
-     pdfFunctionFactory
 
-   }) {
 
-     var imagePromise = handleImageData(image, nativeDecoder);
 
-     var smaskPromise;
 
-     var maskPromise;
 
-     var smask = image.dict.get("SMask");
 
-     var mask = image.dict.get("Mask");
 
-     if (smask) {
 
-       smaskPromise = handleImageData(smask, nativeDecoder);
 
-       maskPromise = Promise.resolve(null);
 
-     } else {
 
-       smaskPromise = Promise.resolve(null);
 
-       if (mask) {
 
-         if ((0, _primitives.isStream)(mask)) {
 
-           maskPromise = handleImageData(mask, nativeDecoder);
 
-         } else if (Array.isArray(mask)) {
 
-           maskPromise = Promise.resolve(mask);
 
-         } else {
 
-           (0, _util.warn)("Unsupported mask format.");
 
-           maskPromise = Promise.resolve(null);
 
-         }
 
-       } else {
 
-         maskPromise = Promise.resolve(null);
 
-       }
 
-     }
 
-     return Promise.all([imagePromise, smaskPromise, maskPromise]).then(function ([imageData, smaskData, maskData]) {
 
-       return new PDFImage({
 
-         xref,
 
-         res,
 
-         image: imageData,
 
-         isInline,
 
-         smask: smaskData,
 
-         mask: maskData,
 
-         pdfFunctionFactory
 
-       });
 
-     });
 
-   };
 
-   PDFImage.createMask = function ({
 
-     imgArray,
 
-     width,
 
-     height,
 
-     imageIsFromDecodeStream,
 
-     inverseDecode
 
-   }) {
 
-     var computedLength = (width + 7 >> 3) * height;
 
-     var actualLength = imgArray.byteLength;
 
-     var haveFullData = computedLength === actualLength;
 
-     var data, i;
 
-     if (imageIsFromDecodeStream && (!inverseDecode || haveFullData)) {
 
-       data = imgArray;
 
-     } else if (!inverseDecode) {
 
-       data = new Uint8ClampedArray(actualLength);
 
-       data.set(imgArray);
 
-     } else {
 
-       data = new Uint8ClampedArray(computedLength);
 
-       data.set(imgArray);
 
-       for (i = actualLength; i < computedLength; i++) {
 
-         data[i] = 0xff;
 
-       }
 
-     }
 
-     if (inverseDecode) {
 
-       for (i = 0; i < actualLength; i++) {
 
-         data[i] ^= 0xff;
 
-       }
 
-     }
 
-     return {
 
-       data,
 
-       width,
 
-       height
 
-     };
 
-   };
 
-   PDFImage.prototype = {
 
-     get drawWidth() {
 
-       return Math.max(this.width, this.smask && this.smask.width || 0, this.mask && this.mask.width || 0);
 
-     },
 
-     get drawHeight() {
 
-       return Math.max(this.height, this.smask && this.smask.height || 0, this.mask && this.mask.height || 0);
 
-     },
 
-     decodeBuffer(buffer) {
 
-       var bpc = this.bpc;
 
-       var numComps = this.numComps;
 
-       var decodeAddends = this.decodeAddends;
 
-       var decodeCoefficients = this.decodeCoefficients;
 
-       var max = (1 << bpc) - 1;
 
-       var i, ii;
 
-       if (bpc === 1) {
 
-         for (i = 0, ii = buffer.length; i < ii; i++) {
 
-           buffer[i] = +!buffer[i];
 
-         }
 
-         return;
 
-       }
 
-       var index = 0;
 
-       for (i = 0, ii = this.width * this.height; i < ii; i++) {
 
-         for (var j = 0; j < numComps; j++) {
 
-           buffer[index] = decodeAndClamp(buffer[index], decodeAddends[j], decodeCoefficients[j], max);
 
-           index++;
 
-         }
 
-       }
 
-     },
 
-     getComponents(buffer) {
 
-       var bpc = this.bpc;
 
-       if (bpc === 8) {
 
-         return buffer;
 
-       }
 
-       var width = this.width;
 
-       var height = this.height;
 
-       var numComps = this.numComps;
 
-       var length = width * height * numComps;
 
-       var bufferPos = 0;
 
-       let output;
 
-       if (bpc <= 8) {
 
-         output = new Uint8Array(length);
 
-       } else if (bpc <= 16) {
 
-         output = new Uint16Array(length);
 
-       } else {
 
-         output = new Uint32Array(length);
 
-       }
 
-       var rowComps = width * numComps;
 
-       var max = (1 << bpc) - 1;
 
-       var i = 0,
 
-           ii,
 
-           buf;
 
-       if (bpc === 1) {
 
-         var mask, loop1End, loop2End;
 
-         for (var j = 0; j < height; j++) {
 
-           loop1End = i + (rowComps & ~7);
 
-           loop2End = i + rowComps;
 
-           while (i < loop1End) {
 
-             buf = buffer[bufferPos++];
 
-             output[i] = buf >> 7 & 1;
 
-             output[i + 1] = buf >> 6 & 1;
 
-             output[i + 2] = buf >> 5 & 1;
 
-             output[i + 3] = buf >> 4 & 1;
 
-             output[i + 4] = buf >> 3 & 1;
 
-             output[i + 5] = buf >> 2 & 1;
 
-             output[i + 6] = buf >> 1 & 1;
 
-             output[i + 7] = buf & 1;
 
-             i += 8;
 
-           }
 
-           if (i < loop2End) {
 
-             buf = buffer[bufferPos++];
 
-             mask = 128;
 
-             while (i < loop2End) {
 
-               output[i++] = +!!(buf & mask);
 
-               mask >>= 1;
 
-             }
 
-           }
 
-         }
 
-       } else {
 
-         var bits = 0;
 
-         buf = 0;
 
-         for (i = 0, ii = length; i < ii; ++i) {
 
-           if (i % rowComps === 0) {
 
-             buf = 0;
 
-             bits = 0;
 
-           }
 
-           while (bits < bpc) {
 
-             buf = buf << 8 | buffer[bufferPos++];
 
-             bits += 8;
 
-           }
 
-           var remainingBits = bits - bpc;
 
-           let value = buf >> remainingBits;
 
-           if (value < 0) {
 
-             value = 0;
 
-           } else if (value > max) {
 
-             value = max;
 
-           }
 
-           output[i] = value;
 
-           buf = buf & (1 << remainingBits) - 1;
 
-           bits = remainingBits;
 
-         }
 
-       }
 
-       return output;
 
-     },
 
-     fillOpacity(rgbaBuf, width, height, actualHeight, image) {
 
-       var smask = this.smask;
 
-       var mask = this.mask;
 
-       var alphaBuf, sw, sh, i, ii, j;
 
-       if (smask) {
 
-         sw = smask.width;
 
-         sh = smask.height;
 
-         alphaBuf = new Uint8ClampedArray(sw * sh);
 
-         smask.fillGrayBuffer(alphaBuf);
 
-         if (sw !== width || sh !== height) {
 
-           alphaBuf = resizeImageMask(alphaBuf, smask.bpc, sw, sh, width, height);
 
-         }
 
-       } else if (mask) {
 
-         if (mask instanceof PDFImage) {
 
-           sw = mask.width;
 
-           sh = mask.height;
 
-           alphaBuf = new Uint8ClampedArray(sw * sh);
 
-           mask.numComps = 1;
 
-           mask.fillGrayBuffer(alphaBuf);
 
-           for (i = 0, ii = sw * sh; i < ii; ++i) {
 
-             alphaBuf[i] = 255 - alphaBuf[i];
 
-           }
 
-           if (sw !== width || sh !== height) {
 
-             alphaBuf = resizeImageMask(alphaBuf, mask.bpc, sw, sh, width, height);
 
-           }
 
-         } else if (Array.isArray(mask)) {
 
-           alphaBuf = new Uint8ClampedArray(width * height);
 
-           var numComps = this.numComps;
 
-           for (i = 0, ii = width * height; i < ii; ++i) {
 
-             var opacity = 0;
 
-             var imageOffset = i * numComps;
 
-             for (j = 0; j < numComps; ++j) {
 
-               var color = image[imageOffset + j];
 
-               var maskOffset = j * 2;
 
-               if (color < mask[maskOffset] || color > mask[maskOffset + 1]) {
 
-                 opacity = 255;
 
-                 break;
 
-               }
 
-             }
 
-             alphaBuf[i] = opacity;
 
-           }
 
-         } else {
 
-           throw new _util.FormatError("Unknown mask format.");
 
-         }
 
-       }
 
-       if (alphaBuf) {
 
-         for (i = 0, j = 3, ii = width * actualHeight; i < ii; ++i, j += 4) {
 
-           rgbaBuf[j] = alphaBuf[i];
 
-         }
 
-       } else {
 
-         for (i = 0, j = 3, ii = width * actualHeight; i < ii; ++i, j += 4) {
 
-           rgbaBuf[j] = 255;
 
-         }
 
-       }
 
-     },
 
-     undoPreblend(buffer, width, height) {
 
-       var matte = this.smask && this.smask.matte;
 
-       if (!matte) {
 
-         return;
 
-       }
 
-       var matteRgb = this.colorSpace.getRgb(matte, 0);
 
-       var matteR = matteRgb[0];
 
-       var matteG = matteRgb[1];
 
-       var matteB = matteRgb[2];
 
-       var length = width * height * 4;
 
-       for (var i = 0; i < length; i += 4) {
 
-         var alpha = buffer[i + 3];
 
-         if (alpha === 0) {
 
-           buffer[i] = 255;
 
-           buffer[i + 1] = 255;
 
-           buffer[i + 2] = 255;
 
-           continue;
 
-         }
 
-         var k = 255 / alpha;
 
-         buffer[i] = (buffer[i] - matteR) * k + matteR;
 
-         buffer[i + 1] = (buffer[i + 1] - matteG) * k + matteG;
 
-         buffer[i + 2] = (buffer[i + 2] - matteB) * k + matteB;
 
-       }
 
-     },
 
-     createImageData(forceRGBA = false) {
 
-       var drawWidth = this.drawWidth;
 
-       var drawHeight = this.drawHeight;
 
-       var imgData = {
 
-         width: drawWidth,
 
-         height: drawHeight,
 
-         kind: 0,
 
-         data: null
 
-       };
 
-       var numComps = this.numComps;
 
-       var originalWidth = this.width;
 
-       var originalHeight = this.height;
 
-       var bpc = this.bpc;
 
-       var rowBytes = originalWidth * numComps * bpc + 7 >> 3;
 
-       var imgArray;
 
-       if (!forceRGBA) {
 
-         var kind;
 
-         if (this.colorSpace.name === "DeviceGray" && bpc === 1) {
 
-           kind = _util.ImageKind.GRAYSCALE_1BPP;
 
-         } else if (this.colorSpace.name === "DeviceRGB" && bpc === 8 && !this.needsDecode) {
 
-           kind = _util.ImageKind.RGB_24BPP;
 
-         }
 
-         if (kind && !this.smask && !this.mask && drawWidth === originalWidth && drawHeight === originalHeight) {
 
-           imgData.kind = kind;
 
-           imgArray = this.getImageBytes(originalHeight * rowBytes);
 
-           if (this.image instanceof _stream.DecodeStream) {
 
-             imgData.data = imgArray;
 
-           } else {
 
-             var newArray = new Uint8ClampedArray(imgArray.length);
 
-             newArray.set(imgArray);
 
-             imgData.data = newArray;
 
-           }
 
-           if (this.needsDecode) {
 
-             (0, _util.assert)(kind === _util.ImageKind.GRAYSCALE_1BPP, "PDFImage.createImageData: The image must be grayscale.");
 
-             var buffer = imgData.data;
 
-             for (var i = 0, ii = buffer.length; i < ii; i++) {
 
-               buffer[i] ^= 0xff;
 
-             }
 
-           }
 
-           return imgData;
 
-         }
 
-         if (this.image instanceof _jpeg_stream.JpegStream && !this.smask && !this.mask) {
 
-           let imageLength = originalHeight * rowBytes;
 
-           switch (this.colorSpace.name) {
 
-             case "DeviceGray":
 
-               imageLength *= 3;
 
-             case "DeviceRGB":
 
-             case "DeviceCMYK":
 
-               imgData.kind = _util.ImageKind.RGB_24BPP;
 
-               imgData.data = this.getImageBytes(imageLength, drawWidth, drawHeight, true);
 
-               return imgData;
 
-           }
 
-         }
 
-       }
 
-       imgArray = this.getImageBytes(originalHeight * rowBytes);
 
-       var actualHeight = 0 | imgArray.length / rowBytes * drawHeight / originalHeight;
 
-       var comps = this.getComponents(imgArray);
 
-       var alpha01, maybeUndoPreblend;
 
-       if (!forceRGBA && !this.smask && !this.mask) {
 
-         imgData.kind = _util.ImageKind.RGB_24BPP;
 
-         imgData.data = new Uint8ClampedArray(drawWidth * drawHeight * 3);
 
-         alpha01 = 0;
 
-         maybeUndoPreblend = false;
 
-       } else {
 
-         imgData.kind = _util.ImageKind.RGBA_32BPP;
 
-         imgData.data = new Uint8ClampedArray(drawWidth * drawHeight * 4);
 
-         alpha01 = 1;
 
-         maybeUndoPreblend = true;
 
-         this.fillOpacity(imgData.data, drawWidth, drawHeight, actualHeight, comps);
 
-       }
 
-       if (this.needsDecode) {
 
-         this.decodeBuffer(comps);
 
-       }
 
-       this.colorSpace.fillRgb(imgData.data, originalWidth, originalHeight, drawWidth, drawHeight, actualHeight, bpc, comps, alpha01);
 
-       if (maybeUndoPreblend) {
 
-         this.undoPreblend(imgData.data, drawWidth, actualHeight);
 
-       }
 
-       return imgData;
 
-     },
 
-     fillGrayBuffer(buffer) {
 
-       var numComps = this.numComps;
 
-       if (numComps !== 1) {
 
-         throw new _util.FormatError(`Reading gray scale from a color image: ${numComps}`);
 
-       }
 
-       var width = this.width;
 
-       var height = this.height;
 
-       var bpc = this.bpc;
 
-       var rowBytes = width * numComps * bpc + 7 >> 3;
 
-       var imgArray = this.getImageBytes(height * rowBytes);
 
-       var comps = this.getComponents(imgArray);
 
-       var i, length;
 
-       if (bpc === 1) {
 
-         length = width * height;
 
-         if (this.needsDecode) {
 
-           for (i = 0; i < length; ++i) {
 
-             buffer[i] = comps[i] - 1 & 255;
 
-           }
 
-         } else {
 
-           for (i = 0; i < length; ++i) {
 
-             buffer[i] = -comps[i] & 255;
 
-           }
 
-         }
 
-         return;
 
-       }
 
-       if (this.needsDecode) {
 
-         this.decodeBuffer(comps);
 
-       }
 
-       length = width * height;
 
-       var scale = 255 / ((1 << bpc) - 1);
 
-       for (i = 0; i < length; ++i) {
 
-         buffer[i] = scale * comps[i];
 
-       }
 
-     },
 
-     getImageBytes(length, drawWidth, drawHeight, forceRGB = false) {
 
-       this.image.reset();
 
-       this.image.drawWidth = drawWidth || this.width;
 
-       this.image.drawHeight = drawHeight || this.height;
 
-       this.image.forceRGB = !!forceRGB;
 
-       return this.image.getBytes(length, true);
 
-     }
 
-   };
 
-   return PDFImage;
 
- }();
 
- exports.PDFImage = PDFImage;
 
- /***/ }),
 
- /* 44 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.isNodeJS = void 0;
 
- const isNodeJS = typeof process === "object" && process + "" === "[object process]" && !process.versions["nw"] && !process.versions["electron"];
 
- exports.isNodeJS = isNodeJS;
 
- /***/ }),
 
- /* 45 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.MessageHandler = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- const CallbackKind = {
 
-   UNKNOWN: 0,
 
-   DATA: 1,
 
-   ERROR: 2
 
- };
 
- const StreamKind = {
 
-   UNKNOWN: 0,
 
-   CANCEL: 1,
 
-   CANCEL_COMPLETE: 2,
 
-   CLOSE: 3,
 
-   ENQUEUE: 4,
 
-   ERROR: 5,
 
-   PULL: 6,
 
-   PULL_COMPLETE: 7,
 
-   START_COMPLETE: 8
 
- };
 
- function wrapReason(reason) {
 
-   if (typeof reason !== "object" || reason === null) {
 
-     return reason;
 
-   }
 
-   switch (reason.name) {
 
-     case "AbortException":
 
-       return new _util.AbortException(reason.message);
 
-     case "MissingPDFException":
 
-       return new _util.MissingPDFException(reason.message);
 
-     case "UnexpectedResponseException":
 
-       return new _util.UnexpectedResponseException(reason.message, reason.status);
 
-     case "UnknownErrorException":
 
-       return new _util.UnknownErrorException(reason.message, reason.details);
 
-     default:
 
-       return new _util.UnknownErrorException(reason.message, reason.toString());
 
-   }
 
- }
 
- class MessageHandler {
 
-   constructor(sourceName, targetName, comObj) {
 
-     this.sourceName = sourceName;
 
-     this.targetName = targetName;
 
-     this.comObj = comObj;
 
-     this.callbackId = 1;
 
-     this.streamId = 1;
 
-     this.postMessageTransfers = true;
 
-     this.streamSinks = Object.create(null);
 
-     this.streamControllers = Object.create(null);
 
-     this.callbackCapabilities = Object.create(null);
 
-     this.actionHandler = Object.create(null);
 
-     this._onComObjOnMessage = event => {
 
-       const data = event.data;
 
-       if (data.targetName !== this.sourceName) {
 
-         return;
 
-       }
 
-       if (data.stream) {
 
-         this._processStreamMessage(data);
 
-         return;
 
-       }
 
-       if (data.callback) {
 
-         const callbackId = data.callbackId;
 
-         const capability = this.callbackCapabilities[callbackId];
 
-         if (!capability) {
 
-           throw new Error(`Cannot resolve callback ${callbackId}`);
 
-         }
 
-         delete this.callbackCapabilities[callbackId];
 
-         if (data.callback === CallbackKind.DATA) {
 
-           capability.resolve(data.data);
 
-         } else if (data.callback === CallbackKind.ERROR) {
 
-           capability.reject(wrapReason(data.reason));
 
-         } else {
 
-           throw new Error("Unexpected callback case");
 
-         }
 
-         return;
 
-       }
 
-       const action = this.actionHandler[data.action];
 
-       if (!action) {
 
-         throw new Error(`Unknown action from worker: ${data.action}`);
 
-       }
 
-       if (data.callbackId) {
 
-         const sourceName = this.sourceName;
 
-         const targetName = data.sourceName;
 
-         new Promise(function (resolve) {
 
-           resolve(action(data.data));
 
-         }).then(function (result) {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             callback: CallbackKind.DATA,
 
-             callbackId: data.callbackId,
 
-             data: result
 
-           });
 
-         }, function (reason) {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             callback: CallbackKind.ERROR,
 
-             callbackId: data.callbackId,
 
-             reason: wrapReason(reason)
 
-           });
 
-         });
 
-         return;
 
-       }
 
-       if (data.streamId) {
 
-         this._createStreamSink(data);
 
-         return;
 
-       }
 
-       action(data.data);
 
-     };
 
-     comObj.addEventListener("message", this._onComObjOnMessage);
 
-   }
 
-   on(actionName, handler) {
 
-     const ah = this.actionHandler;
 
-     if (ah[actionName]) {
 
-       throw new Error(`There is already an actionName called "${actionName}"`);
 
-     }
 
-     ah[actionName] = handler;
 
-   }
 
-   send(actionName, data, transfers) {
 
-     this._postMessage({
 
-       sourceName: this.sourceName,
 
-       targetName: this.targetName,
 
-       action: actionName,
 
-       data
 
-     }, transfers);
 
-   }
 
-   sendWithPromise(actionName, data, transfers) {
 
-     const callbackId = this.callbackId++;
 
-     const capability = (0, _util.createPromiseCapability)();
 
-     this.callbackCapabilities[callbackId] = capability;
 
-     try {
 
-       this._postMessage({
 
-         sourceName: this.sourceName,
 
-         targetName: this.targetName,
 
-         action: actionName,
 
-         callbackId,
 
-         data
 
-       }, transfers);
 
-     } catch (ex) {
 
-       capability.reject(ex);
 
-     }
 
-     return capability.promise;
 
-   }
 
-   sendWithStream(actionName, data, queueingStrategy, transfers) {
 
-     const streamId = this.streamId++;
 
-     const sourceName = this.sourceName;
 
-     const targetName = this.targetName;
 
-     const comObj = this.comObj;
 
-     return new ReadableStream({
 
-       start: controller => {
 
-         const startCapability = (0, _util.createPromiseCapability)();
 
-         this.streamControllers[streamId] = {
 
-           controller,
 
-           startCall: startCapability,
 
-           pullCall: null,
 
-           cancelCall: null,
 
-           isClosed: false
 
-         };
 
-         this._postMessage({
 
-           sourceName,
 
-           targetName,
 
-           action: actionName,
 
-           streamId,
 
-           data,
 
-           desiredSize: controller.desiredSize
 
-         }, transfers);
 
-         return startCapability.promise;
 
-       },
 
-       pull: controller => {
 
-         const pullCapability = (0, _util.createPromiseCapability)();
 
-         this.streamControllers[streamId].pullCall = pullCapability;
 
-         comObj.postMessage({
 
-           sourceName,
 
-           targetName,
 
-           stream: StreamKind.PULL,
 
-           streamId,
 
-           desiredSize: controller.desiredSize
 
-         });
 
-         return pullCapability.promise;
 
-       },
 
-       cancel: reason => {
 
-         (0, _util.assert)(reason instanceof Error, "cancel must have a valid reason");
 
-         const cancelCapability = (0, _util.createPromiseCapability)();
 
-         this.streamControllers[streamId].cancelCall = cancelCapability;
 
-         this.streamControllers[streamId].isClosed = true;
 
-         comObj.postMessage({
 
-           sourceName,
 
-           targetName,
 
-           stream: StreamKind.CANCEL,
 
-           streamId,
 
-           reason: wrapReason(reason)
 
-         });
 
-         return cancelCapability.promise;
 
-       }
 
-     }, queueingStrategy);
 
-   }
 
-   _createStreamSink(data) {
 
-     const self = this;
 
-     const action = this.actionHandler[data.action];
 
-     const streamId = data.streamId;
 
-     const sourceName = this.sourceName;
 
-     const targetName = data.sourceName;
 
-     const comObj = this.comObj;
 
-     const streamSink = {
 
-       enqueue(chunk, size = 1, transfers) {
 
-         if (this.isCancelled) {
 
-           return;
 
-         }
 
-         const lastDesiredSize = this.desiredSize;
 
-         this.desiredSize -= size;
 
-         if (lastDesiredSize > 0 && this.desiredSize <= 0) {
 
-           this.sinkCapability = (0, _util.createPromiseCapability)();
 
-           this.ready = this.sinkCapability.promise;
 
-         }
 
-         self._postMessage({
 
-           sourceName,
 
-           targetName,
 
-           stream: StreamKind.ENQUEUE,
 
-           streamId,
 
-           chunk
 
-         }, transfers);
 
-       },
 
-       close() {
 
-         if (this.isCancelled) {
 
-           return;
 
-         }
 
-         this.isCancelled = true;
 
-         comObj.postMessage({
 
-           sourceName,
 
-           targetName,
 
-           stream: StreamKind.CLOSE,
 
-           streamId
 
-         });
 
-         delete self.streamSinks[streamId];
 
-       },
 
-       error(reason) {
 
-         (0, _util.assert)(reason instanceof Error, "error must have a valid reason");
 
-         if (this.isCancelled) {
 
-           return;
 
-         }
 
-         this.isCancelled = true;
 
-         comObj.postMessage({
 
-           sourceName,
 
-           targetName,
 
-           stream: StreamKind.ERROR,
 
-           streamId,
 
-           reason: wrapReason(reason)
 
-         });
 
-       },
 
-       sinkCapability: (0, _util.createPromiseCapability)(),
 
-       onPull: null,
 
-       onCancel: null,
 
-       isCancelled: false,
 
-       desiredSize: data.desiredSize,
 
-       ready: null
 
-     };
 
-     streamSink.sinkCapability.resolve();
 
-     streamSink.ready = streamSink.sinkCapability.promise;
 
-     this.streamSinks[streamId] = streamSink;
 
-     new Promise(function (resolve) {
 
-       resolve(action(data.data, streamSink));
 
-     }).then(function () {
 
-       comObj.postMessage({
 
-         sourceName,
 
-         targetName,
 
-         stream: StreamKind.START_COMPLETE,
 
-         streamId,
 
-         success: true
 
-       });
 
-     }, function (reason) {
 
-       comObj.postMessage({
 
-         sourceName,
 
-         targetName,
 
-         stream: StreamKind.START_COMPLETE,
 
-         streamId,
 
-         reason: wrapReason(reason)
 
-       });
 
-     });
 
-   }
 
-   _processStreamMessage(data) {
 
-     const streamId = data.streamId;
 
-     const sourceName = this.sourceName;
 
-     const targetName = data.sourceName;
 
-     const comObj = this.comObj;
 
-     switch (data.stream) {
 
-       case StreamKind.START_COMPLETE:
 
-         if (data.success) {
 
-           this.streamControllers[streamId].startCall.resolve();
 
-         } else {
 
-           this.streamControllers[streamId].startCall.reject(wrapReason(data.reason));
 
-         }
 
-         break;
 
-       case StreamKind.PULL_COMPLETE:
 
-         if (data.success) {
 
-           this.streamControllers[streamId].pullCall.resolve();
 
-         } else {
 
-           this.streamControllers[streamId].pullCall.reject(wrapReason(data.reason));
 
-         }
 
-         break;
 
-       case StreamKind.PULL:
 
-         if (!this.streamSinks[streamId]) {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             stream: StreamKind.PULL_COMPLETE,
 
-             streamId,
 
-             success: true
 
-           });
 
-           break;
 
-         }
 
-         if (this.streamSinks[streamId].desiredSize <= 0 && data.desiredSize > 0) {
 
-           this.streamSinks[streamId].sinkCapability.resolve();
 
-         }
 
-         this.streamSinks[streamId].desiredSize = data.desiredSize;
 
-         const {
 
-           onPull
 
-         } = this.streamSinks[data.streamId];
 
-         new Promise(function (resolve) {
 
-           resolve(onPull && onPull());
 
-         }).then(function () {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             stream: StreamKind.PULL_COMPLETE,
 
-             streamId,
 
-             success: true
 
-           });
 
-         }, function (reason) {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             stream: StreamKind.PULL_COMPLETE,
 
-             streamId,
 
-             reason: wrapReason(reason)
 
-           });
 
-         });
 
-         break;
 
-       case StreamKind.ENQUEUE:
 
-         (0, _util.assert)(this.streamControllers[streamId], "enqueue should have stream controller");
 
-         if (this.streamControllers[streamId].isClosed) {
 
-           break;
 
-         }
 
-         this.streamControllers[streamId].controller.enqueue(data.chunk);
 
-         break;
 
-       case StreamKind.CLOSE:
 
-         (0, _util.assert)(this.streamControllers[streamId], "close should have stream controller");
 
-         if (this.streamControllers[streamId].isClosed) {
 
-           break;
 
-         }
 
-         this.streamControllers[streamId].isClosed = true;
 
-         this.streamControllers[streamId].controller.close();
 
-         this._deleteStreamController(streamId);
 
-         break;
 
-       case StreamKind.ERROR:
 
-         (0, _util.assert)(this.streamControllers[streamId], "error should have stream controller");
 
-         this.streamControllers[streamId].controller.error(wrapReason(data.reason));
 
-         this._deleteStreamController(streamId);
 
-         break;
 
-       case StreamKind.CANCEL_COMPLETE:
 
-         if (data.success) {
 
-           this.streamControllers[streamId].cancelCall.resolve();
 
-         } else {
 
-           this.streamControllers[streamId].cancelCall.reject(wrapReason(data.reason));
 
-         }
 
-         this._deleteStreamController(streamId);
 
-         break;
 
-       case StreamKind.CANCEL:
 
-         if (!this.streamSinks[streamId]) {
 
-           break;
 
-         }
 
-         const {
 
-           onCancel
 
-         } = this.streamSinks[data.streamId];
 
-         new Promise(function (resolve) {
 
-           resolve(onCancel && onCancel(wrapReason(data.reason)));
 
-         }).then(function () {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             stream: StreamKind.CANCEL_COMPLETE,
 
-             streamId,
 
-             success: true
 
-           });
 
-         }, function (reason) {
 
-           comObj.postMessage({
 
-             sourceName,
 
-             targetName,
 
-             stream: StreamKind.CANCEL_COMPLETE,
 
-             streamId,
 
-             reason: wrapReason(reason)
 
-           });
 
-         });
 
-         this.streamSinks[streamId].sinkCapability.reject(wrapReason(data.reason));
 
-         this.streamSinks[streamId].isCancelled = true;
 
-         delete this.streamSinks[streamId];
 
-         break;
 
-       default:
 
-         throw new Error("Unexpected stream case");
 
-     }
 
-   }
 
-   async _deleteStreamController(streamId) {
 
-     await Promise.allSettled([this.streamControllers[streamId].startCall, this.streamControllers[streamId].pullCall, this.streamControllers[streamId].cancelCall].map(function (capability) {
 
-       return capability && capability.promise;
 
-     }));
 
-     delete this.streamControllers[streamId];
 
-   }
 
-   _postMessage(message, transfers) {
 
-     if (transfers && this.postMessageTransfers) {
 
-       this.comObj.postMessage(message, transfers);
 
-     } else {
 
-       this.comObj.postMessage(message);
 
-     }
 
-   }
 
-   destroy() {
 
-     this.comObj.removeEventListener("message", this._onComObjOnMessage);
 
-   }
 
- }
 
- exports.MessageHandler = MessageHandler;
 
- /***/ }),
 
- /* 46 */
 
- /***/ (function(module, exports, __w_pdfjs_require__) {
 
- "use strict";
 
- Object.defineProperty(exports, "__esModule", {
 
-   value: true
 
- });
 
- exports.PDFWorkerStream = void 0;
 
- var _util = __w_pdfjs_require__(2);
 
- class PDFWorkerStream {
 
-   constructor(msgHandler) {
 
-     this._msgHandler = msgHandler;
 
-     this._contentLength = null;
 
-     this._fullRequestReader = null;
 
-     this._rangeRequestReaders = [];
 
-   }
 
-   getFullReader() {
 
-     (0, _util.assert)(!this._fullRequestReader);
 
-     this._fullRequestReader = new PDFWorkerStreamReader(this._msgHandler);
 
-     return this._fullRequestReader;
 
-   }
 
-   getRangeReader(begin, end) {
 
-     const reader = new PDFWorkerStreamRangeReader(begin, end, this._msgHandler);
 
-     this._rangeRequestReaders.push(reader);
 
-     return reader;
 
-   }
 
-   cancelAllRequests(reason) {
 
-     if (this._fullRequestReader) {
 
-       this._fullRequestReader.cancel(reason);
 
-     }
 
-     const readers = this._rangeRequestReaders.slice(0);
 
-     readers.forEach(function (reader) {
 
-       reader.cancel(reason);
 
-     });
 
-   }
 
- }
 
- exports.PDFWorkerStream = PDFWorkerStream;
 
- class PDFWorkerStreamReader {
 
-   constructor(msgHandler) {
 
-     this._msgHandler = msgHandler;
 
-     this.onProgress = null;
 
-     this._contentLength = null;
 
-     this._isRangeSupported = false;
 
-     this._isStreamingSupported = false;
 
-     const readableStream = this._msgHandler.sendWithStream("GetReader");
 
-     this._reader = readableStream.getReader();
 
-     this._headersReady = this._msgHandler.sendWithPromise("ReaderHeadersReady").then(data => {
 
-       this._isStreamingSupported = data.isStreamingSupported;
 
-       this._isRangeSupported = data.isRangeSupported;
 
-       this._contentLength = data.contentLength;
 
-     });
 
-   }
 
-   get headersReady() {
 
-     return this._headersReady;
 
-   }
 
-   get contentLength() {
 
-     return this._contentLength;
 
-   }
 
-   get isStreamingSupported() {
 
-     return this._isStreamingSupported;
 
-   }
 
-   get isRangeSupported() {
 
-     return this._isRangeSupported;
 
-   }
 
-   async read() {
 
-     const {
 
-       value,
 
-       done
 
-     } = await this._reader.read();
 
-     if (done) {
 
-       return {
 
-         value: undefined,
 
-         done: true
 
-       };
 
-     }
 
-     return {
 
-       value: value.buffer,
 
-       done: false
 
-     };
 
-   }
 
-   cancel(reason) {
 
-     this._reader.cancel(reason);
 
-   }
 
- }
 
- class PDFWorkerStreamRangeReader {
 
-   constructor(begin, end, msgHandler) {
 
-     this._msgHandler = msgHandler;
 
-     this.onProgress = null;
 
-     const readableStream = this._msgHandler.sendWithStream("GetRangeReader", {
 
-       begin,
 
-       end
 
-     });
 
-     this._reader = readableStream.getReader();
 
-   }
 
-   get isStreamingSupported() {
 
-     return false;
 
-   }
 
-   async read() {
 
-     const {
 
-       value,
 
-       done
 
-     } = await this._reader.read();
 
-     if (done) {
 
-       return {
 
-         value: undefined,
 
-         done: true
 
-       };
 
-     }
 
-     return {
 
-       value: value.buffer,
 
-       done: false
 
-     };
 
-   }
 
-   cancel(reason) {
 
-     this._reader.cancel(reason);
 
-   }
 
- }
 
- /***/ })
 
- /******/ ]);
 
- });
 
- //# sourceMappingURL=pdf.worker.js.map
 
 
  |