ohm.js 683 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853
  1. (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.ohm = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
  2. var ohm = require('..');
  3. module.exports = ohm.makeRecipe(["grammar",{"source":"BuiltInRules {\n\n alnum (an alpha-numeric character)\n = letter\n | digit\n\n letter (a letter)\n = lower\n | upper\n | unicodeLtmo\n\n digit (a digit)\n = \"0\"..\"9\"\n\n hexDigit (a hexadecimal digit)\n = digit\n | \"a\"..\"f\"\n | \"A\"..\"F\"\n\n ListOf<elem, sep>\n = NonemptyListOf<elem, sep>\n | EmptyListOf<elem, sep>\n\n NonemptyListOf<elem, sep>\n = elem (sep elem)*\n\n EmptyListOf<elem, sep>\n = /* nothing */\n\n listOf<elem, sep>\n = nonemptyListOf<elem, sep>\n | emptyListOf<elem, sep>\n\n nonemptyListOf<elem, sep>\n = elem (sep elem)*\n\n emptyListOf<elem, sep>\n = /* nothing */\n\n}"},"BuiltInRules",null,null,{"alnum":["define",{"sourceInterval":[18,78]},"an alpha-numeric character",[],["alt",{"sourceInterval":[60,78]},["app",{"sourceInterval":[60,66]},"letter",[]],["app",{"sourceInterval":[73,78]},"digit",[]]]],"letter":["define",{"sourceInterval":[82,142]},"a letter",[],["alt",{"sourceInterval":[107,142]},["app",{"sourceInterval":[107,112]},"lower",[]],["app",{"sourceInterval":[119,124]},"upper",[]],["app",{"sourceInterval":[131,142]},"unicodeLtmo",[]]]],"digit":["define",{"sourceInterval":[146,177]},"a digit",[],["range",{"sourceInterval":[169,177]},"0","9"]],"hexDigit":["define",{"sourceInterval":[181,254]},"a hexadecimal digit",[],["alt",{"sourceInterval":[219,254]},["app",{"sourceInterval":[219,224]},"digit",[]],["range",{"sourceInterval":[231,239]},"a","f"],["range",{"sourceInterval":[246,254]},"A","F"]]],"ListOf":["define",{"sourceInterval":[258,336]},null,["elem","sep"],["alt",{"sourceInterval":[282,336]},["app",{"sourceInterval":[282,307]},"NonemptyListOf",[["param",{},0],["param",{},1]]],["app",{"sourceInterval":[314,336]},"EmptyListOf",[["param",{},0],["param",{},1]]]]],"NonemptyListOf":["define",{"sourceInterval":[340,388]},null,["elem","sep"],["seq",{"sourceInterval":[372,388]},["param",{},0],["star",{"sourceInterval":[377,388]},["seq",{"sourceInterval":[378,386]},["param",{},1],["param",{},0]]]]],"EmptyListOf":["define",{"sourceInterval":[392,434]},null,["elem","sep"],["seq",{"sourceInterval":[438,438]}]],"listOf":["define",{"sourceInterval":[438,516]},null,["elem","sep"],["alt",{"sourceInterval":[462,516]},["app",{"sourceInterval":[462,487]},"nonemptyListOf",[["param",{},0],["param",{},1]]],["app",{"sourceInterval":[494,516]},"emptyListOf",[["param",{},0],["param",{},1]]]]],"nonemptyListOf":["define",{"sourceInterval":[520,568]},null,["elem","sep"],["seq",{"sourceInterval":[552,568]},["param",{},0],["star",{"sourceInterval":[557,568]},["seq",{"sourceInterval":[558,566]},["param",{},1],["param",{},0]]]]],"emptyListOf":["define",{"sourceInterval":[572,614]},null,["elem","sep"],["seq",{"sourceInterval":[616,616]}]]}]);
  4. },{"..":46}],2:[function(require,module,exports){
  5. var ohm = require('..');
  6. module.exports = ohm.makeRecipe(["grammar",{"source":"Ohm {\n\n Grammars\n = Grammar*\n\n Grammar\n = ident SuperGrammar? \"{\" Rule* \"}\"\n\n SuperGrammar\n = \"<:\" ident\n\n Rule\n = ident Formals? ruleDescr? \"=\" RuleBody -- define\n | ident Formals? \":=\" RuleBody -- override\n | ident Formals? \"+=\" RuleBody -- extend\n\n RuleBody\n = \"|\"? NonemptyListOf<TopLevelTerm, \"|\">\n\n TopLevelTerm\n = Seq caseName -- inline\n | Seq\n\n Formals\n = \"<\" ListOf<ident, \",\"> \">\"\n\n Params\n = \"<\" ListOf<Seq, \",\"> \">\"\n\n Alt\n = NonemptyListOf<Seq, \"|\">\n\n Seq\n = Iter*\n\n Iter\n = Pred \"*\" -- star\n | Pred \"+\" -- plus\n | Pred \"?\" -- opt\n | Pred\n\n Pred\n = \"~\" Lex -- not\n | \"&\" Lex -- lookahead\n | Lex\n\n Lex\n = \"#\" Base -- lex\n | Base\n\n Base\n = ident Params? ~(ruleDescr? \"=\" | \":=\" | \"+=\") -- application\n | oneCharTerminal \"..\" oneCharTerminal -- range\n | terminal -- terminal\n | \"(\" Alt \")\" -- paren\n\n ruleDescr (a rule description)\n = \"(\" ruleDescrText \")\"\n\n ruleDescrText\n = (~\")\" any)*\n\n caseName\n = \"--\" (~\"\\n\" space)* name (~\"\\n\" space)* (\"\\n\" | &\"}\")\n\n name (a name)\n = nameFirst nameRest*\n\n nameFirst\n = \"_\"\n | letter\n\n nameRest\n = \"_\"\n | alnum\n\n ident (an identifier)\n = name\n\n terminal\n = \"\\\"\" terminalChar* \"\\\"\"\n\n oneCharTerminal\n = \"\\\"\" terminalChar \"\\\"\"\n\n terminalChar\n = escapeChar\n | ~\"\\\\\" ~\"\\\"\" ~\"\\n\" any\n\n escapeChar (an escape sequence)\n = \"\\\\\\\\\" -- backslash\n | \"\\\\\\\"\" -- doubleQuote\n | \"\\\\\\'\" -- singleQuote\n | \"\\\\b\" -- backspace\n | \"\\\\n\" -- lineFeed\n | \"\\\\r\" -- carriageReturn\n | \"\\\\t\" -- tab\n | \"\\\\u\" hexDigit hexDigit hexDigit hexDigit -- unicodeEscape\n | \"\\\\x\" hexDigit hexDigit -- hexEscape\n\n space\n += comment\n\n comment\n = \"//\" (~\"\\n\" any)* \"\\n\" -- singleLine\n | \"/*\" (~\"*/\" any)* \"*/\" -- multiLine\n\n tokens = token*\n\n token = caseName | comment | ident | operator | punctuation | terminal | any\n\n operator = \"<:\" | \"=\" | \":=\" | \"+=\" | \"*\" | \"+\" | \"?\" | \"~\" | \"&\"\n\n punctuation = \"<\" | \">\" | \",\" | \"--\"\n}"},"Ohm",null,"Grammars",{"Grammars":["define",{"sourceInterval":[9,32]},null,[],["star",{"sourceInterval":[24,32]},["app",{"sourceInterval":[24,31]},"Grammar",[]]]],"Grammar":["define",{"sourceInterval":[36,83]},null,[],["seq",{"sourceInterval":[50,83]},["app",{"sourceInterval":[50,55]},"ident",[]],["opt",{"sourceInterval":[56,69]},["app",{"sourceInterval":[56,68]},"SuperGrammar",[]]],["terminal",{"sourceInterval":[70,73]},"{"],["star",{"sourceInterval":[74,79]},["app",{"sourceInterval":[74,78]},"Rule",[]]],["terminal",{"sourceInterval":[80,83]},"}"]]],"SuperGrammar":["define",{"sourceInterval":[87,116]},null,[],["seq",{"sourceInterval":[106,116]},["terminal",{"sourceInterval":[106,110]},"<:"],["app",{"sourceInterval":[111,116]},"ident",[]]]],"Rule_define":["define",{"sourceInterval":[131,181]},null,[],["seq",{"sourceInterval":[131,170]},["app",{"sourceInterval":[131,136]},"ident",[]],["opt",{"sourceInterval":[137,145]},["app",{"sourceInterval":[137,144]},"Formals",[]]],["opt",{"sourceInterval":[146,156]},["app",{"sourceInterval":[146,155]},"ruleDescr",[]]],["terminal",{"sourceInterval":[157,160]},"="],["app",{"sourceInterval":[162,170]},"RuleBody",[]]]],"Rule_override":["define",{"sourceInterval":[188,240]},null,[],["seq",{"sourceInterval":[188,227]},["app",{"sourceInterval":[188,193]},"ident",[]],["opt",{"sourceInterval":[194,202]},["app",{"sourceInterval":[194,201]},"Formals",[]]],["terminal",{"sourceInterval":[214,218]},":="],["app",{"sourceInterval":[219,227]},"RuleBody",[]]]],"Rule_extend":["define",{"sourceInterval":[247,297]},null,[],["seq",{"sourceInterval":[247,286]},["app",{"sourceInterval":[247,252]},"ident",[]],["opt",{"sourceInterval":[253,261]},["app",{"sourceInterval":[253,260]},"Formals",[]]],["terminal",{"sourceInterval":[273,277]},"+="],["app",{"sourceInterval":[278,286]},"RuleBody",[]]]],"Rule":["define",{"sourceInterval":[120,297]},null,[],["alt",{"sourceInterval":[131,297]},["app",{"sourceInterval":[131,170]},"Rule_define",[]],["app",{"sourceInterval":[188,227]},"Rule_override",[]],["app",{"sourceInterval":[247,286]},"Rule_extend",[]]]],"RuleBody":["define",{"sourceInterval":[301,354]},null,[],["seq",{"sourceInterval":[316,354]},["opt",{"sourceInterval":[316,320]},["terminal",{"sourceInterval":[316,319]},"|"]],["app",{"sourceInterval":[321,354]},"NonemptyListOf",[["app",{"sourceInterval":[336,348]},"TopLevelTerm",[]],["terminal",{"sourceInterval":[350,353]},"|"]]]]],"TopLevelTerm_inline":["define",{"sourceInterval":[377,400]},null,[],["seq",{"sourceInterval":[377,389]},["app",{"sourceInterval":[377,380]},"Seq",[]],["app",{"sourceInterval":[381,389]},"caseName",[]]]],"TopLevelTerm":["define",{"sourceInterval":[358,410]},null,[],["alt",{"sourceInterval":[377,410]},["app",{"sourceInterval":[377,389]},"TopLevelTerm_inline",[]],["app",{"sourceInterval":[407,410]},"Seq",[]]]],"Formals":["define",{"sourceInterval":[414,454]},null,[],["seq",{"sourceInterval":[428,454]},["terminal",{"sourceInterval":[428,431]},"<"],["app",{"sourceInterval":[432,450]},"ListOf",[["app",{"sourceInterval":[439,444]},"ident",[]],["terminal",{"sourceInterval":[446,449]},","]]],["terminal",{"sourceInterval":[451,454]},">"]]],"Params":["define",{"sourceInterval":[458,495]},null,[],["seq",{"sourceInterval":[471,495]},["terminal",{"sourceInterval":[471,474]},"<"],["app",{"sourceInterval":[475,491]},"ListOf",[["app",{"sourceInterval":[482,485]},"Seq",[]],["terminal",{"sourceInterval":[487,490]},","]]],["terminal",{"sourceInterval":[492,495]},">"]]],"Alt":["define",{"sourceInterval":[499,533]},null,[],["app",{"sourceInterval":[509,533]},"NonemptyListOf",[["app",{"sourceInterval":[524,527]},"Seq",[]],["terminal",{"sourceInterval":[529,532]},"|"]]]],"Seq":["define",{"sourceInterval":[537,552]},null,[],["star",{"sourceInterval":[547,552]},["app",{"sourceInterval":[547,551]},"Iter",[]]]],"Iter_star":["define",{"sourceInterval":[567,584]},null,[],["seq",{"sourceInterval":[567,575]},["app",{"sourceInterval":[567,571]},"Pred",[]],["terminal",{"sourceInterval":[572,575]},"*"]]],"Iter_plus":["define",{"sourceInterval":[591,608]},null,[],["seq",{"sourceInterval":[591,599]},["app",{"sourceInterval":[591,595]},"Pred",[]],["terminal",{"sourceInterval":[596,599]},"+"]]],"Iter_opt":["define",{"sourceInterval":[615,631]},null,[],["seq",{"sourceInterval":[615,623]},["app",{"sourceInterval":[615,619]},"Pred",[]],["terminal",{"sourceInterval":[620,623]},"?"]]],"Iter":["define",{"sourceInterval":[556,642]},null,[],["alt",{"sourceInterval":[567,642]},["app",{"sourceInterval":[567,575]},"Iter_star",[]],["app",{"sourceInterval":[591,599]},"Iter_plus",[]],["app",{"sourceInterval":[615,623]},"Iter_opt",[]],["app",{"sourceInterval":[638,642]},"Pred",[]]]],"Pred_not":["define",{"sourceInterval":[657,672]},null,[],["seq",{"sourceInterval":[657,664]},["terminal",{"sourceInterval":[657,660]},"~"],["app",{"sourceInterval":[661,664]},"Lex",[]]]],"Pred_lookahead":["define",{"sourceInterval":[679,700]},null,[],["seq",{"sourceInterval":[679,686]},["terminal",{"sourceInterval":[679,682]},"&"],["app",{"sourceInterval":[683,686]},"Lex",[]]]],"Pred":["define",{"sourceInterval":[646,710]},null,[],["alt",{"sourceInterval":[657,710]},["app",{"sourceInterval":[657,664]},"Pred_not",[]],["app",{"sourceInterval":[679,686]},"Pred_lookahead",[]],["app",{"sourceInterval":[707,710]},"Lex",[]]]],"Lex_lex":["define",{"sourceInterval":[724,740]},null,[],["seq",{"sourceInterval":[724,732]},["terminal",{"sourceInterval":[724,727]},"#"],["app",{"sourceInterval":[728,732]},"Base",[]]]],"Lex":["define",{"sourceInterval":[714,751]},null,[],["alt",{"sourceInterval":[724,751]},["app",{"sourceInterval":[724,732]},"Lex_lex",[]],["app",{"sourceInterval":[747,751]},"Base",[]]]],"Base_application":["define",{"sourceInterval":[766,827]},null,[],["seq",{"sourceInterval":[766,811]},["app",{"sourceInterval":[766,771]},"ident",[]],["opt",{"sourceInterval":[772,779]},["app",{"sourceInterval":[772,778]},"Params",[]]],["not",{"sourceInterval":[780,811]},["alt",{"sourceInterval":[782,810]},["seq",{"sourceInterval":[782,796]},["opt",{"sourceInterval":[782,792]},["app",{"sourceInterval":[782,791]},"ruleDescr",[]]],["terminal",{"sourceInterval":[793,796]},"="]],["terminal",{"sourceInterval":[799,803]},":="],["terminal",{"sourceInterval":[806,810]},"+="]]]]],"Base_range":["define",{"sourceInterval":[834,889]},null,[],["seq",{"sourceInterval":[834,870]},["app",{"sourceInterval":[834,849]},"oneCharTerminal",[]],["terminal",{"sourceInterval":[850,854]},".."],["app",{"sourceInterval":[855,870]},"oneCharTerminal",[]]]],"Base_terminal":["define",{"sourceInterval":[896,954]},null,[],["app",{"sourceInterval":[896,904]},"terminal",[]]],"Base_paren":["define",{"sourceInterval":[961,1016]},null,[],["seq",{"sourceInterval":[961,972]},["terminal",{"sourceInterval":[961,964]},"("],["app",{"sourceInterval":[965,968]},"Alt",[]],["terminal",{"sourceInterval":[969,972]},")"]]],"Base":["define",{"sourceInterval":[755,1016]},null,[],["alt",{"sourceInterval":[766,1016]},["app",{"sourceInterval":[766,811]},"Base_application",[]],["app",{"sourceInterval":[834,870]},"Base_range",[]],["app",{"sourceInterval":[896,904]},"Base_terminal",[]],["app",{"sourceInterval":[961,972]},"Base_paren",[]]]],"ruleDescr":["define",{"sourceInterval":[1020,1079]},"a rule description",[],["seq",{"sourceInterval":[1058,1079]},["terminal",{"sourceInterval":[1058,1061]},"("],["app",{"sourceInterval":[1062,1075]},"ruleDescrText",[]],["terminal",{"sourceInterval":[1076,1079]},")"]]],"ruleDescrText":["define",{"sourceInterval":[1083,1114]},null,[],["star",{"sourceInterval":[1103,1114]},["seq",{"sourceInterval":[1104,1112]},["not",{"sourceInterval":[1104,1108]},["terminal",{"sourceInterval":[1105,1108]},")"]],["app",{"sourceInterval":[1109,1112]},"any",[]]]]],"caseName":["define",{"sourceInterval":[1118,1186]},null,[],["seq",{"sourceInterval":[1133,1186]},["terminal",{"sourceInterval":[1133,1137]},"--"],["star",{"sourceInterval":[1138,1152]},["seq",{"sourceInterval":[1139,1150]},["not",{"sourceInterval":[1139,1144]},["terminal",{"sourceInterval":[1140,1144]},"\n"]],["app",{"sourceInterval":[1145,1150]},"space",[]]]],["app",{"sourceInterval":[1153,1157]},"name",[]],["star",{"sourceInterval":[1158,1172]},["seq",{"sourceInterval":[1159,1170]},["not",{"sourceInterval":[1159,1164]},["terminal",{"sourceInterval":[1160,1164]},"\n"]],["app",{"sourceInterval":[1165,1170]},"space",[]]]],["alt",{"sourceInterval":[1174,1185]},["terminal",{"sourceInterval":[1174,1178]},"\n"],["lookahead",{"sourceInterval":[1181,1185]},["terminal",{"sourceInterval":[1182,1185]},"}"]]]]],"name":["define",{"sourceInterval":[1190,1230]},"a name",[],["seq",{"sourceInterval":[1211,1230]},["app",{"sourceInterval":[1211,1220]},"nameFirst",[]],["star",{"sourceInterval":[1221,1230]},["app",{"sourceInterval":[1221,1229]},"nameRest",[]]]]],"nameFirst":["define",{"sourceInterval":[1234,1266]},null,[],["alt",{"sourceInterval":[1250,1266]},["terminal",{"sourceInterval":[1250,1253]},"_"],["app",{"sourceInterval":[1260,1266]},"letter",[]]]],"nameRest":["define",{"sourceInterval":[1270,1300]},null,[],["alt",{"sourceInterval":[1285,1300]},["terminal",{"sourceInterval":[1285,1288]},"_"],["app",{"sourceInterval":[1295,1300]},"alnum",[]]]],"ident":["define",{"sourceInterval":[1304,1337]},"an identifier",[],["app",{"sourceInterval":[1333,1337]},"name",[]]],"terminal":["define",{"sourceInterval":[1341,1379]},null,[],["seq",{"sourceInterval":[1356,1379]},["terminal",{"sourceInterval":[1356,1360]},"\""],["star",{"sourceInterval":[1361,1374]},["app",{"sourceInterval":[1361,1373]},"terminalChar",[]]],["terminal",{"sourceInterval":[1375,1379]},"\""]]],"oneCharTerminal":["define",{"sourceInterval":[1383,1427]},null,[],["seq",{"sourceInterval":[1405,1427]},["terminal",{"sourceInterval":[1405,1409]},"\""],["app",{"sourceInterval":[1410,1422]},"terminalChar",[]],["terminal",{"sourceInterval":[1423,1427]},"\""]]],"terminalChar":["define",{"sourceInterval":[1431,1488]},null,[],["alt",{"sourceInterval":[1450,1488]},["app",{"sourceInterval":[1450,1460]},"escapeChar",[]],["seq",{"sourceInterval":[1467,1488]},["not",{"sourceInterval":[1467,1472]},["terminal",{"sourceInterval":[1468,1472]},"\\"]],["not",{"sourceInterval":[1473,1478]},["terminal",{"sourceInterval":[1474,1478]},"\""]],["not",{"sourceInterval":[1479,1484]},["terminal",{"sourceInterval":[1480,1484]},"\n"]],["app",{"sourceInterval":[1485,1488]},"any",[]]]]],"escapeChar_backslash":["define",{"sourceInterval":[1531,1586]},null,[],["terminal",{"sourceInterval":[1531,1537]},"\\\\"]],"escapeChar_doubleQuote":["define",{"sourceInterval":[1593,1650]},null,[],["terminal",{"sourceInterval":[1593,1599]},"\\\""]],"escapeChar_singleQuote":["define",{"sourceInterval":[1657,1714]},null,[],["terminal",{"sourceInterval":[1657,1663]},"\\'"]],"escapeChar_backspace":["define",{"sourceInterval":[1721,1776]},null,[],["terminal",{"sourceInterval":[1721,1726]},"\\b"]],"escapeChar_lineFeed":["define",{"sourceInterval":[1783,1837]},null,[],["terminal",{"sourceInterval":[1783,1788]},"\\n"]],"escapeChar_carriageReturn":["define",{"sourceInterval":[1844,1904]},null,[],["terminal",{"sourceInterval":[1844,1849]},"\\r"]],"escapeChar_tab":["define",{"sourceInterval":[1911,1960]},null,[],["terminal",{"sourceInterval":[1911,1916]},"\\t"]],"escapeChar_unicodeEscape":["define",{"sourceInterval":[1967,2026]},null,[],["seq",{"sourceInterval":[1967,2008]},["terminal",{"sourceInterval":[1967,1972]},"\\u"],["app",{"sourceInterval":[1973,1981]},"hexDigit",[]],["app",{"sourceInterval":[1982,1990]},"hexDigit",[]],["app",{"sourceInterval":[1991,1999]},"hexDigit",[]],["app",{"sourceInterval":[2000,2008]},"hexDigit",[]]]],"escapeChar_hexEscape":["define",{"sourceInterval":[2033,2088]},null,[],["seq",{"sourceInterval":[2033,2056]},["terminal",{"sourceInterval":[2033,2038]},"\\x"],["app",{"sourceInterval":[2039,2047]},"hexDigit",[]],["app",{"sourceInterval":[2048,2056]},"hexDigit",[]]]],"escapeChar":["define",{"sourceInterval":[1492,2088]},"an escape sequence",[],["alt",{"sourceInterval":[1531,2088]},["app",{"sourceInterval":[1531,1537]},"escapeChar_backslash",[]],["app",{"sourceInterval":[1593,1599]},"escapeChar_doubleQuote",[]],["app",{"sourceInterval":[1657,1663]},"escapeChar_singleQuote",[]],["app",{"sourceInterval":[1721,1726]},"escapeChar_backspace",[]],["app",{"sourceInterval":[1783,1788]},"escapeChar_lineFeed",[]],["app",{"sourceInterval":[1844,1849]},"escapeChar_carriageReturn",[]],["app",{"sourceInterval":[1911,1916]},"escapeChar_tab",[]],["app",{"sourceInterval":[1967,2008]},"escapeChar_unicodeEscape",[]],["app",{"sourceInterval":[2033,2056]},"escapeChar_hexEscape",[]]]],"space":["extend",{"sourceInterval":[2092,2111]},null,[],["app",{"sourceInterval":[2104,2111]},"comment",[]]],"comment_singleLine":["define",{"sourceInterval":[2129,2166]},null,[],["seq",{"sourceInterval":[2129,2151]},["terminal",{"sourceInterval":[2129,2133]},"//"],["star",{"sourceInterval":[2134,2146]},["seq",{"sourceInterval":[2135,2144]},["not",{"sourceInterval":[2135,2140]},["terminal",{"sourceInterval":[2136,2140]},"\n"]],["app",{"sourceInterval":[2141,2144]},"any",[]]]],["terminal",{"sourceInterval":[2147,2151]},"\n"]]],"comment_multiLine":["define",{"sourceInterval":[2173,2209]},null,[],["seq",{"sourceInterval":[2173,2195]},["terminal",{"sourceInterval":[2173,2177]},"/*"],["star",{"sourceInterval":[2178,2190]},["seq",{"sourceInterval":[2179,2188]},["not",{"sourceInterval":[2179,2184]},["terminal",{"sourceInterval":[2180,2184]},"*/"]],["app",{"sourceInterval":[2185,2188]},"any",[]]]],["terminal",{"sourceInterval":[2191,2195]},"*/"]]],"comment":["define",{"sourceInterval":[2115,2209]},null,[],["alt",{"sourceInterval":[2129,2209]},["app",{"sourceInterval":[2129,2151]},"comment_singleLine",[]],["app",{"sourceInterval":[2173,2195]},"comment_multiLine",[]]]],"tokens":["define",{"sourceInterval":[2213,2228]},null,[],["star",{"sourceInterval":[2222,2228]},["app",{"sourceInterval":[2222,2227]},"token",[]]]],"token":["define",{"sourceInterval":[2232,2308]},null,[],["alt",{"sourceInterval":[2240,2308]},["app",{"sourceInterval":[2240,2248]},"caseName",[]],["app",{"sourceInterval":[2251,2258]},"comment",[]],["app",{"sourceInterval":[2261,2266]},"ident",[]],["app",{"sourceInterval":[2269,2277]},"operator",[]],["app",{"sourceInterval":[2280,2291]},"punctuation",[]],["app",{"sourceInterval":[2294,2302]},"terminal",[]],["app",{"sourceInterval":[2305,2308]},"any",[]]]],"operator":["define",{"sourceInterval":[2312,2377]},null,[],["alt",{"sourceInterval":[2323,2377]},["terminal",{"sourceInterval":[2323,2327]},"<:"],["terminal",{"sourceInterval":[2330,2333]},"="],["terminal",{"sourceInterval":[2336,2340]},":="],["terminal",{"sourceInterval":[2343,2347]},"+="],["terminal",{"sourceInterval":[2350,2353]},"*"],["terminal",{"sourceInterval":[2356,2359]},"+"],["terminal",{"sourceInterval":[2362,2365]},"?"],["terminal",{"sourceInterval":[2368,2371]},"~"],["terminal",{"sourceInterval":[2374,2377]},"&"]]],"punctuation":["define",{"sourceInterval":[2381,2417]},null,[],["alt",{"sourceInterval":[2395,2417]},["terminal",{"sourceInterval":[2395,2398]},"<"],["terminal",{"sourceInterval":[2401,2404]},">"],["terminal",{"sourceInterval":[2407,2410]},","],["terminal",{"sourceInterval":[2413,2417]},"--"]]]}]);
  7. },{"..":46}],3:[function(require,module,exports){
  8. var ohm = require('..');
  9. module.exports = ohm.makeRecipe(["grammar",{"source":"OperationsAndAttributes {\n\n AttributeSignature =\n name\n\n OperationSignature =\n name Formals?\n\n Formals\n = \"(\" ListOf<name, \",\"> \")\"\n\n name (a name)\n = nameFirst nameRest*\n\n nameFirst\n = \"_\"\n | letter\n\n nameRest\n = \"_\"\n | alnum\n\n}"},"OperationsAndAttributes",null,"AttributeSignature",{"AttributeSignature":["define",{"sourceInterval":[29,58]},null,[],["app",{"sourceInterval":[54,58]},"name",[]]],"OperationSignature":["define",{"sourceInterval":[62,100]},null,[],["seq",{"sourceInterval":[87,100]},["app",{"sourceInterval":[87,91]},"name",[]],["opt",{"sourceInterval":[92,100]},["app",{"sourceInterval":[92,99]},"Formals",[]]]]],"Formals":["define",{"sourceInterval":[104,143]},null,[],["seq",{"sourceInterval":[118,143]},["terminal",{"sourceInterval":[118,121]},"("],["app",{"sourceInterval":[122,139]},"ListOf",[["app",{"sourceInterval":[129,133]},"name",[]],["terminal",{"sourceInterval":[135,138]},","]]],["terminal",{"sourceInterval":[140,143]},")"]]],"name":["define",{"sourceInterval":[147,187]},"a name",[],["seq",{"sourceInterval":[168,187]},["app",{"sourceInterval":[168,177]},"nameFirst",[]],["star",{"sourceInterval":[178,187]},["app",{"sourceInterval":[178,186]},"nameRest",[]]]]],"nameFirst":["define",{"sourceInterval":[191,223]},null,[],["alt",{"sourceInterval":[207,223]},["terminal",{"sourceInterval":[207,210]},"_"],["app",{"sourceInterval":[217,223]},"letter",[]]]],"nameRest":["define",{"sourceInterval":[227,257]},null,[],["alt",{"sourceInterval":[242,257]},["terminal",{"sourceInterval":[242,245]},"_"],["app",{"sourceInterval":[252,257]},"alnum",[]]]]}]);
  10. },{"..":46}],4:[function(require,module,exports){
  11. 'use strict';
  12. // --------------------------------------------------------------------
  13. // Imports
  14. // --------------------------------------------------------------------
  15. var assert = require('../src/common').assert;
  16. // --------------------------------------------------------------------
  17. // Private stuff
  18. // --------------------------------------------------------------------
  19. // Helpers
  20. function getProp(name, thing, fn) {
  21. return fn(thing[name]);
  22. }
  23. function mapProp(name, thing, fn) {
  24. return thing[name].map(fn);
  25. }
  26. // Returns a function that will walk a single property of a node.
  27. // `descriptor` is a string indicating the property name, optionally ending
  28. // with '[]' (e.g., 'children[]').
  29. function getPropWalkFn(descriptor) {
  30. var parts = descriptor.split(/ ?\[\]/);
  31. if (parts.length === 2) {
  32. return mapProp.bind(null, parts[0]);
  33. }
  34. return getProp.bind(null, descriptor);
  35. }
  36. function getProps(walkFns, thing, fn) {
  37. return walkFns.map(function(walkFn) {
  38. return walkFn(thing, fn);
  39. });
  40. }
  41. function getWalkFn(shape) {
  42. if (typeof shape === 'string') {
  43. return getProps.bind(null, [getPropWalkFn(shape)]);
  44. } else if (Array.isArray(shape)) {
  45. return getProps.bind(null, shape.map(getPropWalkFn));
  46. } else {
  47. assert(typeof shape === 'function', 'Expected a string, Array, or function');
  48. assert(shape.length === 2, 'Expected a function of arity 2, got ' + shape.length);
  49. return shape;
  50. }
  51. }
  52. function isRestrictedIdentifier(str) {
  53. return /^[a-zA-Z_][0-9a-zA-Z_]*$/.test(str);
  54. }
  55. function trim(s) {
  56. return s.trim();
  57. }
  58. function parseSignature(sig) {
  59. var parts = sig.split(/[()]/).map(trim);
  60. if (parts.length === 3 && parts[2] === '') {
  61. var name = parts[0];
  62. var params = [];
  63. if (parts[1].length > 0) {
  64. params = parts[1].split(',').map(trim);
  65. }
  66. if (isRestrictedIdentifier(name) && params.every(isRestrictedIdentifier)) {
  67. return {name: name, formals: params};
  68. }
  69. }
  70. throw new Error('Invalid operation signature: ' + sig);
  71. }
  72. /*
  73. A VisitorFamily contains a set of recursive operations that are defined over some kind of
  74. tree structure. The `config` parameter specifies how to walk the tree:
  75. - 'getTag' is function which, given a node in the tree, returns the node's 'tag' (type)
  76. - 'shapes' an object that maps from a tag to a value that describes how to recursively
  77. evaluate the operation for nodes of that type. The value can be:
  78. * a string indicating the property name that holds that node's only child
  79. * an Array of property names (or an empty array indicating a leaf type), or
  80. * a function taking two arguments (node, fn), and returning an Array which is the result
  81. of apply `fn` to each of the node's children.
  82. */
  83. function VisitorFamily(config) {
  84. this._shapes = config.shapes;
  85. this._getTag = config.getTag;
  86. this.Adapter = function(thing, family) {
  87. this._adaptee = thing;
  88. this._family = family;
  89. };
  90. this.Adapter.prototype.valueOf = function() {
  91. throw new Error('heeey!');
  92. };
  93. this.operations = {};
  94. this._arities = Object.create(null);
  95. this._getChildren = Object.create(null);
  96. var self = this;
  97. Object.keys(this._shapes).forEach(function(k) {
  98. var shape = self._shapes[k];
  99. self._getChildren[k] = getWalkFn(shape);
  100. // A function means the arity isn't fixed, so don't put an entry in the arity map.
  101. if (typeof shape !== 'function') {
  102. self._arities[k] = Array.isArray(shape) ? shape.length : 1;
  103. }
  104. });
  105. this._wrap = function(thing) { return new self.Adapter(thing, self); };
  106. }
  107. VisitorFamily.prototype.wrap = function(thing) {
  108. return this._wrap(thing);
  109. };
  110. VisitorFamily.prototype._checkActionDict = function(dict) {
  111. var self = this;
  112. Object.keys(dict).forEach(function(k) {
  113. assert(k in self._getChildren, "Unrecognized action name '" + k + "'");
  114. var action = dict[k];
  115. assert(typeof action === 'function', "Key '" + k + "': expected function, got " + action);
  116. if (k in self._arities) {
  117. var expected = self._arities[k];
  118. var actual = dict[k].length;
  119. assert(actual === expected,
  120. "Action '" + k + "' has the wrong arity: expected " + expected + ', got ' + actual);
  121. }
  122. });
  123. };
  124. VisitorFamily.prototype.addOperation = function(signature, actions) {
  125. var sig = parseSignature(signature);
  126. var name = sig.name;
  127. this._checkActionDict(actions);
  128. this.operations[name] = {
  129. name: name,
  130. formals: sig.formals,
  131. actions: actions
  132. };
  133. var family = this;
  134. this.Adapter.prototype[name] = function() {
  135. var tag = family._getTag(this._adaptee);
  136. assert(tag in family._getChildren, "getTag returned unrecognized tag '" + tag + "'");
  137. assert(tag in actions, "No action for '" + tag + "' in operation '" + name + "'");
  138. // Create an "arguments object" from the arguments that were passed to this
  139. // operation / attribute.
  140. var args = Object.create(null);
  141. for (var i = 0; i < arguments.length; i++) {
  142. args[sig.formals[i]] = arguments[i];
  143. }
  144. var oldArgs = this.args;
  145. this.args = args;
  146. var ans = actions[tag].apply(this, family._getChildren[tag](this._adaptee, family._wrap));
  147. this.args = oldArgs;
  148. return ans;
  149. };
  150. return this;
  151. };
  152. // --------------------------------------------------------------------
  153. // Exports
  154. // --------------------------------------------------------------------
  155. module.exports = VisitorFamily;
  156. },{"../src/common":44}],5:[function(require,module,exports){
  157. 'use strict';
  158. module.exports = {
  159. VisitorFamily: require('./VisitorFamily'),
  160. semanticsForToAST: require('./semantics-toAST').semantics,
  161. toAST: require('./semantics-toAST').helper
  162. };
  163. },{"./VisitorFamily":4,"./semantics-toAST":6}],6:[function(require,module,exports){
  164. 'use strict';
  165. // --------------------------------------------------------------------
  166. // Imports
  167. // --------------------------------------------------------------------
  168. var pexprs = require('../src/pexprs');
  169. var MatchResult = require('../src/MatchResult');
  170. var Grammar = require('../src/Grammar');
  171. var extend = require('util-extend');
  172. // --------------------------------------------------------------------
  173. // Operations
  174. // --------------------------------------------------------------------
  175. var defaultOperation = {
  176. _terminal: function() {
  177. return this.primitiveValue;
  178. },
  179. _nonterminal: function(children) {
  180. var ctorName = this._node.ctorName;
  181. var mapping = this.args.mapping;
  182. // without customization
  183. if (!mapping.hasOwnProperty(ctorName)) {
  184. // intermediate node
  185. if (this._node instanceof pexprs.Alt || this._node instanceof pexprs.Apply) {
  186. return children[0].toAST(mapping);
  187. }
  188. // lexical rule
  189. if (this.isLexical()) {
  190. return this.sourceString;
  191. }
  192. // singular node (e.g. only surrounded by literals or lookaheads)
  193. var realChildren = children.filter(function(child) {
  194. return !child.isTerminal();
  195. });
  196. if (realChildren.length === 1) {
  197. return realChildren[0].toAST(mapping);
  198. }
  199. // rest: terms with multiple children
  200. }
  201. // direct forward
  202. if (typeof mapping[ctorName] === 'number') {
  203. return children[mapping[ctorName]].toAST(mapping);
  204. }
  205. // named/mapped children or unnamed children ('0', '1', '2', ...)
  206. var propMap = mapping[ctorName] || children;
  207. var node = {
  208. type: ctorName
  209. };
  210. for (var prop in propMap) {
  211. var mappedProp = mapping[ctorName] && mapping[ctorName][prop];
  212. if (typeof mappedProp === 'number') {
  213. // direct forward
  214. node[prop] = children[mappedProp].toAST(mapping);
  215. } else if ((typeof mappedProp === 'string') || (typeof mappedProp === 'boolean') ||
  216. (mappedProp === null)) {
  217. // primitive value
  218. node[prop] = mappedProp;
  219. } else if ((typeof mappedProp === 'object') && (mappedProp instanceof Number)) {
  220. // primitive number (must be unboxed)
  221. node[prop] = Number(mappedProp);
  222. } else if (typeof mappedProp === 'function') {
  223. // computed value
  224. node[prop] = mappedProp.call(this, children);
  225. } else if (mappedProp === undefined) {
  226. if (children[prop] && !children[prop].isTerminal()) {
  227. node[prop] = children[prop].toAST(mapping);
  228. } else {
  229. // delete predefined 'type' properties, like 'type', if explicitely removed
  230. delete node[prop];
  231. }
  232. }
  233. }
  234. return node;
  235. },
  236. _iter: function(children) {
  237. if (this._node.isOptional()) {
  238. if (this.numChildren === 0) {
  239. return null;
  240. } else {
  241. return children[0].toAST(this.args.mapping);
  242. }
  243. }
  244. return children.map(function(child) {
  245. return child.toAST(this.args.mapping);
  246. }, this);
  247. },
  248. NonemptyListOf: function(first, sep, rest) {
  249. return [first.toAST(this.args.mapping)].concat(rest.toAST(this.args.mapping));
  250. },
  251. EmptyListOf: function() {
  252. return [];
  253. }
  254. };
  255. // Returns a plain JavaScript object that includes an abstract syntax tree (AST)
  256. // for the given match result `res` containg a concrete syntax tree (CST) and grammar.
  257. // The optional `mapping` parameter can be used to customize how the nodes of the CST
  258. // are mapped to the AST (see /doc/extras.md#toastmatchresult-mapping).
  259. function toAST(res, mapping) {
  260. if (!(res instanceof MatchResult) || res.failed()) {
  261. throw new Error('toAST() expects a succesfull MatchResult as first parameter');
  262. }
  263. mapping = extend({}, mapping);
  264. var operation = extend({}, defaultOperation);
  265. for (var termName in mapping) {
  266. if (typeof mapping[termName] === 'function') {
  267. operation[termName] = mapping[termName];
  268. delete mapping[termName];
  269. }
  270. }
  271. var g = res._cst.grammar;
  272. var s = g.createSemantics().addOperation('toAST(mapping)', operation);
  273. return s(res).toAST(mapping);
  274. }
  275. // Returns a semantics containg the toAST(mapping) operation for the given grammar g.
  276. function semanticsForToAST(g) {
  277. if (!(g instanceof Grammar)) {
  278. throw new Error('semanticsToAST() expects a Grammar as parameter');
  279. }
  280. return g.createSemantics().addOperation('toAST(mapping)', defaultOperation);
  281. }
  282. module.exports = {
  283. helper: toAST,
  284. semantics: semanticsForToAST
  285. };
  286. },{"../src/Grammar":33,"../src/MatchResult":37,"../src/pexprs":64,"util-extend":29}],7:[function(require,module,exports){
  287. 'use strict';
  288. var assign = require('es5-ext/object/assign')
  289. , normalizeOpts = require('es5-ext/object/normalize-options')
  290. , isCallable = require('es5-ext/object/is-callable')
  291. , contains = require('es5-ext/string/#/contains')
  292. , d;
  293. d = module.exports = function (dscr, value/*, options*/) {
  294. var c, e, w, options, desc;
  295. if ((arguments.length < 2) || (typeof dscr !== 'string')) {
  296. options = value;
  297. value = dscr;
  298. dscr = null;
  299. } else {
  300. options = arguments[2];
  301. }
  302. if (dscr == null) {
  303. c = w = true;
  304. e = false;
  305. } else {
  306. c = contains.call(dscr, 'c');
  307. e = contains.call(dscr, 'e');
  308. w = contains.call(dscr, 'w');
  309. }
  310. desc = { value: value, configurable: c, enumerable: e, writable: w };
  311. return !options ? desc : assign(normalizeOpts(options), desc);
  312. };
  313. d.gs = function (dscr, get, set/*, options*/) {
  314. var c, e, options, desc;
  315. if (typeof dscr !== 'string') {
  316. options = set;
  317. set = get;
  318. get = dscr;
  319. dscr = null;
  320. } else {
  321. options = arguments[3];
  322. }
  323. if (get == null) {
  324. get = undefined;
  325. } else if (!isCallable(get)) {
  326. options = get;
  327. get = set = undefined;
  328. } else if (set == null) {
  329. set = undefined;
  330. } else if (!isCallable(set)) {
  331. options = set;
  332. set = undefined;
  333. }
  334. if (dscr == null) {
  335. c = true;
  336. e = false;
  337. } else {
  338. c = contains.call(dscr, 'c');
  339. e = contains.call(dscr, 'e');
  340. }
  341. desc = { get: get, set: set, configurable: c, enumerable: e };
  342. return !options ? desc : assign(normalizeOpts(options), desc);
  343. };
  344. },{"es5-ext/object/assign":9,"es5-ext/object/is-callable":12,"es5-ext/object/normalize-options":17,"es5-ext/string/#/contains":19}],8:[function(require,module,exports){
  345. "use strict";
  346. // eslint-disable-next-line no-empty-function
  347. module.exports = function () {};
  348. },{}],9:[function(require,module,exports){
  349. "use strict";
  350. module.exports = require("./is-implemented")()
  351. ? Object.assign
  352. : require("./shim");
  353. },{"./is-implemented":10,"./shim":11}],10:[function(require,module,exports){
  354. "use strict";
  355. module.exports = function () {
  356. var assign = Object.assign, obj;
  357. if (typeof assign !== "function") return false;
  358. obj = { foo: "raz" };
  359. assign(obj, { bar: "dwa" }, { trzy: "trzy" });
  360. return (obj.foo + obj.bar + obj.trzy) === "razdwatrzy";
  361. };
  362. },{}],11:[function(require,module,exports){
  363. "use strict";
  364. var keys = require("../keys")
  365. , value = require("../valid-value")
  366. , max = Math.max;
  367. module.exports = function (dest, src /*, …srcn*/) {
  368. var error, i, length = max(arguments.length, 2), assign;
  369. dest = Object(value(dest));
  370. assign = function (key) {
  371. try {
  372. dest[key] = src[key];
  373. } catch (e) {
  374. if (!error) error = e;
  375. }
  376. };
  377. for (i = 1; i < length; ++i) {
  378. src = arguments[i];
  379. keys(src).forEach(assign);
  380. }
  381. if (error !== undefined) throw error;
  382. return dest;
  383. };
  384. },{"../keys":14,"../valid-value":18}],12:[function(require,module,exports){
  385. // Deprecated
  386. "use strict";
  387. module.exports = function (obj) {
  388. return typeof obj === "function";
  389. };
  390. },{}],13:[function(require,module,exports){
  391. "use strict";
  392. var _undefined = require("../function/noop")(); // Support ES3 engines
  393. module.exports = function (val) {
  394. return (val !== _undefined) && (val !== null);
  395. };
  396. },{"../function/noop":8}],14:[function(require,module,exports){
  397. "use strict";
  398. module.exports = require("./is-implemented")()
  399. ? Object.keys
  400. : require("./shim");
  401. },{"./is-implemented":15,"./shim":16}],15:[function(require,module,exports){
  402. "use strict";
  403. module.exports = function () {
  404. try {
  405. Object.keys("primitive");
  406. return true;
  407. } catch (e) {
  408. return false;
  409. }
  410. };
  411. },{}],16:[function(require,module,exports){
  412. "use strict";
  413. var isValue = require("../is-value");
  414. var keys = Object.keys;
  415. module.exports = function (object) {
  416. return keys(isValue(object) ? Object(object) : object);
  417. };
  418. },{"../is-value":13}],17:[function(require,module,exports){
  419. "use strict";
  420. var isValue = require("./is-value");
  421. var forEach = Array.prototype.forEach, create = Object.create;
  422. var process = function (src, obj) {
  423. var key;
  424. for (key in src) obj[key] = src[key];
  425. };
  426. // eslint-disable-next-line no-unused-vars
  427. module.exports = function (opts1 /*, …options*/) {
  428. var result = create(null);
  429. forEach.call(arguments, function (options) {
  430. if (!isValue(options)) return;
  431. process(Object(options), result);
  432. });
  433. return result;
  434. };
  435. },{"./is-value":13}],18:[function(require,module,exports){
  436. "use strict";
  437. var isValue = require("./is-value");
  438. module.exports = function (value) {
  439. if (!isValue(value)) throw new TypeError("Cannot use null or undefined");
  440. return value;
  441. };
  442. },{"./is-value":13}],19:[function(require,module,exports){
  443. "use strict";
  444. module.exports = require("./is-implemented")()
  445. ? String.prototype.contains
  446. : require("./shim");
  447. },{"./is-implemented":20,"./shim":21}],20:[function(require,module,exports){
  448. "use strict";
  449. var str = "razdwatrzy";
  450. module.exports = function () {
  451. if (typeof str.contains !== "function") return false;
  452. return (str.contains("dwa") === true) && (str.contains("foo") === false);
  453. };
  454. },{}],21:[function(require,module,exports){
  455. "use strict";
  456. var indexOf = String.prototype.indexOf;
  457. module.exports = function (searchString/*, position*/) {
  458. return indexOf.call(this, searchString, arguments[1]) > -1;
  459. };
  460. },{}],22:[function(require,module,exports){
  461. 'use strict';
  462. module.exports = require('./is-implemented')() ? Symbol : require('./polyfill');
  463. },{"./is-implemented":23,"./polyfill":25}],23:[function(require,module,exports){
  464. 'use strict';
  465. var validTypes = { object: true, symbol: true };
  466. module.exports = function () {
  467. var symbol;
  468. if (typeof Symbol !== 'function') return false;
  469. symbol = Symbol('test symbol');
  470. try { String(symbol); } catch (e) { return false; }
  471. // Return 'true' also for polyfills
  472. if (!validTypes[typeof Symbol.iterator]) return false;
  473. if (!validTypes[typeof Symbol.toPrimitive]) return false;
  474. if (!validTypes[typeof Symbol.toStringTag]) return false;
  475. return true;
  476. };
  477. },{}],24:[function(require,module,exports){
  478. 'use strict';
  479. module.exports = function (x) {
  480. if (!x) return false;
  481. if (typeof x === 'symbol') return true;
  482. if (!x.constructor) return false;
  483. if (x.constructor.name !== 'Symbol') return false;
  484. return (x[x.constructor.toStringTag] === 'Symbol');
  485. };
  486. },{}],25:[function(require,module,exports){
  487. // ES2015 Symbol polyfill for environments that do not (or partially) support it
  488. 'use strict';
  489. var d = require('d')
  490. , validateSymbol = require('./validate-symbol')
  491. , create = Object.create, defineProperties = Object.defineProperties
  492. , defineProperty = Object.defineProperty, objPrototype = Object.prototype
  493. , NativeSymbol, SymbolPolyfill, HiddenSymbol, globalSymbols = create(null)
  494. , isNativeSafe;
  495. if (typeof Symbol === 'function') {
  496. NativeSymbol = Symbol;
  497. try {
  498. String(NativeSymbol());
  499. isNativeSafe = true;
  500. } catch (ignore) {}
  501. }
  502. var generateName = (function () {
  503. var created = create(null);
  504. return function (desc) {
  505. var postfix = 0, name, ie11BugWorkaround;
  506. while (created[desc + (postfix || '')]) ++postfix;
  507. desc += (postfix || '');
  508. created[desc] = true;
  509. name = '@@' + desc;
  510. defineProperty(objPrototype, name, d.gs(null, function (value) {
  511. // For IE11 issue see:
  512. // https://connect.microsoft.com/IE/feedbackdetail/view/1928508/
  513. // ie11-broken-getters-on-dom-objects
  514. // https://github.com/medikoo/es6-symbol/issues/12
  515. if (ie11BugWorkaround) return;
  516. ie11BugWorkaround = true;
  517. defineProperty(this, name, d(value));
  518. ie11BugWorkaround = false;
  519. }));
  520. return name;
  521. };
  522. }());
  523. // Internal constructor (not one exposed) for creating Symbol instances.
  524. // This one is used to ensure that `someSymbol instanceof Symbol` always return false
  525. HiddenSymbol = function Symbol(description) {
  526. if (this instanceof HiddenSymbol) throw new TypeError('Symbol is not a constructor');
  527. return SymbolPolyfill(description);
  528. };
  529. // Exposed `Symbol` constructor
  530. // (returns instances of HiddenSymbol)
  531. module.exports = SymbolPolyfill = function Symbol(description) {
  532. var symbol;
  533. if (this instanceof Symbol) throw new TypeError('Symbol is not a constructor');
  534. if (isNativeSafe) return NativeSymbol(description);
  535. symbol = create(HiddenSymbol.prototype);
  536. description = (description === undefined ? '' : String(description));
  537. return defineProperties(symbol, {
  538. __description__: d('', description),
  539. __name__: d('', generateName(description))
  540. });
  541. };
  542. defineProperties(SymbolPolyfill, {
  543. for: d(function (key) {
  544. if (globalSymbols[key]) return globalSymbols[key];
  545. return (globalSymbols[key] = SymbolPolyfill(String(key)));
  546. }),
  547. keyFor: d(function (s) {
  548. var key;
  549. validateSymbol(s);
  550. for (key in globalSymbols) if (globalSymbols[key] === s) return key;
  551. }),
  552. // To ensure proper interoperability with other native functions (e.g. Array.from)
  553. // fallback to eventual native implementation of given symbol
  554. hasInstance: d('', (NativeSymbol && NativeSymbol.hasInstance) || SymbolPolyfill('hasInstance')),
  555. isConcatSpreadable: d('', (NativeSymbol && NativeSymbol.isConcatSpreadable) ||
  556. SymbolPolyfill('isConcatSpreadable')),
  557. iterator: d('', (NativeSymbol && NativeSymbol.iterator) || SymbolPolyfill('iterator')),
  558. match: d('', (NativeSymbol && NativeSymbol.match) || SymbolPolyfill('match')),
  559. replace: d('', (NativeSymbol && NativeSymbol.replace) || SymbolPolyfill('replace')),
  560. search: d('', (NativeSymbol && NativeSymbol.search) || SymbolPolyfill('search')),
  561. species: d('', (NativeSymbol && NativeSymbol.species) || SymbolPolyfill('species')),
  562. split: d('', (NativeSymbol && NativeSymbol.split) || SymbolPolyfill('split')),
  563. toPrimitive: d('', (NativeSymbol && NativeSymbol.toPrimitive) || SymbolPolyfill('toPrimitive')),
  564. toStringTag: d('', (NativeSymbol && NativeSymbol.toStringTag) || SymbolPolyfill('toStringTag')),
  565. unscopables: d('', (NativeSymbol && NativeSymbol.unscopables) || SymbolPolyfill('unscopables'))
  566. });
  567. // Internal tweaks for real symbol producer
  568. defineProperties(HiddenSymbol.prototype, {
  569. constructor: d(SymbolPolyfill),
  570. toString: d('', function () { return this.__name__; })
  571. });
  572. // Proper implementation of methods exposed on Symbol.prototype
  573. // They won't be accessible on produced symbol instances as they derive from HiddenSymbol.prototype
  574. defineProperties(SymbolPolyfill.prototype, {
  575. toString: d(function () { return 'Symbol (' + validateSymbol(this).__description__ + ')'; }),
  576. valueOf: d(function () { return validateSymbol(this); })
  577. });
  578. defineProperty(SymbolPolyfill.prototype, SymbolPolyfill.toPrimitive, d('', function () {
  579. var symbol = validateSymbol(this);
  580. if (typeof symbol === 'symbol') return symbol;
  581. return symbol.toString();
  582. }));
  583. defineProperty(SymbolPolyfill.prototype, SymbolPolyfill.toStringTag, d('c', 'Symbol'));
  584. // Proper implementaton of toPrimitive and toStringTag for returned symbol instances
  585. defineProperty(HiddenSymbol.prototype, SymbolPolyfill.toStringTag,
  586. d('c', SymbolPolyfill.prototype[SymbolPolyfill.toStringTag]));
  587. // Note: It's important to define `toPrimitive` as last one, as some implementations
  588. // implement `toPrimitive` natively without implementing `toStringTag` (or other specified symbols)
  589. // And that may invoke error in definition flow:
  590. // See: https://github.com/medikoo/es6-symbol/issues/13#issuecomment-164146149
  591. defineProperty(HiddenSymbol.prototype, SymbolPolyfill.toPrimitive,
  592. d('c', SymbolPolyfill.prototype[SymbolPolyfill.toPrimitive]));
  593. },{"./validate-symbol":26,"d":7}],26:[function(require,module,exports){
  594. 'use strict';
  595. var isSymbol = require('./is-symbol');
  596. module.exports = function (value) {
  597. if (!isSymbol(value)) throw new TypeError(value + " is not a symbol");
  598. return value;
  599. };
  600. },{"./is-symbol":24}],27:[function(require,module,exports){
  601. if (typeof Object.create === 'function') {
  602. // implementation from standard node.js 'util' module
  603. module.exports = function inherits(ctor, superCtor) {
  604. ctor.super_ = superCtor
  605. ctor.prototype = Object.create(superCtor.prototype, {
  606. constructor: {
  607. value: ctor,
  608. enumerable: false,
  609. writable: true,
  610. configurable: true
  611. }
  612. });
  613. };
  614. } else {
  615. // old school shim for old browsers
  616. module.exports = function inherits(ctor, superCtor) {
  617. ctor.super_ = superCtor
  618. var TempCtor = function () {}
  619. TempCtor.prototype = superCtor.prototype
  620. ctor.prototype = new TempCtor()
  621. ctor.prototype.constructor = ctor
  622. }
  623. }
  624. },{}],28:[function(require,module,exports){
  625. /*!
  626. * Determine if an object is a Buffer
  627. *
  628. * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>
  629. * @license MIT
  630. */
  631. // The _isBuffer check is for Safari 5-7 support, because it's missing
  632. // Object.prototype.constructor. Remove this eventually
  633. module.exports = function (obj) {
  634. return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)
  635. }
  636. function isBuffer (obj) {
  637. return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)
  638. }
  639. // For Node v0.10 support. Remove this eventually.
  640. function isSlowBuffer (obj) {
  641. return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))
  642. }
  643. },{}],29:[function(require,module,exports){
  644. // Copyright Joyent, Inc. and other Node contributors.
  645. //
  646. // Permission is hereby granted, free of charge, to any person obtaining a
  647. // copy of this software and associated documentation files (the
  648. // "Software"), to deal in the Software without restriction, including
  649. // without limitation the rights to use, copy, modify, merge, publish,
  650. // distribute, sublicense, and/or sell copies of the Software, and to permit
  651. // persons to whom the Software is furnished to do so, subject to the
  652. // following conditions:
  653. //
  654. // The above copyright notice and this permission notice shall be included
  655. // in all copies or substantial portions of the Software.
  656. //
  657. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
  658. // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  659. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
  660. // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
  661. // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
  662. // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
  663. // USE OR OTHER DEALINGS IN THE SOFTWARE.
  664. module.exports = extend;
  665. function extend(origin, add) {
  666. // Don't do anything if add isn't an object
  667. if (!add || typeof add !== 'object') return origin;
  668. var keys = Object.keys(add);
  669. var i = keys.length;
  670. while (i--) {
  671. origin[keys[i]] = add[keys[i]];
  672. }
  673. return origin;
  674. }
  675. },{}],30:[function(require,module,exports){
  676. 'use strict';
  677. // --------------------------------------------------------------------
  678. // Imports
  679. // --------------------------------------------------------------------
  680. var GrammarDecl = require('./GrammarDecl');
  681. var pexprs = require('./pexprs');
  682. // --------------------------------------------------------------------
  683. // Private stuff
  684. // --------------------------------------------------------------------
  685. function Builder() {}
  686. Builder.prototype = {
  687. currentDecl: null,
  688. newGrammar: function(name) {
  689. return new GrammarDecl(name);
  690. },
  691. grammar: function(metaInfo, name, superGrammar, defaultStartRule, rules) {
  692. var gDecl = new GrammarDecl(name);
  693. if (superGrammar) {
  694. gDecl.withSuperGrammar(this.fromRecipe(superGrammar));
  695. }
  696. if (defaultStartRule) {
  697. gDecl.withDefaultStartRule(defaultStartRule);
  698. }
  699. if (metaInfo && metaInfo.source) {
  700. gDecl.withSource(metaInfo.source);
  701. }
  702. var self = this;
  703. this.currentDecl = gDecl;
  704. Object.keys(rules).forEach(function(ruleName) {
  705. var ruleRecipe = rules[ruleName];
  706. var action = ruleRecipe[0]; // define/extend/override
  707. var metaInfo = ruleRecipe[1];
  708. var description = ruleRecipe[2];
  709. var formals = ruleRecipe[3];
  710. var body = self.fromRecipe(ruleRecipe[4]);
  711. var source;
  712. if (gDecl.source && metaInfo && metaInfo.sourceInterval) {
  713. source = gDecl.source.subInterval(
  714. metaInfo.sourceInterval[0],
  715. metaInfo.sourceInterval[1] - metaInfo.sourceInterval[0]);
  716. }
  717. gDecl[action](ruleName, formals, body, description, source);
  718. });
  719. this.currentDecl = null;
  720. return gDecl.build();
  721. },
  722. terminal: function(x) {
  723. return new pexprs.Terminal(x);
  724. },
  725. range: function(from, to) {
  726. return new pexprs.Range(from, to);
  727. },
  728. param: function(index) {
  729. return new pexprs.Param(index);
  730. },
  731. alt: function(/* term1, term1, ... */) {
  732. var terms = [];
  733. for (var idx = 0; idx < arguments.length; idx++) {
  734. var arg = arguments[idx];
  735. if (!(arg instanceof pexprs.PExpr)) {
  736. arg = this.fromRecipe(arg);
  737. }
  738. if (arg instanceof pexprs.Alt) {
  739. terms = terms.concat(arg.terms);
  740. } else {
  741. terms.push(arg);
  742. }
  743. }
  744. return terms.length === 1 ? terms[0] : new pexprs.Alt(terms);
  745. },
  746. seq: function(/* factor1, factor2, ... */) {
  747. var factors = [];
  748. for (var idx = 0; idx < arguments.length; idx++) {
  749. var arg = arguments[idx];
  750. if (!(arg instanceof pexprs.PExpr)) {
  751. arg = this.fromRecipe(arg);
  752. }
  753. if (arg instanceof pexprs.Seq) {
  754. factors = factors.concat(arg.factors);
  755. } else {
  756. factors.push(arg);
  757. }
  758. }
  759. return factors.length === 1 ? factors[0] : new pexprs.Seq(factors);
  760. },
  761. star: function(expr) {
  762. if (!(expr instanceof pexprs.PExpr)) {
  763. expr = this.fromRecipe(expr);
  764. }
  765. return new pexprs.Star(expr);
  766. },
  767. plus: function(expr) {
  768. if (!(expr instanceof pexprs.PExpr)) {
  769. expr = this.fromRecipe(expr);
  770. }
  771. return new pexprs.Plus(expr);
  772. },
  773. opt: function(expr) {
  774. if (!(expr instanceof pexprs.PExpr)) {
  775. expr = this.fromRecipe(expr);
  776. }
  777. return new pexprs.Opt(expr);
  778. },
  779. not: function(expr) {
  780. if (!(expr instanceof pexprs.PExpr)) {
  781. expr = this.fromRecipe(expr);
  782. }
  783. return new pexprs.Not(expr);
  784. },
  785. la: function(expr) {
  786. // TODO: temporary to still be able to read old recipes
  787. return this.lookahead(expr);
  788. },
  789. lookahead: function(expr) {
  790. if (!(expr instanceof pexprs.PExpr)) {
  791. expr = this.fromRecipe(expr);
  792. }
  793. return new pexprs.Lookahead(expr);
  794. },
  795. lex: function(expr) {
  796. if (!(expr instanceof pexprs.PExpr)) {
  797. expr = this.fromRecipe(expr);
  798. }
  799. return new pexprs.Lex(expr);
  800. },
  801. app: function(ruleName, optParams) {
  802. if (optParams && optParams.length > 0) {
  803. optParams = optParams.map(function(param) {
  804. return param instanceof pexprs.PExpr ? param :
  805. this.fromRecipe(param);
  806. }, this);
  807. }
  808. return new pexprs.Apply(ruleName, optParams);
  809. },
  810. fromRecipe: function(recipe) {
  811. // the meta-info of 'grammar' is proccessed in Builder.grammar
  812. var result = this[recipe[0]].apply(this,
  813. recipe[0] === 'grammar' ? recipe.slice(1) : recipe.slice(2));
  814. var metaInfo = recipe[1];
  815. if (metaInfo) {
  816. if (metaInfo.sourceInterval && this.currentDecl) {
  817. result.withSource(
  818. this.currentDecl.sourceInterval.apply(this.currentDecl, metaInfo.sourceInterval)
  819. );
  820. }
  821. }
  822. return result;
  823. }
  824. };
  825. // --------------------------------------------------------------------
  826. // Exports
  827. // --------------------------------------------------------------------
  828. module.exports = Builder;
  829. },{"./GrammarDecl":34,"./pexprs":64}],31:[function(require,module,exports){
  830. 'use strict';
  831. // --------------------------------------------------------------------
  832. // Imports
  833. // --------------------------------------------------------------------
  834. var Failure = require('./Failure');
  835. var TerminalNode = require('./nodes').TerminalNode;
  836. var assert = require('./common').assert;
  837. var inherits = require('inherits');
  838. var pexprs = require('./pexprs');
  839. function CaseInsensitiveTerminal(param) {
  840. this.obj = param;
  841. }
  842. inherits(CaseInsensitiveTerminal, pexprs.PExpr);
  843. CaseInsensitiveTerminal.prototype = {
  844. _getString: function(state) {
  845. var terminal = state.currentApplication().args[this.obj.index];
  846. assert(terminal instanceof pexprs.Terminal, 'expected a Terminal expression');
  847. return terminal.obj;
  848. },
  849. // Implementation of the PExpr API
  850. allowsSkippingPrecedingSpace: function() {
  851. return true;
  852. },
  853. eval: function(state) {
  854. var inputStream = state.inputStream;
  855. var origPos = inputStream.pos;
  856. var matchStr = this._getString(state);
  857. if (!inputStream.matchString(matchStr, true)) {
  858. state.processFailure(origPos, this);
  859. return false;
  860. } else {
  861. state.pushBinding(new TerminalNode(state.grammar, matchStr), origPos);
  862. return true;
  863. }
  864. },
  865. generateExample: function(grammar, examples, inSyntacticContext, actuals) {
  866. // Start with a example generated from the Terminal...
  867. var str = this.obj.generateExample(grammar, examples, inSyntacticContext, actuals).value;
  868. // ...and randomly switch characters to uppercase/lowercase.
  869. var value = '';
  870. for (var i = 0; i < str.length; ++i) {
  871. value += Math.random() < 0.5 ? str[i].toLocaleLowerCase() : str[i].toLocaleUpperCase();
  872. }
  873. return {value: value};
  874. },
  875. getArity: function() {
  876. return 1;
  877. },
  878. substituteParams: function(actuals) {
  879. return new CaseInsensitiveTerminal(this.obj.substituteParams(actuals));
  880. },
  881. toDisplayString: function() {
  882. return this.obj.toDisplayString() + ' (case-insensitive)';
  883. },
  884. toFailure: function(grammar) {
  885. return new Failure(this, this.obj.toFailure(grammar) + ' (case-insensitive)', 'description');
  886. },
  887. _isNullable: function(grammar, memo) {
  888. return this.obj._isNullable(grammar, memo);
  889. }
  890. };
  891. module.exports = CaseInsensitiveTerminal;
  892. },{"./Failure":32,"./common":44,"./nodes":47,"./pexprs":64,"inherits":27}],32:[function(require,module,exports){
  893. 'use strict';
  894. // --------------------------------------------------------------------
  895. // Private stuff
  896. // --------------------------------------------------------------------
  897. /*
  898. `Failure`s represent expressions that weren't matched while parsing. They are used to generate
  899. error messages automatically. The interface of `Failure`s includes the collowing methods:
  900. - getText() : String
  901. - getType() : String (one of {"description", "string", "code"})
  902. - isDescription() : bool
  903. - isStringTerminal() : bool
  904. - isCode() : bool
  905. - isFluffy() : bool
  906. - makeFluffy() : void
  907. - subsumes(Failure) : bool
  908. */
  909. function isValidType(type) {
  910. return type === 'description' || type === 'string' || type === 'code';
  911. }
  912. function Failure(pexpr, text, type) {
  913. if (!isValidType(type)) {
  914. throw new Error('invalid Failure type: ' + type);
  915. }
  916. this.pexpr = pexpr;
  917. this.text = text;
  918. this.type = type;
  919. this.fluffy = false;
  920. }
  921. Failure.prototype.getPExpr = function() {
  922. return this.pexpr;
  923. };
  924. Failure.prototype.getText = function() {
  925. return this.text;
  926. };
  927. Failure.prototype.getType = function() {
  928. return this.type;
  929. };
  930. Failure.prototype.isDescription = function() {
  931. return this.type === 'description';
  932. };
  933. Failure.prototype.isStringTerminal = function() {
  934. return this.type === 'string';
  935. };
  936. Failure.prototype.isCode = function() {
  937. return this.type === 'code';
  938. };
  939. Failure.prototype.isFluffy = function() {
  940. return this.fluffy;
  941. };
  942. Failure.prototype.makeFluffy = function() {
  943. this.fluffy = true;
  944. };
  945. Failure.prototype.clearFluffy = function() {
  946. this.fluffy = false;
  947. };
  948. Failure.prototype.subsumes = function(that) {
  949. return this.getText() === that.getText() &&
  950. this.type === that.type &&
  951. (!this.isFluffy() || this.isFluffy() && that.isFluffy());
  952. };
  953. Failure.prototype.toString = function() {
  954. return this.type === 'string' ?
  955. JSON.stringify(this.getText()) :
  956. this.getText();
  957. };
  958. Failure.prototype.clone = function() {
  959. var failure = new Failure(this.pexpr, this.text, this.type);
  960. if (this.isFluffy()) {
  961. failure.makeFluffy();
  962. }
  963. return failure;
  964. };
  965. Failure.prototype.toKey = function() {
  966. return this.toString() + '#' + this.type;
  967. };
  968. // --------------------------------------------------------------------
  969. // Exports
  970. // --------------------------------------------------------------------
  971. module.exports = Failure;
  972. },{}],33:[function(require,module,exports){
  973. 'use strict';
  974. // --------------------------------------------------------------------
  975. // Imports
  976. // --------------------------------------------------------------------
  977. var CaseInsensitiveTerminal = require('./CaseInsensitiveTerminal');
  978. var Matcher = require('./Matcher');
  979. var Semantics = require('./Semantics');
  980. var common = require('./common');
  981. var errors = require('./errors');
  982. var pexprs = require('./pexprs');
  983. // --------------------------------------------------------------------
  984. // Private stuff
  985. // --------------------------------------------------------------------
  986. function getSortedRuleValues(grammar) {
  987. return Object.keys(grammar.rules).sort().map(function(name) { return grammar.rules[name]; });
  988. }
  989. function Grammar(
  990. name,
  991. superGrammar,
  992. rules,
  993. optDefaultStartRule) {
  994. this.name = name;
  995. this.superGrammar = superGrammar;
  996. this.rules = rules;
  997. if (optDefaultStartRule) {
  998. if (!(optDefaultStartRule in rules)) {
  999. throw new Error("Invalid start rule: '" + optDefaultStartRule +
  1000. "' is not a rule in grammar '" + name + "'");
  1001. }
  1002. this.defaultStartRule = optDefaultStartRule;
  1003. }
  1004. }
  1005. var ohmGrammar;
  1006. var buildGrammar;
  1007. // This method is called from main.js once Ohm has loaded.
  1008. Grammar.initApplicationParser = function(grammar, builderFn) {
  1009. ohmGrammar = grammar;
  1010. buildGrammar = builderFn;
  1011. };
  1012. Grammar.prototype = {
  1013. matcher: function() {
  1014. return new Matcher(this);
  1015. },
  1016. // Return true if the grammar is a built-in grammar, otherwise false.
  1017. // NOTE: This might give an unexpected result if called before BuiltInRules is defined!
  1018. isBuiltIn: function() {
  1019. return this === Grammar.ProtoBuiltInRules || this === Grammar.BuiltInRules;
  1020. },
  1021. equals: function(g) {
  1022. if (this === g) {
  1023. return true;
  1024. }
  1025. // Do the cheapest comparisons first.
  1026. if (g == null ||
  1027. this.name !== g.name ||
  1028. this.defaultStartRule !== g.defaultStartRule ||
  1029. !(this.superGrammar === g.superGrammar || this.superGrammar.equals(g.superGrammar))) {
  1030. return false;
  1031. }
  1032. var myRules = getSortedRuleValues(this);
  1033. var otherRules = getSortedRuleValues(g);
  1034. return myRules.length === otherRules.length && myRules.every(function(rule, i) {
  1035. return rule.description === otherRules[i].description &&
  1036. rule.formals.join(',') === otherRules[i].formals.join(',') &&
  1037. rule.body.toString() === otherRules[i].body.toString();
  1038. });
  1039. },
  1040. match: function(input, optStartApplication) {
  1041. var m = this.matcher();
  1042. m.replaceInputRange(0, 0, input);
  1043. return m.match(optStartApplication);
  1044. },
  1045. trace: function(input, optStartApplication) {
  1046. var m = this.matcher();
  1047. m.replaceInputRange(0, 0, input);
  1048. return m.trace(optStartApplication);
  1049. },
  1050. semantics: function() {
  1051. // TODO: Remove this eventually! Deprecated in v0.12.
  1052. throw new Error('semantics() is deprecated -- use createSemantics() instead.');
  1053. },
  1054. createSemantics: function() {
  1055. return Semantics.createSemantics(this);
  1056. },
  1057. extendSemantics: function(superSemantics) {
  1058. return Semantics.createSemantics(this, superSemantics._getSemantics());
  1059. },
  1060. // Check that every key in `actionDict` corresponds to a semantic action, and that it maps to
  1061. // a function of the correct arity. If not, throw an exception.
  1062. _checkTopDownActionDict: function(what, name, actionDict) {
  1063. function isSpecialAction(a) {
  1064. return a === '_iter' || a === '_terminal' || a === '_nonterminal' || a === '_default';
  1065. }
  1066. var problems = [];
  1067. for (var k in actionDict) {
  1068. var v = actionDict[k];
  1069. if (!isSpecialAction(k) && !(k in this.rules)) {
  1070. problems.push("'" + k + "' is not a valid semantic action for '" + this.name + "'");
  1071. } else if (typeof v !== 'function') {
  1072. problems.push(
  1073. "'" + k + "' must be a function in an action dictionary for '" + this.name + "'");
  1074. } else {
  1075. var actual = v.length;
  1076. var expected = this._topDownActionArity(k);
  1077. if (actual !== expected) {
  1078. problems.push(
  1079. "Semantic action '" + k + "' has the wrong arity: " +
  1080. 'expected ' + expected + ', got ' + actual);
  1081. }
  1082. }
  1083. }
  1084. if (problems.length > 0) {
  1085. var prettyProblems = problems.map(function(problem) { return '- ' + problem; });
  1086. var error = new Error(
  1087. "Found errors in the action dictionary of the '" + name + "' " + what + ':\n' +
  1088. prettyProblems.join('\n'));
  1089. error.problems = problems;
  1090. throw error;
  1091. }
  1092. },
  1093. // Return the expected arity for a semantic action named `actionName`, which
  1094. // is either a rule name or a special action name like '_nonterminal'.
  1095. _topDownActionArity: function(actionName) {
  1096. if (actionName === '_iter' || actionName === '_nonterminal' || actionName === '_default') {
  1097. return 1;
  1098. } else if (actionName === '_terminal') {
  1099. return 0;
  1100. }
  1101. return this.rules[actionName].body.getArity();
  1102. },
  1103. _inheritsFrom: function(grammar) {
  1104. var g = this.superGrammar;
  1105. while (g) {
  1106. if (g.equals(grammar, true)) {
  1107. return true;
  1108. }
  1109. g = g.superGrammar;
  1110. }
  1111. return false;
  1112. },
  1113. toRecipe: function(optVarName) {
  1114. var metaInfo = {};
  1115. // Include the grammar source if it is available.
  1116. if (this.source) {
  1117. metaInfo.source = this.source.contents;
  1118. }
  1119. var superGrammar = null;
  1120. if (this.superGrammar && !this.superGrammar.isBuiltIn()) {
  1121. superGrammar = JSON.parse(this.superGrammar.toRecipe());
  1122. }
  1123. var startRule = null;
  1124. if (this.defaultStartRule) {
  1125. startRule = this.defaultStartRule;
  1126. }
  1127. var rules = {};
  1128. var self = this;
  1129. Object.keys(this.rules).forEach(function(ruleName) {
  1130. var ruleInfo = self.rules[ruleName];
  1131. var body = ruleInfo.body;
  1132. var isDefinition = !self.superGrammar || !self.superGrammar.rules[ruleName];
  1133. var operation;
  1134. if (isDefinition) {
  1135. operation = 'define';
  1136. } else {
  1137. operation = body instanceof pexprs.Extend ? 'extend' : 'override';
  1138. }
  1139. var metaInfo = {};
  1140. if (ruleInfo.source && self.source) {
  1141. var adjusted = ruleInfo.source.relativeTo(self.source);
  1142. metaInfo.sourceInterval = [adjusted.startIdx, adjusted.endIdx];
  1143. }
  1144. var description = isDefinition ? ruleInfo.description : null;
  1145. var bodyRecipe = body.outputRecipe(ruleInfo.formals, self.source);
  1146. rules[ruleName] = [
  1147. operation, // "define"/"extend"/"override"
  1148. metaInfo,
  1149. description,
  1150. ruleInfo.formals,
  1151. bodyRecipe
  1152. ];
  1153. });
  1154. return JSON.stringify([
  1155. 'grammar',
  1156. metaInfo,
  1157. this.name,
  1158. superGrammar,
  1159. startRule,
  1160. rules
  1161. ]);
  1162. },
  1163. // TODO: Come up with better names for these methods.
  1164. // TODO: Write the analog of these methods for inherited attributes.
  1165. toOperationActionDictionaryTemplate: function() {
  1166. return this._toOperationOrAttributeActionDictionaryTemplate();
  1167. },
  1168. toAttributeActionDictionaryTemplate: function() {
  1169. return this._toOperationOrAttributeActionDictionaryTemplate();
  1170. },
  1171. _toOperationOrAttributeActionDictionaryTemplate: function() {
  1172. // TODO: add the super-grammar's templates at the right place, e.g., a case for AddExpr_plus
  1173. // should appear next to other cases of AddExpr.
  1174. var sb = new common.StringBuffer();
  1175. sb.append('{');
  1176. var first = true;
  1177. for (var ruleName in this.rules) {
  1178. var body = this.rules[ruleName].body;
  1179. if (first) {
  1180. first = false;
  1181. } else {
  1182. sb.append(',');
  1183. }
  1184. sb.append('\n');
  1185. sb.append(' ');
  1186. this.addSemanticActionTemplate(ruleName, body, sb);
  1187. }
  1188. sb.append('\n}');
  1189. return sb.contents();
  1190. },
  1191. addSemanticActionTemplate: function(ruleName, body, sb) {
  1192. sb.append(ruleName);
  1193. sb.append(': function(');
  1194. var arity = this._topDownActionArity(ruleName);
  1195. sb.append(common.repeat('_', arity).join(', '));
  1196. sb.append(') {\n');
  1197. sb.append(' }');
  1198. },
  1199. // Parse a string which expresses a rule application in this grammar, and return the
  1200. // resulting Apply node.
  1201. parseApplication: function(str) {
  1202. var app;
  1203. if (str.indexOf('<') === -1) {
  1204. // simple application
  1205. app = new pexprs.Apply(str);
  1206. } else {
  1207. // parameterized application
  1208. var cst = ohmGrammar.match(str, 'Base_application');
  1209. app = buildGrammar(cst, {});
  1210. }
  1211. // Ensure that the application is valid.
  1212. if (!(app.ruleName in this.rules)) {
  1213. throw errors.undeclaredRule(app.ruleName, this.name);
  1214. }
  1215. var formals = this.rules[app.ruleName].formals;
  1216. if (formals.length !== app.args.length) {
  1217. var source = this.rules[app.ruleName].source;
  1218. throw errors.wrongNumberOfParameters(app.ruleName, formals.length, app.args.length, source);
  1219. }
  1220. return app;
  1221. }
  1222. };
  1223. // The following grammar contains a few rules that couldn't be written in "userland".
  1224. // At the bottom of src/main.js, we create a sub-grammar of this grammar that's called
  1225. // `BuiltInRules`. That grammar contains several convenience rules, e.g., `letter` and
  1226. // `digit`, and is implicitly the super-grammar of any grammar whose super-grammar
  1227. // isn't specified.
  1228. Grammar.ProtoBuiltInRules = new Grammar(
  1229. 'ProtoBuiltInRules', // name
  1230. undefined, // supergrammar
  1231. {
  1232. any: {
  1233. body: pexprs.any,
  1234. formals: [],
  1235. description: 'any character',
  1236. primitive: true
  1237. },
  1238. end: {
  1239. body: pexprs.end,
  1240. formals: [],
  1241. description: 'end of input',
  1242. primitive: true
  1243. },
  1244. caseInsensitive: {
  1245. body: new CaseInsensitiveTerminal(new pexprs.Param(0)),
  1246. formals: ['str'],
  1247. primitive: true
  1248. },
  1249. lower: {
  1250. body: new pexprs.UnicodeChar('Ll'),
  1251. formals: [],
  1252. description: 'a lowercase letter',
  1253. primitive: true
  1254. },
  1255. upper: {
  1256. body: new pexprs.UnicodeChar('Lu'),
  1257. formals: [],
  1258. description: 'an uppercase letter',
  1259. primitive: true
  1260. },
  1261. // The union of Lt (titlecase), Lm (modifier), and Lo (other), i.e. any letter not in Ll or Lu.
  1262. unicodeLtmo: {
  1263. body: new pexprs.UnicodeChar('Ltmo'),
  1264. formals: [],
  1265. description: 'a Unicode character in Lt, Lm, or Lo',
  1266. primitive: true
  1267. },
  1268. // These rules are not truly primitive (they could be written in userland) but are defined
  1269. // here for bootstrapping purposes.
  1270. spaces: {
  1271. body: new pexprs.Star(new pexprs.Apply('space')),
  1272. formals: []
  1273. },
  1274. space: {
  1275. body: new pexprs.Range('\x00', ' '),
  1276. formals: [],
  1277. description: 'a space'
  1278. }
  1279. }
  1280. );
  1281. // --------------------------------------------------------------------
  1282. // Exports
  1283. // --------------------------------------------------------------------
  1284. module.exports = Grammar;
  1285. },{"./CaseInsensitiveTerminal":31,"./Matcher":39,"./Semantics":42,"./common":44,"./errors":45,"./pexprs":64}],34:[function(require,module,exports){
  1286. 'use strict';
  1287. // --------------------------------------------------------------------
  1288. // Imports
  1289. // --------------------------------------------------------------------
  1290. var Grammar = require('./Grammar');
  1291. var InputStream = require('./InputStream');
  1292. var common = require('./common');
  1293. var errors = require('./errors');
  1294. var pexprs = require('./pexprs');
  1295. // --------------------------------------------------------------------
  1296. // Private Stuff
  1297. // --------------------------------------------------------------------
  1298. // Constructors
  1299. function GrammarDecl(name) {
  1300. this.name = name;
  1301. }
  1302. // Helpers
  1303. GrammarDecl.prototype.sourceInterval = function(startIdx, endIdx) {
  1304. return this.source.subInterval(startIdx, endIdx - startIdx);
  1305. };
  1306. GrammarDecl.prototype.ensureSuperGrammar = function() {
  1307. if (!this.superGrammar) {
  1308. this.withSuperGrammar(
  1309. // TODO: The conditional expression below is an ugly hack. It's kind of ok because
  1310. // I doubt anyone will ever try to declare a grammar called `BuiltInRules`. Still,
  1311. // we should try to find a better way to do this.
  1312. this.name === 'BuiltInRules' ?
  1313. Grammar.ProtoBuiltInRules :
  1314. Grammar.BuiltInRules);
  1315. }
  1316. return this.superGrammar;
  1317. };
  1318. GrammarDecl.prototype.installOverriddenOrExtendedRule = function(name, formals, body, source) {
  1319. var duplicateParameterNames = common.getDuplicates(formals);
  1320. if (duplicateParameterNames.length > 0) {
  1321. throw errors.duplicateParameterNames(name, duplicateParameterNames, source);
  1322. }
  1323. var ruleInfo = this.ensureSuperGrammar().rules[name];
  1324. var expectedFormals = ruleInfo.formals;
  1325. var expectedNumFormals = expectedFormals ? expectedFormals.length : 0;
  1326. if (formals.length !== expectedNumFormals) {
  1327. throw errors.wrongNumberOfParameters(name, expectedNumFormals, formals.length, source);
  1328. }
  1329. return this.install(name, formals, body, ruleInfo.description, source);
  1330. };
  1331. GrammarDecl.prototype.install = function(name, formals, body, description, source) {
  1332. this.rules[name] = {
  1333. body: body.introduceParams(formals),
  1334. formals: formals,
  1335. description: description,
  1336. source: source
  1337. };
  1338. return this;
  1339. };
  1340. // Stuff that you should only do once
  1341. GrammarDecl.prototype.withSuperGrammar = function(superGrammar) {
  1342. if (this.superGrammar) {
  1343. throw new Error('the super grammar of a GrammarDecl cannot be set more than once');
  1344. }
  1345. this.superGrammar = superGrammar;
  1346. this.rules = Object.create(superGrammar.rules);
  1347. // Grammars with an explicit supergrammar inherit a default start rule.
  1348. if (!superGrammar.isBuiltIn()) {
  1349. this.defaultStartRule = superGrammar.defaultStartRule;
  1350. }
  1351. return this;
  1352. };
  1353. GrammarDecl.prototype.withDefaultStartRule = function(ruleName) {
  1354. this.defaultStartRule = ruleName;
  1355. return this;
  1356. };
  1357. GrammarDecl.prototype.withSource = function(source) {
  1358. this.source = new InputStream(source).interval(0, source.length);
  1359. return this;
  1360. };
  1361. // Creates a Grammar instance, and if it passes the sanity checks, returns it.
  1362. GrammarDecl.prototype.build = function() {
  1363. var grammar = new Grammar(
  1364. this.name,
  1365. this.ensureSuperGrammar(),
  1366. this.rules,
  1367. this.defaultStartRule);
  1368. // TODO: change the pexpr.prototype.assert... methods to make them add
  1369. // exceptions to an array that's provided as an arg. Then we'll be able to
  1370. // show more than one error of the same type at a time.
  1371. // TODO: include the offending pexpr in the errors, that way we can show
  1372. // the part of the source that caused it.
  1373. var grammarErrors = [];
  1374. var grammarHasInvalidApplications = false;
  1375. Object.keys(grammar.rules).forEach(function(ruleName) {
  1376. var body = grammar.rules[ruleName].body;
  1377. try {
  1378. body.assertChoicesHaveUniformArity(ruleName);
  1379. } catch (e) {
  1380. grammarErrors.push(e);
  1381. }
  1382. try {
  1383. body.assertAllApplicationsAreValid(ruleName, grammar);
  1384. } catch (e) {
  1385. grammarErrors.push(e);
  1386. grammarHasInvalidApplications = true;
  1387. }
  1388. });
  1389. if (!grammarHasInvalidApplications) {
  1390. // The following check can only be done if the grammar has no invalid applications.
  1391. Object.keys(grammar.rules).forEach(function(ruleName) {
  1392. var body = grammar.rules[ruleName].body;
  1393. try {
  1394. body.assertIteratedExprsAreNotNullable(grammar, []);
  1395. } catch (e) {
  1396. grammarErrors.push(e);
  1397. }
  1398. });
  1399. }
  1400. if (grammarErrors.length > 0) {
  1401. errors.throwErrors(grammarErrors);
  1402. }
  1403. if (this.source) {
  1404. grammar.source = this.source;
  1405. }
  1406. return grammar;
  1407. };
  1408. // Rule declarations
  1409. GrammarDecl.prototype.define = function(name, formals, body, description, source) {
  1410. this.ensureSuperGrammar();
  1411. if (this.superGrammar.rules[name]) {
  1412. throw errors.duplicateRuleDeclaration(name, this.name, this.superGrammar.name, source);
  1413. } else if (this.rules[name]) {
  1414. throw errors.duplicateRuleDeclaration(name, this.name, this.name, source);
  1415. }
  1416. var duplicateParameterNames = common.getDuplicates(formals);
  1417. if (duplicateParameterNames.length > 0) {
  1418. throw errors.duplicateParameterNames(name, duplicateParameterNames, source);
  1419. }
  1420. return this.install(name, formals, body, description, source);
  1421. };
  1422. GrammarDecl.prototype.override = function(name, formals, body, descIgnored, source) {
  1423. var ruleInfo = this.ensureSuperGrammar().rules[name];
  1424. if (!ruleInfo) {
  1425. throw errors.cannotOverrideUndeclaredRule(name, this.superGrammar.name, source);
  1426. }
  1427. this.installOverriddenOrExtendedRule(name, formals, body, source);
  1428. return this;
  1429. };
  1430. GrammarDecl.prototype.extend = function(name, formals, fragment, descIgnored, source) {
  1431. var ruleInfo = this.ensureSuperGrammar().rules[name];
  1432. if (!ruleInfo) {
  1433. throw errors.cannotExtendUndeclaredRule(name, this.superGrammar.name, source);
  1434. }
  1435. var body = new pexprs.Extend(this.superGrammar, name, fragment);
  1436. body.source = fragment.source;
  1437. this.installOverriddenOrExtendedRule(name, formals, body, source);
  1438. return this;
  1439. };
  1440. // --------------------------------------------------------------------
  1441. // Exports
  1442. // --------------------------------------------------------------------
  1443. module.exports = GrammarDecl;
  1444. },{"./Grammar":33,"./InputStream":35,"./common":44,"./errors":45,"./pexprs":64}],35:[function(require,module,exports){
  1445. 'use strict';
  1446. // --------------------------------------------------------------------
  1447. // Imports
  1448. // --------------------------------------------------------------------
  1449. var Interval = require('./Interval');
  1450. // --------------------------------------------------------------------
  1451. // Private stuff
  1452. // --------------------------------------------------------------------
  1453. function InputStream(source) {
  1454. this.source = source;
  1455. this.pos = 0;
  1456. this.examinedLength = 0;
  1457. }
  1458. InputStream.prototype = {
  1459. atEnd: function() {
  1460. var ans = this.pos === this.source.length;
  1461. this.examinedLength = Math.max(this.examinedLength, this.pos + 1);
  1462. return ans;
  1463. },
  1464. next: function() {
  1465. var ans = this.source[this.pos++];
  1466. this.examinedLength = Math.max(this.examinedLength, this.pos);
  1467. return ans;
  1468. },
  1469. matchString: function(s, optIgnoreCase) {
  1470. var idx;
  1471. if (optIgnoreCase) {
  1472. /*
  1473. Case-insensitive comparison is a tricky business. Some notable gotchas include the
  1474. "Turkish I" problem (http://www.i18nguy.com/unicode/turkish-i18n.html) and the fact
  1475. that the German Esszet (ß) turns into "SS" in upper case.
  1476. This is intended to be a locale-invariant comparison, which means it may not obey
  1477. locale-specific expectations (e.g. "i" => "İ").
  1478. */
  1479. for (idx = 0; idx < s.length; idx++) {
  1480. var actual = this.next();
  1481. var expected = s[idx];
  1482. if (actual == null || actual.toUpperCase() !== expected.toUpperCase()) {
  1483. return false;
  1484. }
  1485. }
  1486. return true;
  1487. }
  1488. // Default is case-sensitive comparison.
  1489. for (idx = 0; idx < s.length; idx++) {
  1490. if (this.next() !== s[idx]) { return false; }
  1491. }
  1492. return true;
  1493. },
  1494. sourceSlice: function(startIdx, endIdx) {
  1495. return this.source.slice(startIdx, endIdx);
  1496. },
  1497. interval: function(startIdx, optEndIdx) {
  1498. return new Interval(this.source, startIdx, optEndIdx ? optEndIdx : this.pos);
  1499. }
  1500. };
  1501. // --------------------------------------------------------------------
  1502. // Exports
  1503. // --------------------------------------------------------------------
  1504. module.exports = InputStream;
  1505. },{"./Interval":36}],36:[function(require,module,exports){
  1506. 'use strict';
  1507. // --------------------------------------------------------------------
  1508. // Imports
  1509. // --------------------------------------------------------------------
  1510. var assert = require('./common').assert;
  1511. var errors = require('./errors');
  1512. var util = require('./util');
  1513. // --------------------------------------------------------------------
  1514. // Private stuff
  1515. // --------------------------------------------------------------------
  1516. function Interval(sourceString, startIdx, endIdx) {
  1517. this.sourceString = sourceString;
  1518. this.startIdx = startIdx;
  1519. this.endIdx = endIdx;
  1520. }
  1521. Interval.coverage = function(/* interval1, interval2, ... */) {
  1522. var sourceString = arguments[0].sourceString;
  1523. var startIdx = arguments[0].startIdx;
  1524. var endIdx = arguments[0].endIdx;
  1525. for (var idx = 1; idx < arguments.length; idx++) {
  1526. var interval = arguments[idx];
  1527. if (interval.sourceString !== sourceString) {
  1528. throw errors.intervalSourcesDontMatch();
  1529. } else {
  1530. startIdx = Math.min(startIdx, arguments[idx].startIdx);
  1531. endIdx = Math.max(endIdx, arguments[idx].endIdx);
  1532. }
  1533. }
  1534. return new Interval(sourceString, startIdx, endIdx);
  1535. };
  1536. Interval.prototype = {
  1537. coverageWith: function(/* interval1, interval2, ... */) {
  1538. var intervals = Array.prototype.slice.call(arguments);
  1539. intervals.push(this);
  1540. return Interval.coverage.apply(undefined, intervals);
  1541. },
  1542. collapsedLeft: function() {
  1543. return new Interval(this.sourceString, this.startIdx, this.startIdx);
  1544. },
  1545. collapsedRight: function() {
  1546. return new Interval(this.sourceString, this.endIdx, this.endIdx);
  1547. },
  1548. getLineAndColumnMessage: function() {
  1549. var range = [this.startIdx, this.endIdx];
  1550. return util.getLineAndColumnMessage(this.sourceString, this.startIdx, range);
  1551. },
  1552. // Returns an array of 0, 1, or 2 intervals that represents the result of the
  1553. // interval difference operation.
  1554. minus: function(that) {
  1555. if (this.sourceString !== that.sourceString) {
  1556. throw errors.intervalSourcesDontMatch();
  1557. } else if (this.startIdx === that.startIdx && this.endIdx === that.endIdx) {
  1558. // `this` and `that` are the same interval!
  1559. return [
  1560. ];
  1561. } else if (this.startIdx < that.startIdx && that.endIdx < this.endIdx) {
  1562. // `that` splits `this` into two intervals
  1563. return [
  1564. new Interval(this.sourceString, this.startIdx, that.startIdx),
  1565. new Interval(this.sourceString, that.endIdx, this.endIdx)
  1566. ];
  1567. } else if (this.startIdx < that.endIdx && that.endIdx < this.endIdx) {
  1568. // `that` contains a prefix of `this`
  1569. return [
  1570. new Interval(this.sourceString, that.endIdx, this.endIdx)
  1571. ];
  1572. } else if (this.startIdx < that.startIdx && that.startIdx < this.endIdx) {
  1573. // `that` contains a suffix of `this`
  1574. return [
  1575. new Interval(this.sourceString, this.startIdx, that.startIdx)
  1576. ];
  1577. } else {
  1578. // `that` and `this` do not overlap
  1579. return [
  1580. this
  1581. ];
  1582. }
  1583. },
  1584. // Returns a new Interval that has the same extent as this one, but which is relative
  1585. // to `that`, an Interval that fully covers this one.
  1586. relativeTo: function(that) {
  1587. if (this.sourceString !== that.sourceString) {
  1588. throw errors.intervalSourcesDontMatch();
  1589. }
  1590. assert(this.startIdx >= that.startIdx && this.endIdx <= that.endIdx,
  1591. 'other interval does not cover this one');
  1592. return new Interval(this.sourceString,
  1593. this.startIdx - that.startIdx,
  1594. this.endIdx - that.startIdx);
  1595. },
  1596. // Returns a new Interval which contains the same contents as this one,
  1597. // but with whitespace trimmed from both ends. (This only makes sense when
  1598. // the input stream is a string.)
  1599. trimmed: function() {
  1600. var contents = this.contents;
  1601. var startIdx = this.startIdx + contents.match(/^\s*/)[0].length;
  1602. var endIdx = this.endIdx - contents.match(/\s*$/)[0].length;
  1603. return new Interval(this.sourceString, startIdx, endIdx);
  1604. },
  1605. subInterval: function(offset, len) {
  1606. var newStartIdx = this.startIdx + offset;
  1607. return new Interval(this.sourceString, newStartIdx, newStartIdx + len);
  1608. }
  1609. };
  1610. Object.defineProperties(Interval.prototype, {
  1611. contents: {
  1612. get: function() {
  1613. if (this._contents === undefined) {
  1614. this._contents = this.sourceString.slice(this.startIdx, this.endIdx);
  1615. }
  1616. return this._contents;
  1617. },
  1618. enumerable: true
  1619. },
  1620. length: {
  1621. get: function() { return this.endIdx - this.startIdx; },
  1622. enumerable: true
  1623. }
  1624. });
  1625. // --------------------------------------------------------------------
  1626. // Exports
  1627. // --------------------------------------------------------------------
  1628. module.exports = Interval;
  1629. },{"./common":44,"./errors":45,"./util":65}],37:[function(require,module,exports){
  1630. 'use strict';
  1631. // --------------------------------------------------------------------
  1632. // Imports
  1633. // --------------------------------------------------------------------
  1634. var common = require('./common');
  1635. var util = require('./util');
  1636. var Interval = require('./Interval');
  1637. // --------------------------------------------------------------------
  1638. // Private stuff
  1639. // --------------------------------------------------------------------
  1640. function MatchResult(
  1641. matcher,
  1642. input,
  1643. startExpr,
  1644. cst,
  1645. cstOffset,
  1646. rightmostFailurePosition,
  1647. optRecordedFailures) {
  1648. this.matcher = matcher;
  1649. this.input = input;
  1650. this.startExpr = startExpr;
  1651. this._cst = cst;
  1652. this._cstOffset = cstOffset;
  1653. this._rightmostFailurePosition = rightmostFailurePosition;
  1654. this._rightmostFailures = optRecordedFailures;
  1655. if (this.failed()) {
  1656. common.defineLazyProperty(this, 'message', function() {
  1657. var detail = 'Expected ' + this.getExpectedText();
  1658. return util.getLineAndColumnMessage(this.input, this.getRightmostFailurePosition()) + detail;
  1659. });
  1660. common.defineLazyProperty(this, 'shortMessage', function() {
  1661. var detail = 'expected ' + this.getExpectedText();
  1662. var errorInfo = util.getLineAndColumn(this.input, this.getRightmostFailurePosition());
  1663. return 'Line ' + errorInfo.lineNum + ', col ' + errorInfo.colNum + ': ' + detail;
  1664. });
  1665. }
  1666. }
  1667. MatchResult.prototype.succeeded = function() {
  1668. return !!this._cst;
  1669. };
  1670. MatchResult.prototype.failed = function() {
  1671. return !this.succeeded();
  1672. };
  1673. MatchResult.prototype.getRightmostFailurePosition = function() {
  1674. return this._rightmostFailurePosition;
  1675. };
  1676. MatchResult.prototype.getRightmostFailures = function() {
  1677. if (!this._rightmostFailures) {
  1678. this.matcher.setInput(this.input);
  1679. var matchResultWithFailures =
  1680. this.matcher._match(this.startExpr, false, this.getRightmostFailurePosition());
  1681. this._rightmostFailures = matchResultWithFailures.getRightmostFailures();
  1682. }
  1683. return this._rightmostFailures;
  1684. };
  1685. MatchResult.prototype.toString = function() {
  1686. return this.succeeded() ?
  1687. '[match succeeded]' :
  1688. '[match failed at position ' + this.getRightmostFailurePosition() + ']';
  1689. };
  1690. // Return a string summarizing the expected contents of the input stream when
  1691. // the match failure occurred.
  1692. MatchResult.prototype.getExpectedText = function() {
  1693. if (this.succeeded()) {
  1694. throw new Error('cannot get expected text of a successful MatchResult');
  1695. }
  1696. var sb = new common.StringBuffer();
  1697. var failures = this.getRightmostFailures();
  1698. // Filter out the fluffy failures to make the default error messages more useful
  1699. failures = failures.filter(function(failure) {
  1700. return !failure.isFluffy();
  1701. });
  1702. for (var idx = 0; idx < failures.length; idx++) {
  1703. if (idx > 0) {
  1704. if (idx === failures.length - 1) {
  1705. sb.append(failures.length > 2 ? ', or ' : ' or ');
  1706. } else {
  1707. sb.append(', ');
  1708. }
  1709. }
  1710. sb.append(failures[idx].toString());
  1711. }
  1712. return sb.contents();
  1713. };
  1714. MatchResult.prototype.getInterval = function() {
  1715. var pos = this.getRightmostFailurePosition();
  1716. return new Interval(this.input, pos, pos);
  1717. };
  1718. // --------------------------------------------------------------------
  1719. // Exports
  1720. // --------------------------------------------------------------------
  1721. module.exports = MatchResult;
  1722. },{"./Interval":36,"./common":44,"./util":65}],38:[function(require,module,exports){
  1723. 'use strict';
  1724. // --------------------------------------------------------------------
  1725. // Imports
  1726. // --------------------------------------------------------------------
  1727. var InputStream = require('./InputStream');
  1728. var MatchResult = require('./MatchResult');
  1729. var PosInfo = require('./PosInfo');
  1730. var Trace = require('./Trace');
  1731. var pexprs = require('./pexprs');
  1732. // --------------------------------------------------------------------
  1733. // Private stuff
  1734. // --------------------------------------------------------------------
  1735. var applySpaces = new pexprs.Apply('spaces');
  1736. function MatchState(matcher, startExpr, optPositionToRecordFailures) {
  1737. this.matcher = matcher;
  1738. this.startExpr = startExpr;
  1739. this.grammar = matcher.grammar;
  1740. this.input = matcher.input;
  1741. this.inputStream = new InputStream(matcher.input);
  1742. this.memoTable = matcher.memoTable;
  1743. this._bindings = [];
  1744. this._bindingOffsets = [];
  1745. this._applicationStack = [];
  1746. this._posStack = [0];
  1747. this.inLexifiedContextStack = [false];
  1748. this.rightmostFailurePosition = -1;
  1749. this._rightmostFailurePositionStack = [];
  1750. this._recordedFailuresStack = [];
  1751. if (optPositionToRecordFailures !== undefined) {
  1752. this.positionToRecordFailures = optPositionToRecordFailures;
  1753. this.recordedFailures = Object.create(null);
  1754. }
  1755. }
  1756. MatchState.prototype = {
  1757. posToOffset: function(pos) {
  1758. return pos - this._posStack[this._posStack.length - 1];
  1759. },
  1760. enterApplication: function(posInfo, app) {
  1761. this._posStack.push(this.inputStream.pos);
  1762. this._applicationStack.push(app);
  1763. this.inLexifiedContextStack.push(false);
  1764. posInfo.enter(app);
  1765. this._rightmostFailurePositionStack.push(this.rightmostFailurePosition);
  1766. this.rightmostFailurePosition = -1;
  1767. },
  1768. exitApplication: function(posInfo, optNode) {
  1769. var origPos = this._posStack.pop();
  1770. this._applicationStack.pop();
  1771. this.inLexifiedContextStack.pop();
  1772. posInfo.exit();
  1773. this.rightmostFailurePosition = Math.max(
  1774. this.rightmostFailurePosition,
  1775. this._rightmostFailurePositionStack.pop());
  1776. if (optNode) {
  1777. this.pushBinding(optNode, origPos);
  1778. }
  1779. },
  1780. enterLexifiedContext: function() {
  1781. this.inLexifiedContextStack.push(true);
  1782. },
  1783. exitLexifiedContext: function() {
  1784. this.inLexifiedContextStack.pop();
  1785. },
  1786. currentApplication: function() {
  1787. return this._applicationStack[this._applicationStack.length - 1];
  1788. },
  1789. inSyntacticContext: function() {
  1790. if (typeof this.inputStream.source !== 'string') {
  1791. return false;
  1792. }
  1793. var currentApplication = this.currentApplication();
  1794. if (currentApplication) {
  1795. return currentApplication.isSyntactic() && !this.inLexifiedContext();
  1796. } else {
  1797. // The top-level context is syntactic if the start application is.
  1798. return this.startExpr.factors[0].isSyntactic();
  1799. }
  1800. },
  1801. inLexifiedContext: function() {
  1802. return this.inLexifiedContextStack[this.inLexifiedContextStack.length - 1];
  1803. },
  1804. skipSpaces: function() {
  1805. this.pushFailuresInfo();
  1806. this.eval(applySpaces);
  1807. this.popBinding();
  1808. this.popFailuresInfo();
  1809. return this.inputStream.pos;
  1810. },
  1811. skipSpacesIfInSyntacticContext: function() {
  1812. return this.inSyntacticContext() ?
  1813. this.skipSpaces() :
  1814. this.inputStream.pos;
  1815. },
  1816. maybeSkipSpacesBefore: function(expr) {
  1817. if (expr instanceof pexprs.Apply && expr.isSyntactic()) {
  1818. return this.skipSpaces();
  1819. } else if (expr.allowsSkippingPrecedingSpace() && expr !== applySpaces) {
  1820. return this.skipSpacesIfInSyntacticContext();
  1821. } else {
  1822. return this.inputStream.pos;
  1823. }
  1824. },
  1825. pushBinding: function(node, origPos) {
  1826. this._bindings.push(node);
  1827. this._bindingOffsets.push(this.posToOffset(origPos));
  1828. },
  1829. popBinding: function() {
  1830. this._bindings.pop();
  1831. this._bindingOffsets.pop();
  1832. },
  1833. numBindings: function() {
  1834. return this._bindings.length;
  1835. },
  1836. truncateBindings: function(newLength) {
  1837. // Yes, this is this really faster than setting the `length` property (tested with
  1838. // bin/es5bench on Node v6.1.0).
  1839. while (this._bindings.length > newLength) {
  1840. this.popBinding();
  1841. }
  1842. },
  1843. getCurrentPosInfo: function() {
  1844. return this.getPosInfo(this.inputStream.pos);
  1845. },
  1846. getPosInfo: function(pos) {
  1847. var posInfo = this.memoTable[pos];
  1848. if (!posInfo) {
  1849. posInfo = this.memoTable[pos] = new PosInfo();
  1850. }
  1851. return posInfo;
  1852. },
  1853. processFailure: function(pos, expr) {
  1854. this.rightmostFailurePosition = Math.max(this.rightmostFailurePosition, pos);
  1855. if (this.recordedFailures && pos === this.positionToRecordFailures) {
  1856. var app = this.currentApplication();
  1857. if (app) {
  1858. // Substitute parameters with the actual pexprs that were passed to
  1859. // the current rule.
  1860. expr = expr.substituteParams(app.args);
  1861. } else {
  1862. // This branch is only reached for the "end-check" that is
  1863. // performed after the top-level application. In that case,
  1864. // expr === pexprs.end so there is no need to substitute
  1865. // parameters.
  1866. }
  1867. this.recordFailure(expr.toFailure(this.grammar), false);
  1868. }
  1869. },
  1870. recordFailure: function(failure, shouldCloneIfNew) {
  1871. var key = failure.toKey();
  1872. if (!this.recordedFailures[key]) {
  1873. this.recordedFailures[key] = shouldCloneIfNew ? failure.clone() : failure;
  1874. } else if (this.recordedFailures[key].isFluffy() && !failure.isFluffy()) {
  1875. this.recordedFailures[key].clearFluffy();
  1876. }
  1877. },
  1878. recordFailures: function(failures, shouldCloneIfNew) {
  1879. var self = this;
  1880. Object.keys(failures).forEach(function(key) {
  1881. self.recordFailure(failures[key], shouldCloneIfNew);
  1882. });
  1883. },
  1884. cloneRecordedFailures: function() {
  1885. if (!this.recordedFailures) {
  1886. return undefined;
  1887. }
  1888. var ans = Object.create(null);
  1889. var self = this;
  1890. Object.keys(this.recordedFailures).forEach(function(key) {
  1891. ans[key] = self.recordedFailures[key].clone();
  1892. });
  1893. return ans;
  1894. },
  1895. getRightmostFailurePosition: function() {
  1896. return this.rightmostFailurePosition;
  1897. },
  1898. _getRightmostFailureOffset: function() {
  1899. return this.rightmostFailurePosition >= 0 ?
  1900. this.posToOffset(this.rightmostFailurePosition) :
  1901. -1;
  1902. },
  1903. // Returns the memoized trace entry for `expr` at `pos`, if one exists, `null` otherwise.
  1904. getMemoizedTraceEntry: function(pos, expr) {
  1905. var posInfo = this.memoTable[pos];
  1906. if (posInfo && expr.ruleName) {
  1907. var memoRec = posInfo.memo[expr.toMemoKey()];
  1908. if (memoRec && memoRec.traceEntry) {
  1909. var entry = memoRec.traceEntry.cloneWithExpr(expr);
  1910. entry.isMemoized = true;
  1911. return entry;
  1912. }
  1913. }
  1914. return null;
  1915. },
  1916. // Returns a new trace entry, with the currently active trace array as its children.
  1917. getTraceEntry: function(pos, expr, succeeded, bindings) {
  1918. if (expr instanceof pexprs.Apply) {
  1919. var app = this.currentApplication();
  1920. var actuals = app ? app.args : [];
  1921. expr = expr.substituteParams(actuals);
  1922. }
  1923. return this.getMemoizedTraceEntry(pos, expr) ||
  1924. new Trace(this.input, pos, this.inputStream.pos, expr, succeeded, bindings, this.trace);
  1925. },
  1926. isTracing: function() {
  1927. return !!this.trace;
  1928. },
  1929. hasNecessaryInfo: function(memoRec) {
  1930. if (this.trace && !memoRec.traceEntry) {
  1931. return false;
  1932. }
  1933. if (this.recordedFailures &&
  1934. this.inputStream.pos + memoRec.rightmostFailureOffset === this.positionToRecordFailures) {
  1935. return !!memoRec.failuresAtRightmostPosition;
  1936. }
  1937. return true;
  1938. },
  1939. useMemoizedResult: function(origPos, memoRec) {
  1940. if (this.trace) {
  1941. this.trace.push(memoRec.traceEntry);
  1942. }
  1943. var memoRecRightmostFailurePosition = this.inputStream.pos + memoRec.rightmostFailureOffset;
  1944. this.rightmostFailurePosition =
  1945. Math.max(this.rightmostFailurePosition, memoRecRightmostFailurePosition);
  1946. if (this.recordedFailures &&
  1947. this.positionToRecordFailures === memoRecRightmostFailurePosition &&
  1948. memoRec.failuresAtRightmostPosition) {
  1949. this.recordFailures(memoRec.failuresAtRightmostPosition, true);
  1950. }
  1951. this.inputStream.examinedLength =
  1952. Math.max(this.inputStream.examinedLength, memoRec.examinedLength + origPos);
  1953. if (memoRec.value) {
  1954. this.inputStream.pos += memoRec.matchLength;
  1955. this.pushBinding(memoRec.value, origPos);
  1956. return true;
  1957. }
  1958. return false;
  1959. },
  1960. // Evaluate `expr` and return `true` if it succeeded, `false` otherwise. On success, `bindings`
  1961. // will have `expr.getArity()` more elements than before, and the input stream's position may
  1962. // have increased. On failure, `bindings` and position will be unchanged.
  1963. eval: function(expr) {
  1964. var inputStream = this.inputStream;
  1965. var origNumBindings = this._bindings.length;
  1966. var origRecordedFailures;
  1967. if (this.recordedFailures) {
  1968. origRecordedFailures = this.recordedFailures;
  1969. this.recordedFailures = Object.create(null);
  1970. }
  1971. var origPos = inputStream.pos;
  1972. var memoPos = this.maybeSkipSpacesBefore(expr);
  1973. var origTrace;
  1974. if (this.trace) {
  1975. origTrace = this.trace;
  1976. this.trace = [];
  1977. }
  1978. // Do the actual evaluation.
  1979. var ans = expr.eval(this);
  1980. if (this.trace) {
  1981. var bindings = this._bindings.slice(origNumBindings);
  1982. var traceEntry = this.getTraceEntry(memoPos, expr, ans, bindings);
  1983. traceEntry.isImplicitSpaces = expr === applySpaces;
  1984. traceEntry.isRootNode = expr === this.startExpr;
  1985. origTrace.push(traceEntry);
  1986. this.trace = origTrace;
  1987. }
  1988. if (ans) {
  1989. if (this.recordedFailures && inputStream.pos === this.positionToRecordFailures) {
  1990. var self = this;
  1991. Object.keys(this.recordedFailures).forEach(function(key) {
  1992. self.recordedFailures[key].makeFluffy();
  1993. });
  1994. }
  1995. } else {
  1996. // Reset the position and the bindings.
  1997. inputStream.pos = origPos;
  1998. this.truncateBindings(origNumBindings);
  1999. }
  2000. if (this.recordedFailures) {
  2001. this.recordFailures(origRecordedFailures, false);
  2002. }
  2003. return ans;
  2004. },
  2005. getMatchResult: function() {
  2006. this.eval(this.startExpr);
  2007. var rightmostFailures;
  2008. if (this.recordedFailures) {
  2009. var self = this;
  2010. rightmostFailures = Object.keys(this.recordedFailures).map(function(key) {
  2011. return self.recordedFailures[key];
  2012. });
  2013. }
  2014. return new MatchResult(
  2015. this.matcher,
  2016. this.input,
  2017. this.startExpr,
  2018. this._bindings[0],
  2019. this._bindingOffsets[0],
  2020. this.rightmostFailurePosition,
  2021. rightmostFailures);
  2022. },
  2023. getTrace: function() {
  2024. this.trace = [];
  2025. var matchResult = this.getMatchResult();
  2026. // The trace node for the start rule is always the last entry. If it is a syntactic rule,
  2027. // the first entry is for an application of 'spaces'.
  2028. // TODO(pdubroy): Clean this up by introducing a special `Match<startAppl>` rule, which will
  2029. // ensure that there is always a single root trace node.
  2030. var rootTrace = this.trace[this.trace.length - 1];
  2031. rootTrace.result = matchResult;
  2032. return rootTrace;
  2033. },
  2034. pushFailuresInfo: function() {
  2035. this._rightmostFailurePositionStack.push(this.rightmostFailurePosition);
  2036. this._recordedFailuresStack.push(this.recordedFailures);
  2037. },
  2038. popFailuresInfo: function() {
  2039. this.rightmostFailurePosition = this._rightmostFailurePositionStack.pop();
  2040. this.recordedFailures = this._recordedFailuresStack.pop();
  2041. }
  2042. };
  2043. // --------------------------------------------------------------------
  2044. // Exports
  2045. // --------------------------------------------------------------------
  2046. module.exports = MatchState;
  2047. },{"./InputStream":35,"./MatchResult":37,"./PosInfo":41,"./Trace":43,"./pexprs":64}],39:[function(require,module,exports){
  2048. 'use strict';
  2049. // --------------------------------------------------------------------
  2050. // Imports
  2051. // --------------------------------------------------------------------
  2052. var MatchState = require('./MatchState');
  2053. var pexprs = require('./pexprs');
  2054. // --------------------------------------------------------------------
  2055. // Private stuff
  2056. // --------------------------------------------------------------------
  2057. function Matcher(grammar) {
  2058. this.grammar = grammar;
  2059. this.memoTable = [];
  2060. this.input = '';
  2061. }
  2062. Matcher.prototype.getInput = function() {
  2063. return this.input;
  2064. };
  2065. Matcher.prototype.setInput = function(str) {
  2066. if (this.input !== str) {
  2067. this.replaceInputRange(0, this.input.length, str);
  2068. }
  2069. return this;
  2070. };
  2071. Matcher.prototype.replaceInputRange = function(startIdx, endIdx, str) {
  2072. var currentInput = this.input;
  2073. if (startIdx < 0 || startIdx > currentInput.length ||
  2074. endIdx < 0 || endIdx > currentInput.length ||
  2075. startIdx > endIdx) {
  2076. throw new Error('Invalid indices: ' + startIdx + ' and ' + endIdx);
  2077. }
  2078. // update input
  2079. this.input = currentInput.slice(0, startIdx) + str + currentInput.slice(endIdx);
  2080. // update memo table (similar to the above)
  2081. var restOfMemoTable = this.memoTable.slice(endIdx);
  2082. this.memoTable.length = startIdx;
  2083. for (var idx = 0; idx < str.length; idx++) {
  2084. this.memoTable.push(undefined);
  2085. }
  2086. restOfMemoTable.forEach(
  2087. function(posInfo) { this.memoTable.push(posInfo); },
  2088. this);
  2089. // Invalidate memoRecs
  2090. for (var pos = 0; pos < startIdx; pos++) {
  2091. var posInfo = this.memoTable[pos];
  2092. if (posInfo) {
  2093. posInfo.clearObsoleteEntries(pos, startIdx);
  2094. }
  2095. }
  2096. return this;
  2097. };
  2098. Matcher.prototype.match = function(optStartApplicationStr) {
  2099. return this._match(this._getStartExpr(optStartApplicationStr), false);
  2100. };
  2101. Matcher.prototype.trace = function(optStartApplicationStr) {
  2102. return this._match(this._getStartExpr(optStartApplicationStr), true);
  2103. };
  2104. Matcher.prototype._match = function(startExpr, tracing, optPositionToRecordFailures) {
  2105. var state = new MatchState(this, startExpr, optPositionToRecordFailures);
  2106. return tracing ? state.getTrace() : state.getMatchResult();
  2107. };
  2108. /*
  2109. Returns the starting expression for this Matcher's associated grammar. If `optStartApplicationStr`
  2110. is specified, it is a string expressing a rule application in the grammar. If not specified, the
  2111. grammar's default start rule will be used.
  2112. */
  2113. Matcher.prototype._getStartExpr = function(optStartApplicationStr) {
  2114. var applicationStr = optStartApplicationStr || this.grammar.defaultStartRule;
  2115. if (!applicationStr) {
  2116. throw new Error('Missing start rule argument -- the grammar has no default start rule.');
  2117. }
  2118. var startApp = this.grammar.parseApplication(applicationStr);
  2119. return new pexprs.Seq([startApp, pexprs.end]);
  2120. };
  2121. // --------------------------------------------------------------------
  2122. // Exports
  2123. // --------------------------------------------------------------------
  2124. module.exports = Matcher;
  2125. },{"./MatchState":38,"./pexprs":64}],40:[function(require,module,exports){
  2126. 'use strict';
  2127. // --------------------------------------------------------------------
  2128. // Imports
  2129. // --------------------------------------------------------------------
  2130. var extend = require('util-extend');
  2131. // --------------------------------------------------------------------
  2132. // Private stuff
  2133. // --------------------------------------------------------------------
  2134. function Namespace() {
  2135. }
  2136. Namespace.prototype = Object.create(null);
  2137. Namespace.asNamespace = function(objOrNamespace) {
  2138. if (objOrNamespace instanceof Namespace) {
  2139. return objOrNamespace;
  2140. }
  2141. return Namespace.createNamespace(objOrNamespace);
  2142. };
  2143. // Create a new namespace. If `optProps` is specified, all of its properties
  2144. // will be copied to the new namespace.
  2145. Namespace.createNamespace = function(optProps) {
  2146. return Namespace.extend(Namespace.prototype, optProps);
  2147. };
  2148. // Create a new namespace which extends another namespace. If `optProps` is
  2149. // specified, all of its properties will be copied to the new namespace.
  2150. Namespace.extend = function(namespace, optProps) {
  2151. if (namespace !== Namespace.prototype && !(namespace instanceof Namespace)) {
  2152. throw new TypeError('not a Namespace object: ' + namespace);
  2153. }
  2154. var ns = Object.create(namespace, {
  2155. constructor: {
  2156. value: Namespace,
  2157. enumerable: false,
  2158. writable: true,
  2159. configurable: true
  2160. }
  2161. });
  2162. return extend(ns, optProps);
  2163. };
  2164. // TODO: Should this be a regular method?
  2165. Namespace.toString = function(ns) {
  2166. return Object.prototype.toString.call(ns);
  2167. };
  2168. // --------------------------------------------------------------------
  2169. // Exports
  2170. // --------------------------------------------------------------------
  2171. module.exports = Namespace;
  2172. },{"util-extend":29}],41:[function(require,module,exports){
  2173. 'use strict';
  2174. // --------------------------------------------------------------------
  2175. // Private stuff
  2176. // --------------------------------------------------------------------
  2177. function PosInfo() {
  2178. this.applicationMemoKeyStack = []; // active applications at this position
  2179. this.memo = {};
  2180. this.maxExaminedLength = 0;
  2181. this.maxRightmostFailureOffset = -1;
  2182. this.currentLeftRecursion = undefined;
  2183. }
  2184. PosInfo.prototype = {
  2185. isActive: function(application) {
  2186. return this.applicationMemoKeyStack.indexOf(application.toMemoKey()) >= 0;
  2187. },
  2188. enter: function(application) {
  2189. this.applicationMemoKeyStack.push(application.toMemoKey());
  2190. },
  2191. exit: function() {
  2192. this.applicationMemoKeyStack.pop();
  2193. },
  2194. startLeftRecursion: function(headApplication, memoRec) {
  2195. memoRec.isLeftRecursion = true;
  2196. memoRec.headApplication = headApplication;
  2197. memoRec.nextLeftRecursion = this.currentLeftRecursion;
  2198. this.currentLeftRecursion = memoRec;
  2199. var applicationMemoKeyStack = this.applicationMemoKeyStack;
  2200. var indexOfFirstInvolvedRule = applicationMemoKeyStack.indexOf(headApplication.toMemoKey()) + 1;
  2201. var involvedApplicationMemoKeys = applicationMemoKeyStack.slice(indexOfFirstInvolvedRule);
  2202. memoRec.isInvolved = function(applicationMemoKey) {
  2203. return involvedApplicationMemoKeys.indexOf(applicationMemoKey) >= 0;
  2204. };
  2205. memoRec.updateInvolvedApplicationMemoKeys = function() {
  2206. for (var idx = indexOfFirstInvolvedRule; idx < applicationMemoKeyStack.length; idx++) {
  2207. var applicationMemoKey = applicationMemoKeyStack[idx];
  2208. if (!this.isInvolved(applicationMemoKey)) {
  2209. involvedApplicationMemoKeys.push(applicationMemoKey);
  2210. }
  2211. }
  2212. };
  2213. },
  2214. endLeftRecursion: function() {
  2215. this.currentLeftRecursion = this.currentLeftRecursion.nextLeftRecursion;
  2216. },
  2217. // Note: this method doesn't get called for the "head" of a left recursion -- for LR heads,
  2218. // the memoized result (which starts out being a failure) is always used.
  2219. shouldUseMemoizedResult: function(memoRec) {
  2220. if (!memoRec.isLeftRecursion) {
  2221. return true;
  2222. }
  2223. var applicationMemoKeyStack = this.applicationMemoKeyStack;
  2224. for (var idx = 0; idx < applicationMemoKeyStack.length; idx++) {
  2225. var applicationMemoKey = applicationMemoKeyStack[idx];
  2226. if (memoRec.isInvolved(applicationMemoKey)) {
  2227. return false;
  2228. }
  2229. }
  2230. return true;
  2231. },
  2232. memoize: function(memoKey, memoRec) {
  2233. this.memo[memoKey] = memoRec;
  2234. this.maxExaminedLength = Math.max(this.maxExaminedLength, memoRec.examinedLength);
  2235. this.maxRightmostFailureOffset =
  2236. Math.max(this.maxRightmostFailureOffset, memoRec.rightmostFailureOffset);
  2237. return memoRec;
  2238. },
  2239. clearObsoleteEntries: function(pos, invalidatedIdx) {
  2240. if (pos + this.maxExaminedLength <= invalidatedIdx) {
  2241. // Optimization: none of the rule applications that were memoized here examined the
  2242. // interval of the input that changed, so nothing has to be invalidated.
  2243. return;
  2244. }
  2245. var memo = this.memo;
  2246. this.maxExaminedLength = 0;
  2247. this.maxRightmostFailureOffset = -1;
  2248. var self = this;
  2249. Object.keys(memo).forEach(function(k) {
  2250. var memoRec = memo[k];
  2251. if (pos + memoRec.examinedLength > invalidatedIdx) {
  2252. delete memo[k];
  2253. } else {
  2254. self.maxExaminedLength = Math.max(self.maxExaminedLength, memoRec.examinedLength);
  2255. self.maxRightmostFailureOffset =
  2256. Math.max(self.maxRightmostFailureOffset, memoRec.rightmostFailureOffset);
  2257. }
  2258. });
  2259. }
  2260. };
  2261. // --------------------------------------------------------------------
  2262. // Exports
  2263. // --------------------------------------------------------------------
  2264. module.exports = PosInfo;
  2265. },{}],42:[function(require,module,exports){
  2266. 'use strict';
  2267. // --------------------------------------------------------------------
  2268. // Imports
  2269. // --------------------------------------------------------------------
  2270. var Symbol = require('es6-symbol'); // eslint-disable-line no-undef
  2271. var inherits = require('inherits');
  2272. var InputStream = require('./InputStream');
  2273. var IterationNode = require('./nodes').IterationNode;
  2274. var MatchResult = require('./MatchResult');
  2275. var common = require('./common');
  2276. var errors = require('./errors');
  2277. var util = require('./util');
  2278. // --------------------------------------------------------------------
  2279. // Private stuff
  2280. // --------------------------------------------------------------------
  2281. var globalActionStack = [];
  2282. var prototypeGrammar;
  2283. var prototypeGrammarSemantics;
  2284. // JSON is not a valid subset of JavaScript because there are two possible line terminators,
  2285. // U+2028 (line separator) and U+2029 (paragraph separator) that are allowed in JSON strings
  2286. // but not in JavaScript strings.
  2287. // jsonToJS() properly encodes those two characters in JSON so that it can seamlessly be
  2288. // inserted into JavaScript code (plus the encoded version is still valid JSON)
  2289. function jsonToJS(str) {
  2290. var output = str.replace(/[\u2028\u2029]/g, function(char, pos, str) {
  2291. var hex = char.codePointAt(0).toString(16);
  2292. return '\\u' + '0000'.slice(hex.length) + hex;
  2293. });
  2294. return output;
  2295. }
  2296. // ----------------- Wrappers -----------------
  2297. // Wrappers decorate CST nodes with all of the functionality (i.e., operations and attributes)
  2298. // provided by a Semantics (see below). `Wrapper` is the abstract superclass of all wrappers. A
  2299. // `Wrapper` must have `_node` and `_semantics` instance variables, which refer to the CST node and
  2300. // Semantics (resp.) for which it was created, and a `_childWrappers` instance variable which is
  2301. // used to cache the wrapper instances that are created for its child nodes. Setting these instance
  2302. // variables is the responsibility of the constructor of each Semantics-specific subclass of
  2303. // `Wrapper`.
  2304. function Wrapper() {}
  2305. Wrapper.prototype.toString = function() {
  2306. return '[semantics wrapper for ' + this._node.grammar.name + ']';
  2307. };
  2308. // This is used by ohm editor to display a node wrapper appropriately.
  2309. Wrapper.prototype.toJSON = function() {
  2310. return this.toString();
  2311. };
  2312. Wrapper.prototype._forgetMemoizedResultFor = function(attributeName) {
  2313. // Remove the memoized attribute from the cstNode and all its children.
  2314. delete this._node[this._semantics.attributeKeys[attributeName]];
  2315. this.children.forEach(function(child) {
  2316. child._forgetMemoizedResultFor(attributeName);
  2317. });
  2318. };
  2319. // Returns the wrapper of the specified child node. Child wrappers are created lazily and cached in
  2320. // the parent wrapper's `_childWrappers` instance variable.
  2321. Wrapper.prototype.child = function(idx) {
  2322. if (!(0 <= idx && idx < this._node.numChildren())) {
  2323. // TODO: Consider throwing an exception here.
  2324. return undefined;
  2325. }
  2326. var childWrapper = this._childWrappers[idx];
  2327. if (!childWrapper) {
  2328. var childNode = this._node.childAt(idx);
  2329. var offset = this._node.childOffsets[idx];
  2330. var source = this._baseInterval.subInterval(offset, childNode.matchLength);
  2331. var base = childNode.isNonterminal() ? source : this._baseInterval;
  2332. childWrapper = this._childWrappers[idx] = this._semantics.wrap(childNode, source, base);
  2333. }
  2334. return childWrapper;
  2335. };
  2336. // Returns an array containing the wrappers of all of the children of the node associated with this
  2337. // wrapper.
  2338. Wrapper.prototype._children = function() {
  2339. // Force the creation of all child wrappers
  2340. for (var idx = 0; idx < this._node.numChildren(); idx++) {
  2341. this.child(idx);
  2342. }
  2343. return this._childWrappers;
  2344. };
  2345. // Returns `true` if the CST node associated with this wrapper corresponds to an iteration
  2346. // expression, i.e., a Kleene-*, Kleene-+, or an optional. Returns `false` otherwise.
  2347. Wrapper.prototype.isIteration = function() {
  2348. return this._node.isIteration();
  2349. };
  2350. // Returns `true` if the CST node associated with this wrapper is a terminal node, `false`
  2351. // otherwise.
  2352. Wrapper.prototype.isTerminal = function() {
  2353. return this._node.isTerminal();
  2354. };
  2355. // Returns `true` if the CST node associated with this wrapper is a nonterminal node, `false`
  2356. // otherwise.
  2357. Wrapper.prototype.isNonterminal = function() {
  2358. return this._node.isNonterminal();
  2359. };
  2360. // Returns `true` if the CST node associated with this wrapper is a nonterminal node
  2361. // corresponding to a syntactic rule, `false` otherwise.
  2362. Wrapper.prototype.isSyntactic = function() {
  2363. return this.isNonterminal() && this._node.isSyntactic();
  2364. };
  2365. // Returns `true` if the CST node associated with this wrapper is a nonterminal node
  2366. // corresponding to a lexical rule, `false` otherwise.
  2367. Wrapper.prototype.isLexical = function() {
  2368. return this.isNonterminal() && this._node.isLexical();
  2369. };
  2370. // Returns `true` if the CST node associated with this wrapper is an iterator node
  2371. // having either one or no child (? operator), `false` otherwise.
  2372. // Otherwise, throws an exception.
  2373. Wrapper.prototype.isOptional = function() {
  2374. return this._node.isOptional();
  2375. };
  2376. // Create a new _iter wrapper in the same semantics as this wrapper.
  2377. Wrapper.prototype.iteration = function(optChildWrappers) {
  2378. var childWrappers = optChildWrappers || [];
  2379. var childNodes = childWrappers.map(function(c) { return c._node; });
  2380. var iter = new IterationNode(this._node.grammar, childNodes, [], -1, false);
  2381. var wrapper = this._semantics.wrap(iter, null, null);
  2382. wrapper._childWrappers = childWrappers;
  2383. return wrapper;
  2384. };
  2385. Object.defineProperties(Wrapper.prototype, {
  2386. // Returns an array containing the children of this CST node.
  2387. children: {get: function() { return this._children(); }},
  2388. // Returns the name of grammar rule that created this CST node.
  2389. ctorName: {get: function() { return this._node.ctorName; }},
  2390. // TODO: Remove this eventually (deprecated in v0.12).
  2391. interval: {get: function() {
  2392. throw new Error('The `interval` property is deprecated -- use `source` instead');
  2393. }},
  2394. // Returns the number of children of this CST node.
  2395. numChildren: {get: function() { return this._node.numChildren(); }},
  2396. // Returns the primitive value of this CST node, if it's a terminal node. Otherwise,
  2397. // throws an exception.
  2398. primitiveValue: {
  2399. get: function() {
  2400. if (this.isTerminal()) {
  2401. return this._node.primitiveValue;
  2402. }
  2403. throw new TypeError(
  2404. "tried to access the 'primitiveValue' attribute of a non-terminal CST node");
  2405. }
  2406. },
  2407. // Returns the contents of the input stream consumed by this CST node.
  2408. sourceString: {get: function() { return this.source.contents; }}
  2409. });
  2410. // ----------------- Semantics -----------------
  2411. // A Semantics is a container for a family of Operations and Attributes for a given grammar.
  2412. // Semantics enable modularity (different clients of a grammar can create their set of operations
  2413. // and attributes in isolation) and extensibility even when operations and attributes are mutually-
  2414. // recursive. This constructor should not be called directly except from
  2415. // `Semantics.createSemantics`. The normal ways to create a Semantics, given a grammar 'g', are
  2416. // `g.createSemantics()` and `g.extendSemantics(parentSemantics)`.
  2417. function Semantics(grammar, superSemantics) {
  2418. var self = this;
  2419. this.grammar = grammar;
  2420. this.checkedActionDicts = false;
  2421. // Constructor for wrapper instances, which are passed as the arguments to the semantic actions
  2422. // of an operation or attribute. Operations and attributes require double dispatch: the semantic
  2423. // action is chosen based on both the node's type and the semantics. Wrappers ensure that
  2424. // the `execute` method is called with the correct (most specific) semantics object as an
  2425. // argument.
  2426. this.Wrapper = function(node, sourceInterval, baseInterval) {
  2427. self.checkActionDictsIfHaventAlready();
  2428. this._semantics = self;
  2429. this._node = node;
  2430. this.source = sourceInterval;
  2431. // The interval that the childOffsets of `node` are relative to. It should be the source
  2432. // of the closest Nonterminal node.
  2433. this._baseInterval = baseInterval;
  2434. if (node.isNonterminal()) {
  2435. common.assert(sourceInterval === baseInterval);
  2436. }
  2437. this._childWrappers = [];
  2438. };
  2439. this.super = superSemantics;
  2440. if (superSemantics) {
  2441. if (!(grammar.equals(this.super.grammar) || grammar._inheritsFrom(this.super.grammar))) {
  2442. throw new Error(
  2443. "Cannot extend a semantics for grammar '" + this.super.grammar.name +
  2444. "' for use with grammar '" + grammar.name + "' (not a sub-grammar)");
  2445. }
  2446. inherits(this.Wrapper, this.super.Wrapper);
  2447. this.operations = Object.create(this.super.operations);
  2448. this.attributes = Object.create(this.super.attributes);
  2449. this.attributeKeys = Object.create(null);
  2450. // Assign unique symbols for each of the attributes inherited from the super-semantics so that
  2451. // they are memoized independently.
  2452. for (var attributeName in this.attributes) {
  2453. this.attributeKeys[attributeName] = Symbol();
  2454. }
  2455. } else {
  2456. inherits(this.Wrapper, Wrapper);
  2457. this.operations = Object.create(null);
  2458. this.attributes = Object.create(null);
  2459. this.attributeKeys = Object.create(null);
  2460. }
  2461. }
  2462. Semantics.prototype.toString = function() {
  2463. return '[semantics for ' + this.grammar.name + ']';
  2464. };
  2465. Semantics.prototype.checkActionDictsIfHaventAlready = function() {
  2466. if (!this.checkedActionDicts) {
  2467. this.checkActionDicts();
  2468. this.checkedActionDicts = true;
  2469. }
  2470. };
  2471. // Checks that the action dictionaries for all operations and attributes in this semantics,
  2472. // including the ones that were inherited from the super-semantics, agree with the grammar.
  2473. // Throws an exception if one or more of them doesn't.
  2474. Semantics.prototype.checkActionDicts = function() {
  2475. var name;
  2476. for (name in this.operations) {
  2477. this.operations[name].checkActionDict(this.grammar);
  2478. }
  2479. for (name in this.attributes) {
  2480. this.attributes[name].checkActionDict(this.grammar);
  2481. }
  2482. };
  2483. Semantics.prototype.toRecipe = function(semanticsOnly) {
  2484. function hasSuperSemantics(s) {
  2485. return s.super !== Semantics.BuiltInSemantics._getSemantics();
  2486. }
  2487. var str = '(function(g) {\n';
  2488. if (hasSuperSemantics(this)) {
  2489. str += ' var semantics = ' + this.super.toRecipe(true) + '(g';
  2490. var superSemanticsGrammar = this.super.grammar;
  2491. var relatedGrammar = this.grammar;
  2492. while (relatedGrammar !== superSemanticsGrammar) {
  2493. str += '.superGrammar';
  2494. relatedGrammar = relatedGrammar.superGrammar;
  2495. }
  2496. str += ');\n';
  2497. str += ' return g.extendSemantics(semantics)';
  2498. } else {
  2499. str += ' return g.createSemantics()';
  2500. }
  2501. ['Operation', 'Attribute'].forEach(function(type) {
  2502. var semanticOperations = this[type.toLowerCase() + 's'];
  2503. Object.keys(semanticOperations).forEach(function(name) {
  2504. var signature = name;
  2505. if (semanticOperations[name].formals.length > 0) {
  2506. signature += '(' + semanticOperations[name].formals.join(', ') + ')';
  2507. }
  2508. var method;
  2509. if (hasSuperSemantics(this) && this.super[type.toLowerCase() + 's'][name]) {
  2510. method = 'extend' + type;
  2511. } else {
  2512. method = 'add' + type;
  2513. }
  2514. str += '\n .' + method + '(' + JSON.stringify(signature) + ', {';
  2515. var actions = semanticOperations[name].actionDict;
  2516. var srcArray = [];
  2517. Object.keys(actions).forEach(function(actionName) {
  2518. if (semanticOperations[name].builtInDefault !== actions[actionName]) {
  2519. srcArray.push('\n ' + JSON.stringify(actionName) + ': ' +
  2520. actions[actionName].toString());
  2521. }
  2522. });
  2523. str += srcArray.join(',');
  2524. str += '\n })';
  2525. }, this);
  2526. }, this);
  2527. str += ';\n })';
  2528. if (!semanticsOnly) {
  2529. str =
  2530. '(function() {\n' +
  2531. ' var grammar = this.fromRecipe(' + jsonToJS(this.grammar.toRecipe()) + ');\n' +
  2532. ' var semantics = ' + str + '(grammar);\n' +
  2533. ' return semantics;\n' +
  2534. '});\n';
  2535. }
  2536. return str;
  2537. };
  2538. function parseSignature(signature, type) {
  2539. if (!prototypeGrammar) {
  2540. // The Operations and Attributes grammar won't be available while Ohm is loading,
  2541. // but we can get away the following simplification b/c none of the operations
  2542. // that are used while loading take arguments.
  2543. common.assert(signature.indexOf('(') === -1);
  2544. return {
  2545. name: signature,
  2546. formals: []
  2547. };
  2548. }
  2549. var r = prototypeGrammar.match(
  2550. signature,
  2551. type === 'operation' ? 'OperationSignature' : 'AttributeSignature');
  2552. if (r.failed()) {
  2553. throw new Error(r.message);
  2554. }
  2555. return prototypeGrammarSemantics(r).parse();
  2556. }
  2557. function newDefaultAction(type, name, doIt) {
  2558. return function(children) {
  2559. var self = this;
  2560. var thisThing = this._semantics.operations[name] || this._semantics.attributes[name];
  2561. var args = thisThing.formals.map(function(formal) {
  2562. return self.args[formal];
  2563. });
  2564. if (this.isIteration()) {
  2565. // This CST node corresponds to an iteration expression in the grammar (*, +, or ?). The
  2566. // default behavior is to map this operation or attribute over all of its child nodes.
  2567. return children.map(function(child) { return doIt.apply(child, args); });
  2568. }
  2569. // This CST node corresponds to a non-terminal in the grammar (e.g., AddExpr). The fact that
  2570. // we got here means that this action dictionary doesn't have an action for this particular
  2571. // non-terminal or a generic `_nonterminal` action.
  2572. if (children.length === 1) {
  2573. // As a convenience, if this node only has one child, we just return the result of
  2574. // applying this operation / attribute to the child node.
  2575. return doIt.apply(children[0], args);
  2576. } else {
  2577. // Otherwise, we throw an exception to let the programmer know that we don't know what
  2578. // to do with this node.
  2579. throw errors.missingSemanticAction(this.ctorName, name, type, globalActionStack);
  2580. }
  2581. };
  2582. }
  2583. Semantics.prototype.addOperationOrAttribute = function(type, signature, actionDict) {
  2584. var typePlural = type + 's';
  2585. var parsedNameAndFormalArgs = parseSignature(signature, type);
  2586. var name = parsedNameAndFormalArgs.name;
  2587. var formals = parsedNameAndFormalArgs.formals;
  2588. // TODO: check that there are no duplicate formal arguments
  2589. this.assertNewName(name, type);
  2590. // Create the action dictionary for this operation / attribute that contains a `_default` action
  2591. // which defines the default behavior of iteration, terminal, and non-terminal nodes...
  2592. var builtInDefault = newDefaultAction(type, name, doIt);
  2593. var realActionDict = {_default: builtInDefault};
  2594. // ... and add in the actions supplied by the programmer, which may override some or all of the
  2595. // default ones.
  2596. Object.keys(actionDict).forEach(function(name) {
  2597. realActionDict[name] = actionDict[name];
  2598. });
  2599. var entry = type === 'operation' ?
  2600. new Operation(name, formals, realActionDict, builtInDefault) :
  2601. new Attribute(name, realActionDict, builtInDefault);
  2602. // The following check is not strictly necessary (it will happen later anyway) but it's better to
  2603. // catch errors early.
  2604. entry.checkActionDict(this.grammar);
  2605. this[typePlural][name] = entry;
  2606. function doIt() {
  2607. // Dispatch to most specific version of this operation / attribute -- it may have been
  2608. // overridden by a sub-semantics.
  2609. var thisThing = this._semantics[typePlural][name];
  2610. // Check that the caller passed the correct number of arguments.
  2611. if (arguments.length !== thisThing.formals.length) {
  2612. throw new Error(
  2613. 'Invalid number of arguments passed to ' + name + ' ' + type + ' (expected ' +
  2614. thisThing.formals.length + ', got ' + arguments.length + ')');
  2615. }
  2616. // Create an "arguments object" from the arguments that were passed to this
  2617. // operation / attribute.
  2618. var args = Object.create(null);
  2619. for (var idx = 0; idx < arguments.length; idx++) {
  2620. var formal = thisThing.formals[idx];
  2621. args[formal] = arguments[idx];
  2622. }
  2623. var oldArgs = this.args;
  2624. this.args = args;
  2625. var ans = thisThing.execute(this._semantics, this);
  2626. this.args = oldArgs;
  2627. return ans;
  2628. }
  2629. if (type === 'operation') {
  2630. this.Wrapper.prototype[name] = doIt;
  2631. this.Wrapper.prototype[name].toString = function() {
  2632. return '[' + name + ' operation]';
  2633. };
  2634. } else {
  2635. Object.defineProperty(this.Wrapper.prototype, name, {
  2636. get: doIt,
  2637. configurable: true // So the property can be deleted.
  2638. });
  2639. this.attributeKeys[name] = Symbol();
  2640. }
  2641. };
  2642. Semantics.prototype.extendOperationOrAttribute = function(type, name, actionDict) {
  2643. var typePlural = type + 's';
  2644. // Make sure that `name` really is just a name, i.e., that it doesn't also contain formals.
  2645. parseSignature(name, 'attribute');
  2646. if (!(this.super && name in this.super[typePlural])) {
  2647. throw new Error('Cannot extend ' + type + " '" + name +
  2648. "': did not inherit an " + type + ' with that name');
  2649. }
  2650. if (Object.prototype.hasOwnProperty.call(this[typePlural], name)) {
  2651. throw new Error('Cannot extend ' + type + " '" + name + "' again");
  2652. }
  2653. // Create a new operation / attribute whose actionDict delegates to the super operation /
  2654. // attribute's actionDict, and which has all the keys from `inheritedActionDict`.
  2655. var inheritedFormals = this[typePlural][name].formals;
  2656. var inheritedActionDict = this[typePlural][name].actionDict;
  2657. var newActionDict = Object.create(inheritedActionDict);
  2658. Object.keys(actionDict).forEach(function(name) {
  2659. newActionDict[name] = actionDict[name];
  2660. });
  2661. this[typePlural][name] = type === 'operation' ?
  2662. new Operation(name, inheritedFormals, newActionDict) :
  2663. new Attribute(name, newActionDict);
  2664. // The following check is not strictly necessary (it will happen later anyway) but it's better to
  2665. // catch errors early.
  2666. this[typePlural][name].checkActionDict(this.grammar);
  2667. };
  2668. Semantics.prototype.assertNewName = function(name, type) {
  2669. if (Wrapper.prototype.hasOwnProperty(name)) {
  2670. throw new Error(
  2671. 'Cannot add ' + type + " '" + name + "': that's a reserved name");
  2672. }
  2673. if (name in this.operations) {
  2674. throw new Error(
  2675. 'Cannot add ' + type + " '" + name + "': an operation with that name already exists");
  2676. }
  2677. if (name in this.attributes) {
  2678. throw new Error(
  2679. 'Cannot add ' + type + " '" + name + "': an attribute with that name already exists");
  2680. }
  2681. };
  2682. // Returns a wrapper for the given CST `node` in this semantics.
  2683. // If `node` is already a wrapper, returns `node` itself. // TODO: why is this needed?
  2684. Semantics.prototype.wrap = function(node, source, optBaseInterval) {
  2685. var baseInterval = optBaseInterval || source;
  2686. return node instanceof this.Wrapper ? node : new this.Wrapper(node, source, baseInterval);
  2687. };
  2688. // Creates a new Semantics instance for `grammar`, inheriting operations and attributes from
  2689. // `optSuperSemantics`, if it is specified. Returns a function that acts as a proxy for the new
  2690. // Semantics instance. When that function is invoked with a CST node as an argument, it returns
  2691. // a wrapper for that node which gives access to the operations and attributes provided by this
  2692. // semantics.
  2693. Semantics.createSemantics = function(grammar, optSuperSemantics) {
  2694. var s = new Semantics(
  2695. grammar,
  2696. optSuperSemantics !== undefined ?
  2697. optSuperSemantics :
  2698. Semantics.BuiltInSemantics._getSemantics());
  2699. // To enable clients to invoke a semantics like a function, return a function that acts as a proxy
  2700. // for `s`, which is the real `Semantics` instance.
  2701. var proxy = function ASemantics(matchResult) {
  2702. if (!(matchResult instanceof MatchResult)) {
  2703. throw new TypeError(
  2704. 'Semantics expected a MatchResult, but got ' + common.unexpectedObjToString(matchResult));
  2705. }
  2706. if (matchResult.failed()) {
  2707. throw new TypeError('cannot apply Semantics to ' + matchResult.toString());
  2708. }
  2709. var cst = matchResult._cst;
  2710. if (cst.grammar !== grammar) {
  2711. throw new Error(
  2712. "Cannot use a MatchResult from grammar '" + cst.grammar.name +
  2713. "' with a semantics for '" + grammar.name + "'");
  2714. }
  2715. var inputStream = new InputStream(matchResult.input);
  2716. return s.wrap(cst, inputStream.interval(matchResult._cstOffset, matchResult.input.length));
  2717. };
  2718. // Forward public methods from the proxy to the semantics instance.
  2719. proxy.addOperation = function(signature, actionDict) {
  2720. s.addOperationOrAttribute('operation', signature, actionDict);
  2721. return proxy;
  2722. };
  2723. proxy.extendOperation = function(name, actionDict) {
  2724. s.extendOperationOrAttribute('operation', name, actionDict);
  2725. return proxy;
  2726. };
  2727. proxy.addAttribute = function(name, actionDict) {
  2728. s.addOperationOrAttribute('attribute', name, actionDict);
  2729. return proxy;
  2730. };
  2731. proxy.extendAttribute = function(name, actionDict) {
  2732. s.extendOperationOrAttribute('attribute', name, actionDict);
  2733. return proxy;
  2734. };
  2735. proxy._getActionDict = function(operationOrAttributeName) {
  2736. var action = s.operations[operationOrAttributeName] || s.attributes[operationOrAttributeName];
  2737. if (!action) {
  2738. throw new Error('"' + operationOrAttributeName + '" is not a valid operation or attribute ' +
  2739. 'name in this semantics for "' + grammar.name + '"');
  2740. }
  2741. return action.actionDict;
  2742. };
  2743. proxy._remove = function(operationOrAttributeName) {
  2744. var semantic;
  2745. if (operationOrAttributeName in s.operations) {
  2746. semantic = s.operations[operationOrAttributeName];
  2747. delete s.operations[operationOrAttributeName];
  2748. } else if (operationOrAttributeName in s.attributes) {
  2749. semantic = s.attributes[operationOrAttributeName];
  2750. delete s.attributes[operationOrAttributeName];
  2751. }
  2752. delete s.Wrapper.prototype[operationOrAttributeName];
  2753. return semantic;
  2754. };
  2755. proxy.getOperationNames = function() {
  2756. return Object.keys(s.operations);
  2757. };
  2758. proxy.getAttributeNames = function() {
  2759. return Object.keys(s.attributes);
  2760. };
  2761. proxy.getGrammar = function() {
  2762. return s.grammar;
  2763. };
  2764. proxy.toRecipe = function(semanticsOnly) {
  2765. return s.toRecipe(semanticsOnly);
  2766. };
  2767. // Make the proxy's toString() work.
  2768. proxy.toString = s.toString.bind(s);
  2769. // Returns the semantics for the proxy.
  2770. proxy._getSemantics = function() {
  2771. return s;
  2772. };
  2773. return proxy;
  2774. };
  2775. // ----------------- Operation -----------------
  2776. // An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very
  2777. // similar to a Visitor (http://en.wikipedia.org/wiki/Visitor_pattern). An operation is executed by
  2778. // recursively walking the CST, and at each node, invoking the matching semantic action from
  2779. // `actionDict`. See `Operation.prototype.execute` for details of how a CST node's matching semantic
  2780. // action is found.
  2781. function Operation(name, formals, actionDict, builtInDefault) {
  2782. this.name = name;
  2783. this.formals = formals;
  2784. this.actionDict = actionDict;
  2785. this.builtInDefault = builtInDefault;
  2786. }
  2787. Operation.prototype.typeName = 'operation';
  2788. Operation.prototype.checkActionDict = function(grammar) {
  2789. grammar._checkTopDownActionDict(this.typeName, this.name, this.actionDict);
  2790. };
  2791. // Execute this operation on the CST node associated with `nodeWrapper` in the context of the given
  2792. // Semantics instance.
  2793. Operation.prototype.execute = function(semantics, nodeWrapper) {
  2794. try {
  2795. // Look for a semantic action whose name matches the node's constructor name, which is either
  2796. // the name of a rule in the grammar, or '_terminal' (for a terminal node), or '_iter' (for an
  2797. // iteration node). In the latter case, the action function receives a single argument, which
  2798. // is an array containing all of the children of the CST node.
  2799. var ctorName = nodeWrapper._node.ctorName;
  2800. var actionFn = this.actionDict[ctorName];
  2801. var ans;
  2802. if (actionFn) {
  2803. globalActionStack.push([this, ctorName]);
  2804. ans = this.doAction(semantics, nodeWrapper, actionFn, nodeWrapper.isIteration());
  2805. return ans;
  2806. }
  2807. // The action dictionary does not contain a semantic action for this specific type of node.
  2808. // If this is a nonterminal node and the programmer has provided a `_nonterminal` semantic
  2809. // action, we invoke it:
  2810. if (nodeWrapper.isNonterminal()) {
  2811. actionFn = this.actionDict._nonterminal;
  2812. if (actionFn) {
  2813. globalActionStack.push([this, '_nonterminal', ctorName]);
  2814. ans = this.doAction(semantics, nodeWrapper, actionFn, true);
  2815. return ans;
  2816. }
  2817. }
  2818. // Otherwise, we invoke the '_default' semantic action.
  2819. globalActionStack.push([this, 'default action', ctorName]);
  2820. ans = this.doAction(semantics, nodeWrapper, this.actionDict._default, true);
  2821. return ans;
  2822. } finally {
  2823. globalActionStack.pop();
  2824. }
  2825. };
  2826. // Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of
  2827. // `semantics`. If `optPassChildrenAsArray` is truthy, `actionFn` will be called with a single
  2828. // argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will
  2829. // be equal to the number of children in the CST node.
  2830. Operation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) {
  2831. return optPassChildrenAsArray ?
  2832. actionFn.call(nodeWrapper, nodeWrapper._children()) :
  2833. actionFn.apply(nodeWrapper, nodeWrapper._children());
  2834. };
  2835. // ----------------- Attribute -----------------
  2836. // Attributes are Operations whose results are memoized. This means that, for any given semantics,
  2837. // the semantic action for a CST node will be invoked no more than once.
  2838. function Attribute(name, actionDict, builtInDefault) {
  2839. this.name = name;
  2840. this.formals = [];
  2841. this.actionDict = actionDict;
  2842. this.builtInDefault = builtInDefault;
  2843. }
  2844. inherits(Attribute, Operation);
  2845. Attribute.prototype.typeName = 'attribute';
  2846. Attribute.prototype.execute = function(semantics, nodeWrapper) {
  2847. var node = nodeWrapper._node;
  2848. var key = semantics.attributeKeys[this.name];
  2849. if (!node.hasOwnProperty(key)) {
  2850. // The following is a super-send -- isn't JS beautiful? :/
  2851. node[key] = Operation.prototype.execute.call(this, semantics, nodeWrapper);
  2852. }
  2853. return node[key];
  2854. };
  2855. // ----------------- Deferred initialization -----------------
  2856. util.awaitBuiltInRules(function(builtInRules) {
  2857. var operationsAndAttributesGrammar = require('../dist/operations-and-attributes');
  2858. initBuiltInSemantics(builtInRules);
  2859. initPrototypeParser(operationsAndAttributesGrammar); // requires BuiltInSemantics
  2860. });
  2861. function initBuiltInSemantics(builtInRules) {
  2862. var actions = {
  2863. empty: function() {
  2864. return this.iteration();
  2865. },
  2866. nonEmpty: function(first, _, rest) {
  2867. return this.iteration([first].concat(rest.children));
  2868. }
  2869. };
  2870. Semantics.BuiltInSemantics = Semantics
  2871. .createSemantics(builtInRules, null)
  2872. .addOperation('asIteration', {
  2873. emptyListOf: actions.empty,
  2874. nonemptyListOf: actions.nonEmpty,
  2875. EmptyListOf: actions.empty,
  2876. NonemptyListOf: actions.nonEmpty
  2877. });
  2878. }
  2879. function initPrototypeParser(grammar) {
  2880. prototypeGrammarSemantics = grammar.createSemantics().addOperation('parse', {
  2881. AttributeSignature: function(name) {
  2882. return {
  2883. name: name.parse(),
  2884. formals: []
  2885. };
  2886. },
  2887. OperationSignature: function(name, optFormals) {
  2888. return {
  2889. name: name.parse(),
  2890. formals: optFormals.parse()[0] || []
  2891. };
  2892. },
  2893. Formals: function(oparen, fs, cparen) {
  2894. return fs.asIteration().parse();
  2895. },
  2896. name: function(first, rest) {
  2897. return this.sourceString;
  2898. }
  2899. });
  2900. prototypeGrammar = grammar;
  2901. };
  2902. // --------------------------------------------------------------------
  2903. // Exports
  2904. // --------------------------------------------------------------------
  2905. module.exports = Semantics;
  2906. },{"../dist/operations-and-attributes":3,"./InputStream":35,"./MatchResult":37,"./common":44,"./errors":45,"./nodes":47,"./util":65,"es6-symbol":22,"inherits":27}],43:[function(require,module,exports){
  2907. 'use strict';
  2908. // --------------------------------------------------------------------
  2909. // Imports
  2910. // --------------------------------------------------------------------
  2911. var Interval = require('./Interval');
  2912. var common = require('./common');
  2913. // --------------------------------------------------------------------
  2914. // Private stuff
  2915. // --------------------------------------------------------------------
  2916. // Unicode characters that are used in the `toString` output.
  2917. var BALLOT_X = '\u2717';
  2918. var CHECK_MARK = '\u2713';
  2919. var DOT_OPERATOR = '\u22C5';
  2920. var RIGHTWARDS_DOUBLE_ARROW = '\u21D2';
  2921. var SYMBOL_FOR_HORIZONTAL_TABULATION = '\u2409';
  2922. var SYMBOL_FOR_LINE_FEED = '\u240A';
  2923. var SYMBOL_FOR_CARRIAGE_RETURN = '\u240D';
  2924. var Flags = {
  2925. succeeded: 1 << 0,
  2926. isRootNode: 1 << 1,
  2927. isImplicitSpaces: 1 << 2,
  2928. isMemoized: 1 << 3,
  2929. isHeadOfLeftRecursion: 1 << 4,
  2930. terminatesLR: 1 << 5
  2931. };
  2932. function spaces(n) {
  2933. return common.repeat(' ', n).join('');
  2934. }
  2935. // Return a string representation of a portion of `input` at offset `pos`.
  2936. // The result will contain exactly `len` characters.
  2937. function getInputExcerpt(input, pos, len) {
  2938. var excerpt = asEscapedString(input.slice(pos, pos + len));
  2939. // Pad the output if necessary.
  2940. if (excerpt.length < len) {
  2941. return excerpt + common.repeat(' ', len - excerpt.length).join('');
  2942. }
  2943. return excerpt;
  2944. }
  2945. function asEscapedString(obj) {
  2946. if (typeof obj === 'string') {
  2947. // Replace non-printable characters with visible symbols.
  2948. return obj
  2949. .replace(/ /g, DOT_OPERATOR)
  2950. .replace(/\t/g, SYMBOL_FOR_HORIZONTAL_TABULATION)
  2951. .replace(/\n/g, SYMBOL_FOR_LINE_FEED)
  2952. .replace(/\r/g, SYMBOL_FOR_CARRIAGE_RETURN);
  2953. }
  2954. return String(obj);
  2955. }
  2956. // ----------------- Trace -----------------
  2957. function Trace(input, pos1, pos2, expr, succeeded, bindings, optChildren) {
  2958. this.input = input;
  2959. this.pos = this.pos1 = pos1;
  2960. this.pos2 = pos2;
  2961. this.source = new Interval(input, pos1, pos2);
  2962. this.expr = expr;
  2963. this.bindings = bindings;
  2964. this.children = optChildren || [];
  2965. this.terminatingLREntry = null;
  2966. this._flags = succeeded ? Flags.succeeded : 0;
  2967. }
  2968. // A value that can be returned from visitor functions to indicate that a
  2969. // node should not be recursed into.
  2970. Trace.prototype.SKIP = {};
  2971. Object.defineProperty(Trace.prototype, 'displayString', {
  2972. get: function() { return this.expr.toDisplayString(); }
  2973. });
  2974. // For convenience, create a getter and setter for the boolean flags in `Flags`.
  2975. Object.keys(Flags).forEach(function(name) {
  2976. var mask = Flags[name];
  2977. Object.defineProperty(Trace.prototype, name, {
  2978. get: function() {
  2979. return (this._flags & mask) !== 0;
  2980. },
  2981. set: function(val) {
  2982. if (val) {
  2983. this._flags |= mask;
  2984. } else {
  2985. this._flags &= ~mask;
  2986. }
  2987. }
  2988. });
  2989. });
  2990. Trace.prototype.clone = function() {
  2991. return this.cloneWithExpr(this.expr);
  2992. };
  2993. Trace.prototype.cloneWithExpr = function(expr) {
  2994. var ans = new Trace(
  2995. this.input, this.pos, this.pos2, expr, this.succeeded, this.bindings, this.children);
  2996. ans.isHeadOfLeftRecursion = this.isHeadOfLeftRecursion;
  2997. ans.isImplicitSpaces = this.isImplicitSpaces;
  2998. ans.isMemoized = this.isMemoized;
  2999. ans.isRootNode = this.isRootNode;
  3000. ans.terminatesLR = this.terminatesLR;
  3001. ans.terminatingLREntry = this.terminatingLREntry;
  3002. return ans;
  3003. };
  3004. // Record the trace information for the terminating condition of the LR loop.
  3005. Trace.prototype.recordLRTermination = function(ruleBodyTrace, value) {
  3006. this.terminatingLREntry =
  3007. new Trace(this.input, this.pos, this.pos2, this.expr, false, [value], [ruleBodyTrace]);
  3008. this.terminatingLREntry.terminatesLR = true;
  3009. };
  3010. // Recursively traverse this trace node and all its descendents, calling a visitor function
  3011. // for each node that is visited. If `vistorObjOrFn` is an object, then its 'enter' property
  3012. // is a function to call before visiting the children of a node, and its 'exit' property is
  3013. // a function to call afterwards. If `visitorObjOrFn` is a function, it represents the 'enter'
  3014. // function.
  3015. //
  3016. // The functions are called with three arguments: the Trace node, its parent Trace, and a number
  3017. // representing the depth of the node in the tree. (The root node has depth 0.) `optThisArg`, if
  3018. // specified, is the value to use for `this` when executing the visitor functions.
  3019. Trace.prototype.walk = function(visitorObjOrFn, optThisArg) {
  3020. var visitor = visitorObjOrFn;
  3021. if (typeof visitor === 'function') {
  3022. visitor = {enter: visitor};
  3023. }
  3024. function _walk(node, parent, depth) {
  3025. var recurse = true;
  3026. if (visitor.enter) {
  3027. if (visitor.enter.call(optThisArg, node, parent, depth) === Trace.prototype.SKIP) {
  3028. recurse = false;
  3029. }
  3030. }
  3031. if (recurse) {
  3032. node.children.forEach(function(child) {
  3033. _walk(child, node, depth + 1);
  3034. });
  3035. if (visitor.exit) {
  3036. visitor.exit.call(optThisArg, node, parent, depth);
  3037. }
  3038. }
  3039. }
  3040. if (this.isRootNode) {
  3041. // Don't visit the root node itself, only its children.
  3042. this.children.forEach(function(c) { _walk(c, null, 0); });
  3043. } else {
  3044. _walk(this, null, 0);
  3045. }
  3046. };
  3047. // Return a string representation of the trace.
  3048. // Sample:
  3049. // 12⋅+⋅2⋅*⋅3 ✓ exp ⇒ "12"
  3050. // 12⋅+⋅2⋅*⋅3 ✓ addExp (LR) ⇒ "12"
  3051. // 12⋅+⋅2⋅*⋅3 ✗ addExp_plus
  3052. Trace.prototype.toString = function() {
  3053. var sb = new common.StringBuffer();
  3054. this.walk(function(node, parent, depth) {
  3055. if (!node) {
  3056. return this.SKIP;
  3057. }
  3058. var ctorName = node.expr.constructor.name;
  3059. // Don't print anything for Alt nodes.
  3060. if (ctorName === 'Alt') {
  3061. return; // eslint-disable-line consistent-return
  3062. }
  3063. sb.append(getInputExcerpt(node.input, node.pos, 10) + spaces(depth * 2 + 1));
  3064. sb.append((node.succeeded ? CHECK_MARK : BALLOT_X) + ' ' + node.displayString);
  3065. if (node.isHeadOfLeftRecursion) {
  3066. sb.append(' (LR)');
  3067. }
  3068. if (node.succeeded) {
  3069. var contents = asEscapedString(node.source.contents);
  3070. sb.append(' ' + RIGHTWARDS_DOUBLE_ARROW + ' ');
  3071. sb.append(typeof contents === 'string' ? '"' + contents + '"' : contents);
  3072. }
  3073. sb.append('\n');
  3074. }.bind(this));
  3075. return sb.contents();
  3076. };
  3077. // --------------------------------------------------------------------
  3078. // Exports
  3079. // --------------------------------------------------------------------
  3080. module.exports = Trace;
  3081. },{"./Interval":36,"./common":44}],44:[function(require,module,exports){
  3082. 'use strict';
  3083. // --------------------------------------------------------------------
  3084. // Imports
  3085. // --------------------------------------------------------------------
  3086. var extend = require('util-extend');
  3087. // --------------------------------------------------------------------
  3088. // Private Stuff
  3089. // --------------------------------------------------------------------
  3090. // Helpers
  3091. var escapeStringFor = {};
  3092. for (var c = 0; c < 128; c++) {
  3093. escapeStringFor[c] = String.fromCharCode(c);
  3094. }
  3095. escapeStringFor["'".charCodeAt(0)] = "\\'";
  3096. escapeStringFor['"'.charCodeAt(0)] = '\\"';
  3097. escapeStringFor['\\'.charCodeAt(0)] = '\\\\';
  3098. escapeStringFor['\b'.charCodeAt(0)] = '\\b';
  3099. escapeStringFor['\f'.charCodeAt(0)] = '\\f';
  3100. escapeStringFor['\n'.charCodeAt(0)] = '\\n';
  3101. escapeStringFor['\r'.charCodeAt(0)] = '\\r';
  3102. escapeStringFor['\t'.charCodeAt(0)] = '\\t';
  3103. escapeStringFor['\u000b'.charCodeAt(0)] = '\\v';
  3104. // --------------------------------------------------------------------
  3105. // Exports
  3106. // --------------------------------------------------------------------
  3107. exports.abstract = function(optMethodName) {
  3108. var methodName = optMethodName || '';
  3109. return function() {
  3110. throw new Error(
  3111. 'this method ' + methodName + ' is abstract! ' +
  3112. '(it has no implementation in class ' + this.constructor.name + ')');
  3113. };
  3114. };
  3115. exports.assert = function(cond, message) {
  3116. if (!cond) {
  3117. throw new Error(message);
  3118. }
  3119. };
  3120. // Define a lazily-computed, non-enumerable property named `propName`
  3121. // on the object `obj`. `getterFn` will be called to compute the value the
  3122. // first time the property is accessed.
  3123. exports.defineLazyProperty = function(obj, propName, getterFn) {
  3124. var memo;
  3125. Object.defineProperty(obj, propName, {
  3126. get: function() {
  3127. if (!memo) {
  3128. memo = getterFn.call(this);
  3129. }
  3130. return memo;
  3131. }
  3132. });
  3133. };
  3134. exports.clone = function(obj) {
  3135. if (obj) {
  3136. return extend({}, obj);
  3137. }
  3138. return obj;
  3139. };
  3140. exports.extend = extend;
  3141. exports.repeatFn = function(fn, n) {
  3142. var arr = [];
  3143. while (n-- > 0) {
  3144. arr.push(fn());
  3145. }
  3146. return arr;
  3147. };
  3148. exports.repeatStr = function(str, n) {
  3149. return new Array(n + 1).join(str);
  3150. };
  3151. exports.repeat = function(x, n) {
  3152. return exports.repeatFn(function() { return x; }, n);
  3153. };
  3154. exports.getDuplicates = function(array) {
  3155. var duplicates = [];
  3156. for (var idx = 0; idx < array.length; idx++) {
  3157. var x = array[idx];
  3158. if (array.lastIndexOf(x) !== idx && duplicates.indexOf(x) < 0) {
  3159. duplicates.push(x);
  3160. }
  3161. }
  3162. return duplicates;
  3163. };
  3164. exports.copyWithoutDuplicates = function(array) {
  3165. var noDuplicates = [];
  3166. array.forEach(function(entry) {
  3167. if (noDuplicates.indexOf(entry) < 0) {
  3168. noDuplicates.push(entry);
  3169. }
  3170. });
  3171. return noDuplicates;
  3172. };
  3173. exports.isSyntactic = function(ruleName) {
  3174. var firstChar = ruleName[0];
  3175. return firstChar === firstChar.toUpperCase();
  3176. };
  3177. exports.isLexical = function(ruleName) {
  3178. return !exports.isSyntactic(ruleName);
  3179. };
  3180. exports.padLeft = function(str, len, optChar) {
  3181. var ch = optChar || ' ';
  3182. if (str.length < len) {
  3183. return exports.repeatStr(ch, len - str.length) + str;
  3184. }
  3185. return str;
  3186. };
  3187. // StringBuffer
  3188. exports.StringBuffer = function() {
  3189. this.strings = [];
  3190. };
  3191. exports.StringBuffer.prototype.append = function(str) {
  3192. this.strings.push(str);
  3193. };
  3194. exports.StringBuffer.prototype.contents = function() {
  3195. return this.strings.join('');
  3196. };
  3197. // Character escaping and unescaping
  3198. exports.escapeChar = function(c, optDelim) {
  3199. var charCode = c.charCodeAt(0);
  3200. if ((c === '"' || c === "'") && optDelim && c !== optDelim) {
  3201. return c;
  3202. } else if (charCode < 128) {
  3203. return escapeStringFor[charCode];
  3204. } else if (128 <= charCode && charCode < 256) {
  3205. return '\\x' + exports.padLeft(charCode.toString(16), 2, '0');
  3206. } else {
  3207. return '\\u' + exports.padLeft(charCode.toString(16), 4, '0');
  3208. }
  3209. };
  3210. exports.unescapeChar = function(s) {
  3211. if (s.charAt(0) === '\\') {
  3212. switch (s.charAt(1)) {
  3213. case 'b': return '\b';
  3214. case 'f': return '\f';
  3215. case 'n': return '\n';
  3216. case 'r': return '\r';
  3217. case 't': return '\t';
  3218. case 'v': return '\v';
  3219. case 'x': return String.fromCharCode(parseInt(s.substring(2, 4), 16));
  3220. case 'u': return String.fromCharCode(parseInt(s.substring(2, 6), 16));
  3221. default: return s.charAt(1);
  3222. }
  3223. } else {
  3224. return s;
  3225. }
  3226. };
  3227. // Helper for producing a description of an unknown object in a safe way.
  3228. // Especially useful for error messages where an unexpected type of object was encountered.
  3229. exports.unexpectedObjToString = function(obj) {
  3230. if (obj == null) {
  3231. return String(obj);
  3232. }
  3233. var baseToString = Object.prototype.toString.call(obj);
  3234. try {
  3235. var typeName;
  3236. if (obj.constructor && obj.constructor.name) {
  3237. typeName = obj.constructor.name;
  3238. } else if (baseToString.indexOf('[object ') === 0) {
  3239. typeName = baseToString.slice(8, -1); // Extract e.g. "Array" from "[object Array]".
  3240. } else {
  3241. typeName = typeof obj;
  3242. }
  3243. return typeName + ': ' + JSON.stringify(String(obj));
  3244. } catch (e) {
  3245. return baseToString;
  3246. }
  3247. };
  3248. },{"util-extend":29}],45:[function(require,module,exports){
  3249. 'use strict';
  3250. // --------------------------------------------------------------------
  3251. // Imports
  3252. // --------------------------------------------------------------------
  3253. var pexprs = require('./pexprs');
  3254. var Namespace = require('./Namespace');
  3255. // --------------------------------------------------------------------
  3256. // Private stuff
  3257. // --------------------------------------------------------------------
  3258. function createError(message, optInterval) {
  3259. var e;
  3260. if (optInterval) {
  3261. e = new Error(optInterval.getLineAndColumnMessage() + message);
  3262. e.shortMessage = message;
  3263. e.interval = optInterval;
  3264. } else {
  3265. e = new Error(message);
  3266. }
  3267. return e;
  3268. }
  3269. // ----------------- errors about intervals -----------------
  3270. function intervalSourcesDontMatch() {
  3271. return createError("Interval sources don't match");
  3272. }
  3273. // ----------------- errors about grammars -----------------
  3274. // Grammar syntax error
  3275. function grammarSyntaxError(matchFailure) {
  3276. var e = new Error();
  3277. Object.defineProperty(e, 'message', {get: function() { return matchFailure.message; }});
  3278. Object.defineProperty(e, 'shortMessage', {get: function() {
  3279. return 'Expected ' + matchFailure.getExpectedText();
  3280. }});
  3281. e.interval = matchFailure.getInterval();
  3282. return e;
  3283. }
  3284. // Undeclared grammar
  3285. function undeclaredGrammar(grammarName, namespace, interval) {
  3286. var message = namespace ?
  3287. 'Grammar ' + grammarName + ' is not declared in namespace ' + Namespace.toString(namespace) :
  3288. 'Undeclared grammar ' + grammarName;
  3289. return createError(message, interval);
  3290. }
  3291. // Duplicate grammar declaration
  3292. function duplicateGrammarDeclaration(grammar, namespace) {
  3293. return createError('Grammar ' + grammar.name + ' is already declared in this namespace');
  3294. }
  3295. // ----------------- rules -----------------
  3296. // Undeclared rule
  3297. function undeclaredRule(ruleName, grammarName, optInterval) {
  3298. return createError(
  3299. 'Rule ' + ruleName + ' is not declared in grammar ' + grammarName,
  3300. optInterval);
  3301. }
  3302. // Cannot override undeclared rule
  3303. function cannotOverrideUndeclaredRule(ruleName, grammarName, optSource) {
  3304. return createError(
  3305. 'Cannot override rule ' + ruleName + ' because it is not declared in ' + grammarName,
  3306. optSource);
  3307. }
  3308. // Cannot extend undeclared rule
  3309. function cannotExtendUndeclaredRule(ruleName, grammarName, optSource) {
  3310. return createError(
  3311. 'Cannot extend rule ' + ruleName + ' because it is not declared in ' + grammarName,
  3312. optSource);
  3313. }
  3314. // Duplicate rule declaration
  3315. function duplicateRuleDeclaration(ruleName, grammarName, declGrammarName, optSource) {
  3316. var message = "Duplicate declaration for rule '" + ruleName +
  3317. "' in grammar '" + grammarName + "'";
  3318. if (grammarName !== declGrammarName) {
  3319. message += " (originally declared in '" + declGrammarName + "')";
  3320. }
  3321. return createError(message, optSource);
  3322. }
  3323. // Wrong number of parameters
  3324. function wrongNumberOfParameters(ruleName, expected, actual, source) {
  3325. return createError(
  3326. 'Wrong number of parameters for rule ' + ruleName +
  3327. ' (expected ' + expected + ', got ' + actual + ')',
  3328. source);
  3329. }
  3330. // Wrong number of arguments
  3331. function wrongNumberOfArguments(ruleName, expected, actual, expr) {
  3332. return createError(
  3333. 'Wrong number of arguments for rule ' + ruleName +
  3334. ' (expected ' + expected + ', got ' + actual + ')',
  3335. expr.source);
  3336. }
  3337. // Duplicate parameter names
  3338. function duplicateParameterNames(ruleName, duplicates, source) {
  3339. return createError(
  3340. 'Duplicate parameter names in rule ' + ruleName + ': ' + duplicates.join(', '),
  3341. source);
  3342. }
  3343. // Invalid parameter expression
  3344. function invalidParameter(ruleName, expr) {
  3345. return createError(
  3346. 'Invalid parameter to rule ' + ruleName + ': ' + expr + ' has arity ' + expr.getArity() +
  3347. ', but parameter expressions must have arity 1',
  3348. expr.source);
  3349. }
  3350. // Application of syntactic rule from lexical rule
  3351. function applicationOfSyntacticRuleFromLexicalContext(ruleName, applyExpr) {
  3352. return createError(
  3353. 'Cannot apply syntactic rule ' + ruleName + ' from here (inside a lexical context)',
  3354. applyExpr.source);
  3355. }
  3356. // Incorrect argument type
  3357. function incorrectArgumentType(expectedType, expr) {
  3358. return createError('Incorrect argument type: expected ' + expectedType, expr.source);
  3359. }
  3360. // ----------------- Kleene operators -----------------
  3361. function kleeneExprHasNullableOperand(kleeneExpr, applicationStack) {
  3362. var actuals = applicationStack.length > 0 ?
  3363. applicationStack[applicationStack.length - 1].args :
  3364. [];
  3365. var expr = kleeneExpr.expr.substituteParams(actuals);
  3366. var message =
  3367. 'Nullable expression ' + expr + " is not allowed inside '" +
  3368. kleeneExpr.operator + "' (possible infinite loop)";
  3369. if (applicationStack.length > 0) {
  3370. var stackTrace = applicationStack
  3371. .map(function(app) { return new pexprs.Apply(app.ruleName, app.args); })
  3372. .join('\n');
  3373. message += '\nApplication stack (most recent application last):\n' + stackTrace;
  3374. }
  3375. return createError(message, kleeneExpr.expr.source);
  3376. }
  3377. // ----------------- arity -----------------
  3378. function inconsistentArity(ruleName, expected, actual, expr) {
  3379. return createError(
  3380. 'Rule ' + ruleName + ' involves an alternation which has inconsistent arity ' +
  3381. '(expected ' + expected + ', got ' + actual + ')',
  3382. expr.source);
  3383. }
  3384. // ----------------- properties -----------------
  3385. function duplicatePropertyNames(duplicates) {
  3386. return createError('Object pattern has duplicate property names: ' + duplicates.join(', '));
  3387. }
  3388. // ----------------- constructors -----------------
  3389. function invalidConstructorCall(grammar, ctorName, children) {
  3390. return createError(
  3391. 'Attempt to invoke constructor ' + ctorName + ' with invalid or unexpected arguments');
  3392. }
  3393. // ----------------- convenience -----------------
  3394. function multipleErrors(errors) {
  3395. var messages = errors.map(function(e) { return e.message; });
  3396. return createError(
  3397. ['Errors:'].concat(messages).join('\n- '),
  3398. errors[0].interval);
  3399. }
  3400. // ----------------- semantic -----------------
  3401. function missingSemanticAction(ctorName, name, type, stack) {
  3402. var stackTrace = stack.slice(0, -1).map(function(info) {
  3403. var ans = ' ' + info[0].name + ' > ' + info[1];
  3404. return info.length === 3
  3405. ? ans + " for '" + info[2] + "'"
  3406. : ans;
  3407. }).join('\n');
  3408. stackTrace += '\n ' + name + ' > ' + ctorName;
  3409. var where = type + " '" + name + "'";
  3410. var message = "Missing semantic action for '" + ctorName + "' in " + where + '\n' +
  3411. 'Action stack (most recent call last):\n' + stackTrace;
  3412. var e = createError(message);
  3413. e.name = 'missingSemanticAction';
  3414. return e;
  3415. }
  3416. // --------------------------------------------------------------------
  3417. // Exports
  3418. // --------------------------------------------------------------------
  3419. module.exports = {
  3420. applicationOfSyntacticRuleFromLexicalContext: applicationOfSyntacticRuleFromLexicalContext,
  3421. cannotExtendUndeclaredRule: cannotExtendUndeclaredRule,
  3422. cannotOverrideUndeclaredRule: cannotOverrideUndeclaredRule,
  3423. duplicateGrammarDeclaration: duplicateGrammarDeclaration,
  3424. duplicateParameterNames: duplicateParameterNames,
  3425. duplicatePropertyNames: duplicatePropertyNames,
  3426. duplicateRuleDeclaration: duplicateRuleDeclaration,
  3427. inconsistentArity: inconsistentArity,
  3428. incorrectArgumentType: incorrectArgumentType,
  3429. intervalSourcesDontMatch: intervalSourcesDontMatch,
  3430. invalidConstructorCall: invalidConstructorCall,
  3431. invalidParameter: invalidParameter,
  3432. grammarSyntaxError: grammarSyntaxError,
  3433. kleeneExprHasNullableOperand: kleeneExprHasNullableOperand,
  3434. missingSemanticAction: missingSemanticAction,
  3435. undeclaredGrammar: undeclaredGrammar,
  3436. undeclaredRule: undeclaredRule,
  3437. wrongNumberOfArguments: wrongNumberOfArguments,
  3438. wrongNumberOfParameters: wrongNumberOfParameters,
  3439. throwErrors: function(errors) {
  3440. if (errors.length === 1) {
  3441. throw errors[0];
  3442. }
  3443. if (errors.length > 1) {
  3444. throw multipleErrors(errors);
  3445. }
  3446. }
  3447. };
  3448. },{"./Namespace":40,"./pexprs":64}],46:[function(require,module,exports){
  3449. /* global document, XMLHttpRequest */
  3450. 'use strict';
  3451. // --------------------------------------------------------------------
  3452. // Imports
  3453. // --------------------------------------------------------------------
  3454. var Builder = require('./Builder');
  3455. var Grammar = require('./Grammar');
  3456. var Namespace = require('./Namespace');
  3457. var common = require('./common');
  3458. var errors = require('./errors');
  3459. var pexprs = require('./pexprs');
  3460. var util = require('./util');
  3461. var version = require('./version');
  3462. var isBuffer = require('is-buffer');
  3463. // --------------------------------------------------------------------
  3464. // Private stuff
  3465. // --------------------------------------------------------------------
  3466. // The metagrammar, i.e. the grammar for Ohm grammars. Initialized at the
  3467. // bottom of this file because loading the grammar requires Ohm itself.
  3468. var ohmGrammar;
  3469. // An object which makes it possible to stub out the document API for testing.
  3470. var documentInterface = {
  3471. querySelector: function(sel) { return document.querySelector(sel); },
  3472. querySelectorAll: function(sel) { return document.querySelectorAll(sel); }
  3473. };
  3474. // Check if `obj` is a DOM element.
  3475. function isElement(obj) {
  3476. return !!(obj && obj.nodeType === 1);
  3477. }
  3478. function isUndefined(obj) {
  3479. return obj === void 0; // eslint-disable-line no-void
  3480. }
  3481. var MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;
  3482. function isArrayLike(obj) {
  3483. if (obj == null) {
  3484. return false;
  3485. }
  3486. var length = obj.length;
  3487. return typeof length === 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;
  3488. }
  3489. // TODO: just use the jQuery thing
  3490. function load(url) {
  3491. var req = new XMLHttpRequest();
  3492. req.open('GET', url, false);
  3493. try {
  3494. req.send();
  3495. if (req.status === 0 || req.status === 200) {
  3496. return req.responseText;
  3497. }
  3498. } catch (e) {}
  3499. throw new Error('unable to load url ' + url);
  3500. }
  3501. // Returns a Grammar instance (i.e., an object with a `match` method) for
  3502. // `tree`, which is the concrete syntax tree of a user-written grammar.
  3503. // The grammar will be assigned into `namespace` under the name of the grammar
  3504. // as specified in the source.
  3505. function buildGrammar(match, namespace, optOhmGrammarForTesting) {
  3506. var builder = new Builder();
  3507. var decl;
  3508. var currentRuleName;
  3509. var currentRuleFormals;
  3510. var overriding = false;
  3511. var metaGrammar = optOhmGrammarForTesting || ohmGrammar;
  3512. // A visitor that produces a Grammar instance from the CST.
  3513. var helpers = metaGrammar.createSemantics().addOperation('visit', {
  3514. Grammar: function(n, s, open, rs, close) {
  3515. var grammarName = n.visit();
  3516. decl = builder.newGrammar(grammarName, namespace);
  3517. s.visit();
  3518. rs.visit();
  3519. var g = decl.build();
  3520. g.source = this.source.trimmed();
  3521. if (grammarName in namespace) {
  3522. throw errors.duplicateGrammarDeclaration(g, namespace);
  3523. }
  3524. namespace[grammarName] = g;
  3525. return g;
  3526. },
  3527. SuperGrammar: function(_, n) {
  3528. var superGrammarName = n.visit();
  3529. if (superGrammarName === 'null') {
  3530. decl.withSuperGrammar(null);
  3531. } else {
  3532. if (!namespace || !(superGrammarName in namespace)) {
  3533. throw errors.undeclaredGrammar(superGrammarName, namespace, n.source);
  3534. }
  3535. decl.withSuperGrammar(namespace[superGrammarName]);
  3536. }
  3537. },
  3538. Rule_define: function(n, fs, d, _, b) {
  3539. currentRuleName = n.visit();
  3540. currentRuleFormals = fs.visit()[0] || [];
  3541. // If there is no default start rule yet, set it now. This must be done before visiting
  3542. // the body, because it might contain an inline rule definition.
  3543. if (!decl.defaultStartRule && decl.ensureSuperGrammar() !== Grammar.ProtoBuiltInRules) {
  3544. decl.withDefaultStartRule(currentRuleName);
  3545. }
  3546. var body = b.visit();
  3547. var description = d.visit()[0];
  3548. var source = this.source.trimmed();
  3549. return decl.define(currentRuleName, currentRuleFormals, body, description, source);
  3550. },
  3551. Rule_override: function(n, fs, _, b) {
  3552. currentRuleName = n.visit();
  3553. currentRuleFormals = fs.visit()[0] || [];
  3554. overriding = true;
  3555. var body = b.visit();
  3556. var source = this.source.trimmed();
  3557. var ans = decl.override(currentRuleName, currentRuleFormals, body, null, source);
  3558. overriding = false;
  3559. return ans;
  3560. },
  3561. Rule_extend: function(n, fs, _, b) {
  3562. currentRuleName = n.visit();
  3563. currentRuleFormals = fs.visit()[0] || [];
  3564. var body = b.visit();
  3565. var source = this.source.trimmed();
  3566. var ans = decl.extend(currentRuleName, currentRuleFormals, body, null, source);
  3567. return ans;
  3568. },
  3569. RuleBody: function(_, terms) {
  3570. var args = terms.visit();
  3571. return builder.alt.apply(builder, args).withSource(this.source);
  3572. },
  3573. Formals: function(opointy, fs, cpointy) {
  3574. return fs.visit();
  3575. },
  3576. Params: function(opointy, ps, cpointy) {
  3577. return ps.visit();
  3578. },
  3579. Alt: function(seqs) {
  3580. var args = seqs.visit();
  3581. return builder.alt.apply(builder, args).withSource(this.source);
  3582. },
  3583. TopLevelTerm_inline: function(b, n) {
  3584. var inlineRuleName = currentRuleName + '_' + n.visit();
  3585. var body = b.visit();
  3586. var source = this.source.trimmed();
  3587. var isNewRuleDeclaration =
  3588. !(decl.superGrammar && decl.superGrammar.rules[inlineRuleName]);
  3589. if (overriding && !isNewRuleDeclaration) {
  3590. decl.override(inlineRuleName, currentRuleFormals, body, null, source);
  3591. } else {
  3592. decl.define(inlineRuleName, currentRuleFormals, body, null, source);
  3593. }
  3594. var params = currentRuleFormals.map(function(formal) { return builder.app(formal); });
  3595. return builder.app(inlineRuleName, params).withSource(body.source);
  3596. },
  3597. Seq: function(expr) {
  3598. return builder.seq.apply(builder, expr.visit()).withSource(this.source);
  3599. },
  3600. Iter_star: function(x, _) {
  3601. return builder.star(x.visit()).withSource(this.source);
  3602. },
  3603. Iter_plus: function(x, _) {
  3604. return builder.plus(x.visit()).withSource(this.source);
  3605. },
  3606. Iter_opt: function(x, _) {
  3607. return builder.opt(x.visit()).withSource(this.source);
  3608. },
  3609. Pred_not: function(_, x) {
  3610. return builder.not(x.visit()).withSource(this.source);
  3611. },
  3612. Pred_lookahead: function(_, x) {
  3613. return builder.lookahead(x.visit()).withSource(this.source);
  3614. },
  3615. Lex_lex: function(_, x) {
  3616. return builder.lex(x.visit()).withSource(this.source);
  3617. },
  3618. Base_application: function(rule, ps) {
  3619. return builder.app(rule.visit(), ps.visit()[0] || []).withSource(this.source);
  3620. },
  3621. Base_range: function(from, _, to) {
  3622. return builder.range(from.visit(), to.visit()).withSource(this.source);
  3623. },
  3624. Base_terminal: function(expr) {
  3625. return builder.terminal(expr.visit()).withSource(this.source);
  3626. },
  3627. Base_paren: function(open, x, close) {
  3628. return x.visit();
  3629. },
  3630. ruleDescr: function(open, t, close) {
  3631. return t.visit();
  3632. },
  3633. ruleDescrText: function(_) {
  3634. return this.sourceString.trim();
  3635. },
  3636. caseName: function(_, space1, n, space2, end) {
  3637. return n.visit();
  3638. },
  3639. name: function(first, rest) {
  3640. return this.sourceString;
  3641. },
  3642. nameFirst: function(expr) {},
  3643. nameRest: function(expr) {},
  3644. terminal: function(open, cs, close) {
  3645. return cs.visit().join('');
  3646. },
  3647. oneCharTerminal: function(open, c, close) {
  3648. return c.visit();
  3649. },
  3650. terminalChar: function(_) {
  3651. return common.unescapeChar(this.sourceString);
  3652. },
  3653. escapeChar: function(_) {
  3654. return this.sourceString;
  3655. },
  3656. NonemptyListOf: function(x, _, xs) {
  3657. return [x.visit()].concat(xs.visit());
  3658. },
  3659. EmptyListOf: function() {
  3660. return [];
  3661. },
  3662. _terminal: function() {
  3663. return this.primitiveValue;
  3664. }
  3665. });
  3666. return helpers(match).visit();
  3667. }
  3668. function compileAndLoad(source, namespace) {
  3669. var m = ohmGrammar.match(source, 'Grammars');
  3670. if (m.failed()) {
  3671. throw errors.grammarSyntaxError(m);
  3672. }
  3673. return buildGrammar(m, namespace);
  3674. }
  3675. // Return the contents of a script element, fetching it via XHR if necessary.
  3676. function getScriptElementContents(el) {
  3677. if (!isElement(el)) {
  3678. throw new TypeError('Expected a DOM Node, got ' + common.unexpectedObjToString(el));
  3679. }
  3680. if (el.type !== 'text/ohm-js') {
  3681. throw new Error('Expected a script tag with type="text/ohm-js", got ' + el);
  3682. }
  3683. return el.getAttribute('src') ? load(el.getAttribute('src')) : el.innerHTML;
  3684. }
  3685. function grammar(source, optNamespace) {
  3686. var ns = grammars(source, optNamespace);
  3687. // Ensure that the source contained no more than one grammar definition.
  3688. var grammarNames = Object.keys(ns);
  3689. if (grammarNames.length === 0) {
  3690. throw new Error('Missing grammar definition');
  3691. } else if (grammarNames.length > 1) {
  3692. var secondGrammar = ns[grammarNames[1]];
  3693. var interval = secondGrammar.source;
  3694. throw new Error(
  3695. util.getLineAndColumnMessage(interval.sourceString, interval.startIdx) +
  3696. 'Found more than one grammar definition -- use ohm.grammars() instead.');
  3697. }
  3698. return ns[grammarNames[0]]; // Return the one and only grammar.
  3699. }
  3700. function grammars(source, optNamespace) {
  3701. var ns = Namespace.extend(Namespace.asNamespace(optNamespace));
  3702. if (typeof source !== 'string') {
  3703. // For convenience, detect Node.js Buffer objects and automatically call toString().
  3704. if (isBuffer(source)) {
  3705. source = source.toString();
  3706. } else {
  3707. throw new TypeError(
  3708. 'Expected string as first argument, got ' + common.unexpectedObjToString(source));
  3709. }
  3710. }
  3711. compileAndLoad(source, ns);
  3712. return ns;
  3713. }
  3714. function grammarFromScriptElement(optNode) {
  3715. var node = optNode;
  3716. if (isUndefined(node)) {
  3717. var nodeList = documentInterface.querySelectorAll('script[type="text/ohm-js"]');
  3718. if (nodeList.length !== 1) {
  3719. throw new Error(
  3720. 'Expected exactly one script tag with type="text/ohm-js", found ' + nodeList.length);
  3721. }
  3722. node = nodeList[0];
  3723. }
  3724. return grammar(getScriptElementContents(node));
  3725. }
  3726. function grammarsFromScriptElements(optNodeOrNodeList) {
  3727. // Simple case: the argument is a DOM node.
  3728. if (isElement(optNodeOrNodeList)) {
  3729. return grammars(optNodeOrNodeList);
  3730. }
  3731. // Otherwise, it must be either undefined or a NodeList.
  3732. var nodeList = optNodeOrNodeList;
  3733. if (isUndefined(nodeList)) {
  3734. // Find all script elements with type="text/ohm-js".
  3735. nodeList = documentInterface.querySelectorAll('script[type="text/ohm-js"]');
  3736. } else if (typeof nodeList === 'string' || (!isElement(nodeList) && !isArrayLike(nodeList))) {
  3737. throw new TypeError('Expected a Node, NodeList, or Array, but got ' + nodeList);
  3738. }
  3739. var ns = Namespace.createNamespace();
  3740. for (var i = 0; i < nodeList.length; ++i) {
  3741. // Copy the new grammars into `ns` to keep the namespace flat.
  3742. common.extend(ns, grammars(getScriptElementContents(nodeList[i]), ns));
  3743. }
  3744. return ns;
  3745. }
  3746. function makeRecipe(recipe) {
  3747. if (typeof recipe === 'function') {
  3748. return recipe.call(new Builder());
  3749. } else {
  3750. if (typeof recipe === 'string') {
  3751. // stringified JSON recipe
  3752. recipe = JSON.parse(recipe);
  3753. }
  3754. return (new Builder()).fromRecipe(recipe);
  3755. }
  3756. }
  3757. // --------------------------------------------------------------------
  3758. // Exports
  3759. // --------------------------------------------------------------------
  3760. // Stuff that users should know about
  3761. module.exports = {
  3762. createNamespace: Namespace.createNamespace,
  3763. grammar: grammar,
  3764. grammars: grammars,
  3765. grammarFromScriptElement: grammarFromScriptElement,
  3766. grammarsFromScriptElements: grammarsFromScriptElements,
  3767. makeRecipe: makeRecipe,
  3768. ohmGrammar: null, // Initialized below, after Grammar.BuiltInRules.
  3769. pexprs: pexprs,
  3770. util: util,
  3771. extras: require('../extras'),
  3772. version: version
  3773. };
  3774. // Stuff for testing, etc.
  3775. module.exports._buildGrammar = buildGrammar;
  3776. module.exports._setDocumentInterfaceForTesting = function(doc) { documentInterface = doc; };
  3777. // Late initialization for stuff that is bootstrapped.
  3778. Grammar.BuiltInRules = require('../dist/built-in-rules');
  3779. util.announceBuiltInRules(Grammar.BuiltInRules);
  3780. module.exports.ohmGrammar = ohmGrammar = require('../dist/ohm-grammar');
  3781. Grammar.initApplicationParser(ohmGrammar, buildGrammar);
  3782. },{"../dist/built-in-rules":1,"../dist/ohm-grammar":2,"../extras":5,"./Builder":30,"./Grammar":33,"./Namespace":40,"./common":44,"./errors":45,"./pexprs":64,"./util":65,"./version":66,"is-buffer":28}],47:[function(require,module,exports){
  3783. 'use strict';
  3784. var inherits = require('inherits');
  3785. var common = require('./common');
  3786. // --------------------------------------------------------------------
  3787. // Private stuff
  3788. // --------------------------------------------------------------------
  3789. function Node(grammar, ctorName, matchLength) {
  3790. this.grammar = grammar;
  3791. this.ctorName = ctorName;
  3792. this.matchLength = matchLength;
  3793. }
  3794. Node.prototype.numChildren = function() {
  3795. return this.children ? this.children.length : 0;
  3796. };
  3797. Node.prototype.childAt = function(idx) {
  3798. if (this.children) {
  3799. return this.children[idx];
  3800. }
  3801. };
  3802. Node.prototype.indexOfChild = function(arg) {
  3803. return this.children.indexOf(arg);
  3804. };
  3805. Node.prototype.hasChildren = function() {
  3806. return this.numChildren() > 1;
  3807. };
  3808. Node.prototype.hasNoChildren = function() {
  3809. return !this.hasChildren();
  3810. };
  3811. Node.prototype.onlyChild = function() {
  3812. if (this.numChildren() !== 1) {
  3813. throw new Error(
  3814. 'cannot get only child of a node of type ' + this.ctorName +
  3815. ' (it has ' + this.numChildren() + ' children)');
  3816. } else {
  3817. return this.firstChild();
  3818. }
  3819. };
  3820. Node.prototype.firstChild = function() {
  3821. if (this.hasNoChildren()) {
  3822. throw new Error(
  3823. 'cannot get first child of a ' + this.ctorName + ' node, which has no children');
  3824. } else {
  3825. return this.childAt(0);
  3826. }
  3827. };
  3828. Node.prototype.lastChild = function() {
  3829. if (this.hasNoChildren()) {
  3830. throw new Error(
  3831. 'cannot get last child of a ' + this.ctorName + ' node, which has no children');
  3832. } else {
  3833. return this.childAt(this.numChildren() - 1);
  3834. }
  3835. };
  3836. Node.prototype.childBefore = function(child) {
  3837. var childIdx = this.indexOfChild(child);
  3838. if (childIdx < 0) {
  3839. throw new Error('Node.childBefore() called w/ an argument that is not a child');
  3840. } else if (childIdx === 0) {
  3841. throw new Error('cannot get child before first child');
  3842. } else {
  3843. return this.childAt(childIdx - 1);
  3844. }
  3845. };
  3846. Node.prototype.childAfter = function(child) {
  3847. var childIdx = this.indexOfChild(child);
  3848. if (childIdx < 0) {
  3849. throw new Error('Node.childAfter() called w/ an argument that is not a child');
  3850. } else if (childIdx === this.numChildren() - 1) {
  3851. throw new Error('cannot get child after last child');
  3852. } else {
  3853. return this.childAt(childIdx + 1);
  3854. }
  3855. };
  3856. Node.prototype.isTerminal = function() {
  3857. return false;
  3858. };
  3859. Node.prototype.isNonterminal = function() {
  3860. return false;
  3861. };
  3862. Node.prototype.isIteration = function() {
  3863. return false;
  3864. };
  3865. Node.prototype.isOptional = function() {
  3866. return false;
  3867. };
  3868. Node.prototype.toJSON = function() {
  3869. var r = {};
  3870. r[this.ctorName] = this.children;
  3871. return r;
  3872. };
  3873. // Terminals
  3874. function TerminalNode(grammar, value) {
  3875. var matchLength = value ? value.length : 0;
  3876. Node.call(this, grammar, '_terminal', matchLength);
  3877. this.primitiveValue = value;
  3878. }
  3879. inherits(TerminalNode, Node);
  3880. TerminalNode.prototype.isTerminal = function() {
  3881. return true;
  3882. };
  3883. TerminalNode.prototype.toJSON = function() {
  3884. var r = {};
  3885. r[this.ctorName] = this.primitiveValue;
  3886. return r;
  3887. };
  3888. // Nonterminals
  3889. function NonterminalNode(grammar, ruleName, children, childOffsets, matchLength) {
  3890. Node.call(this, grammar, ruleName, matchLength);
  3891. this.children = children;
  3892. this.childOffsets = childOffsets;
  3893. }
  3894. inherits(NonterminalNode, Node);
  3895. NonterminalNode.prototype.isNonterminal = function() {
  3896. return true;
  3897. };
  3898. NonterminalNode.prototype.isLexical = function() {
  3899. return common.isLexical(this.ctorName);
  3900. };
  3901. NonterminalNode.prototype.isSyntactic = function() {
  3902. return common.isSyntactic(this.ctorName);
  3903. };
  3904. // Iterations
  3905. function IterationNode(grammar, children, childOffsets, matchLength, isOptional) {
  3906. Node.call(this, grammar, '_iter', matchLength);
  3907. this.children = children;
  3908. this.childOffsets = childOffsets;
  3909. this.optional = isOptional;
  3910. }
  3911. inherits(IterationNode, Node);
  3912. IterationNode.prototype.isIteration = function() {
  3913. return true;
  3914. };
  3915. IterationNode.prototype.isOptional = function() {
  3916. return this.optional;
  3917. };
  3918. // --------------------------------------------------------------------
  3919. // Exports
  3920. // --------------------------------------------------------------------
  3921. module.exports = {
  3922. Node: Node,
  3923. TerminalNode: TerminalNode,
  3924. NonterminalNode: NonterminalNode,
  3925. IterationNode: IterationNode
  3926. };
  3927. },{"./common":44,"inherits":27}],48:[function(require,module,exports){
  3928. 'use strict';
  3929. // --------------------------------------------------------------------
  3930. // Imports
  3931. // --------------------------------------------------------------------
  3932. var common = require('./common');
  3933. var pexprs = require('./pexprs');
  3934. // --------------------------------------------------------------------
  3935. // Operations
  3936. // --------------------------------------------------------------------
  3937. /*
  3938. Return true if we should skip spaces preceding this expression in a syntactic context.
  3939. */
  3940. pexprs.PExpr.prototype.allowsSkippingPrecedingSpace = common.abstract(
  3941. 'allowsSkippingPrecedingSpace'
  3942. );
  3943. /*
  3944. Generally, these are all first-order expressions and (with the exception of Apply)
  3945. directly read from the input stream.
  3946. */
  3947. pexprs.any.allowsSkippingPrecedingSpace =
  3948. pexprs.end.allowsSkippingPrecedingSpace =
  3949. pexprs.Apply.prototype.allowsSkippingPrecedingSpace =
  3950. pexprs.Terminal.prototype.allowsSkippingPrecedingSpace =
  3951. pexprs.Range.prototype.allowsSkippingPrecedingSpace =
  3952. pexprs.UnicodeChar.prototype.allowsSkippingPrecedingSpace = function() {
  3953. return true;
  3954. };
  3955. /*
  3956. Higher-order expressions that don't directly consume input.
  3957. */
  3958. pexprs.Alt.prototype.allowsSkippingPrecedingSpace =
  3959. pexprs.Iter.prototype.allowsSkippingPrecedingSpace =
  3960. pexprs.Lex.prototype.allowsSkippingPrecedingSpace =
  3961. pexprs.Lookahead.prototype.allowsSkippingPrecedingSpace =
  3962. pexprs.Not.prototype.allowsSkippingPrecedingSpace =
  3963. pexprs.Param.prototype.allowsSkippingPrecedingSpace =
  3964. pexprs.Seq.prototype.allowsSkippingPrecedingSpace = function() {
  3965. return false;
  3966. };
  3967. },{"./common":44,"./pexprs":64}],49:[function(require,module,exports){
  3968. 'use strict';
  3969. // --------------------------------------------------------------------
  3970. // Imports
  3971. // --------------------------------------------------------------------
  3972. var common = require('./common');
  3973. var errors = require('./errors');
  3974. var pexprs = require('./pexprs');
  3975. var util = require('./util');
  3976. var BuiltInRules;
  3977. util.awaitBuiltInRules(function(g) { BuiltInRules = g; });
  3978. // --------------------------------------------------------------------
  3979. // Operations
  3980. // --------------------------------------------------------------------
  3981. var lexifyCount;
  3982. pexprs.PExpr.prototype.assertAllApplicationsAreValid = function(ruleName, grammar) {
  3983. lexifyCount = 0;
  3984. this._assertAllApplicationsAreValid(ruleName, grammar);
  3985. };
  3986. pexprs.PExpr.prototype._assertAllApplicationsAreValid = common.abstract(
  3987. '_assertAllApplicationsAreValid'
  3988. );
  3989. pexprs.any._assertAllApplicationsAreValid =
  3990. pexprs.end._assertAllApplicationsAreValid =
  3991. pexprs.Terminal.prototype._assertAllApplicationsAreValid =
  3992. pexprs.Range.prototype._assertAllApplicationsAreValid =
  3993. pexprs.Param.prototype._assertAllApplicationsAreValid =
  3994. pexprs.UnicodeChar.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  3995. // no-op
  3996. };
  3997. pexprs.Lex.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  3998. lexifyCount++;
  3999. this.expr._assertAllApplicationsAreValid(ruleName, grammar);
  4000. lexifyCount--;
  4001. };
  4002. pexprs.Alt.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  4003. for (var idx = 0; idx < this.terms.length; idx++) {
  4004. this.terms[idx]._assertAllApplicationsAreValid(ruleName, grammar);
  4005. }
  4006. };
  4007. pexprs.Seq.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  4008. for (var idx = 0; idx < this.factors.length; idx++) {
  4009. this.factors[idx]._assertAllApplicationsAreValid(ruleName, grammar);
  4010. }
  4011. };
  4012. pexprs.Iter.prototype._assertAllApplicationsAreValid =
  4013. pexprs.Not.prototype._assertAllApplicationsAreValid =
  4014. pexprs.Lookahead.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  4015. this.expr._assertAllApplicationsAreValid(ruleName, grammar);
  4016. };
  4017. pexprs.Apply.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {
  4018. var ruleInfo = grammar.rules[this.ruleName];
  4019. // Make sure that the rule exists...
  4020. if (!ruleInfo) {
  4021. throw errors.undeclaredRule(this.ruleName, grammar.name, this.source);
  4022. }
  4023. // ...and that this application is allowed
  4024. if (common.isSyntactic(this.ruleName) && (!common.isSyntactic(ruleName) || lexifyCount > 0)) {
  4025. throw errors.applicationOfSyntacticRuleFromLexicalContext(this.ruleName, this);
  4026. }
  4027. // ...and that this application has the correct number of arguments
  4028. var actual = this.args.length;
  4029. var expected = ruleInfo.formals.length;
  4030. if (actual !== expected) {
  4031. throw errors.wrongNumberOfArguments(this.ruleName, expected, actual, this.source);
  4032. }
  4033. // ...and that all of the argument expressions only have valid applications and have arity 1.
  4034. var self = this;
  4035. this.args.forEach(function(arg) {
  4036. arg._assertAllApplicationsAreValid(ruleName, grammar);
  4037. if (arg.getArity() !== 1) {
  4038. throw errors.invalidParameter(self.ruleName, arg);
  4039. }
  4040. });
  4041. // Extra checks for "special" applications
  4042. // If it's an application of 'caseInsensitive', ensure that the argument is a Terminal.
  4043. if (BuiltInRules && ruleInfo === BuiltInRules.rules.caseInsensitive) {
  4044. if (!(this.args[0] instanceof pexprs.Terminal)) {
  4045. throw errors.incorrectArgumentType('a Terminal (e.g. \"abc\")', this.args[0]);
  4046. }
  4047. }
  4048. };
  4049. },{"./common":44,"./errors":45,"./pexprs":64,"./util":65}],50:[function(require,module,exports){
  4050. 'use strict';
  4051. // --------------------------------------------------------------------
  4052. // Imports
  4053. // --------------------------------------------------------------------
  4054. var common = require('./common');
  4055. var errors = require('./errors');
  4056. var pexprs = require('./pexprs');
  4057. // --------------------------------------------------------------------
  4058. // Operations
  4059. // --------------------------------------------------------------------
  4060. pexprs.PExpr.prototype.assertChoicesHaveUniformArity = common.abstract(
  4061. 'assertChoicesHaveUniformArity'
  4062. );
  4063. pexprs.any.assertChoicesHaveUniformArity =
  4064. pexprs.end.assertChoicesHaveUniformArity =
  4065. pexprs.Terminal.prototype.assertChoicesHaveUniformArity =
  4066. pexprs.Range.prototype.assertChoicesHaveUniformArity =
  4067. pexprs.Param.prototype.assertChoicesHaveUniformArity =
  4068. pexprs.Lex.prototype.assertChoicesHaveUniformArity =
  4069. pexprs.UnicodeChar.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4070. // no-op
  4071. };
  4072. pexprs.Alt.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4073. if (this.terms.length === 0) {
  4074. return;
  4075. }
  4076. var arity = this.terms[0].getArity();
  4077. for (var idx = 0; idx < this.terms.length; idx++) {
  4078. var term = this.terms[idx];
  4079. term.assertChoicesHaveUniformArity();
  4080. var otherArity = term.getArity();
  4081. if (arity !== otherArity) {
  4082. throw errors.inconsistentArity(ruleName, arity, otherArity, term);
  4083. }
  4084. }
  4085. };
  4086. pexprs.Extend.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4087. // Extend is a special case of Alt that's guaranteed to have exactly two
  4088. // cases: [extensions, origBody].
  4089. var actualArity = this.terms[0].getArity();
  4090. var expectedArity = this.terms[1].getArity();
  4091. if (actualArity !== expectedArity) {
  4092. throw errors.inconsistentArity(ruleName, expectedArity, actualArity, this.terms[0]);
  4093. }
  4094. };
  4095. pexprs.Seq.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4096. for (var idx = 0; idx < this.factors.length; idx++) {
  4097. this.factors[idx].assertChoicesHaveUniformArity(ruleName);
  4098. }
  4099. };
  4100. pexprs.Iter.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4101. this.expr.assertChoicesHaveUniformArity(ruleName);
  4102. };
  4103. pexprs.Not.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4104. // no-op (not required b/c the nested expr doesn't show up in the CST)
  4105. };
  4106. pexprs.Lookahead.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4107. this.expr.assertChoicesHaveUniformArity(ruleName);
  4108. };
  4109. pexprs.Apply.prototype.assertChoicesHaveUniformArity = function(ruleName) {
  4110. // The arities of the parameter expressions is required to be 1 by
  4111. // `assertAllApplicationsAreValid()`.
  4112. };
  4113. },{"./common":44,"./errors":45,"./pexprs":64}],51:[function(require,module,exports){
  4114. 'use strict';
  4115. // --------------------------------------------------------------------
  4116. // Imports
  4117. // --------------------------------------------------------------------
  4118. var common = require('./common');
  4119. var errors = require('./errors');
  4120. var pexprs = require('./pexprs');
  4121. // --------------------------------------------------------------------
  4122. // Operations
  4123. // --------------------------------------------------------------------
  4124. pexprs.PExpr.prototype.assertIteratedExprsAreNotNullable = common.abstract(
  4125. 'assertIteratedExprsAreNotNullable'
  4126. );
  4127. pexprs.any.assertIteratedExprsAreNotNullable =
  4128. pexprs.end.assertIteratedExprsAreNotNullable =
  4129. pexprs.Terminal.prototype.assertIteratedExprsAreNotNullable =
  4130. pexprs.Range.prototype.assertIteratedExprsAreNotNullable =
  4131. pexprs.Param.prototype.assertIteratedExprsAreNotNullable =
  4132. pexprs.UnicodeChar.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4133. // no-op
  4134. };
  4135. pexprs.Alt.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4136. for (var idx = 0; idx < this.terms.length; idx++) {
  4137. this.terms[idx].assertIteratedExprsAreNotNullable(grammar);
  4138. }
  4139. };
  4140. pexprs.Seq.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4141. for (var idx = 0; idx < this.factors.length; idx++) {
  4142. this.factors[idx].assertIteratedExprsAreNotNullable(grammar);
  4143. }
  4144. };
  4145. pexprs.Iter.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4146. // Note: this is the implementation of this method for `Star` and `Plus` expressions.
  4147. // It is overridden for `Opt` below.
  4148. this.expr.assertIteratedExprsAreNotNullable(grammar);
  4149. if (this.expr.isNullable(grammar)) {
  4150. throw errors.kleeneExprHasNullableOperand(this, []);
  4151. }
  4152. };
  4153. pexprs.Opt.prototype.assertIteratedExprsAreNotNullable =
  4154. pexprs.Not.prototype.assertIteratedExprsAreNotNullable =
  4155. pexprs.Lookahead.prototype.assertIteratedExprsAreNotNullable =
  4156. pexprs.Lex.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4157. this.expr.assertIteratedExprsAreNotNullable(grammar);
  4158. };
  4159. pexprs.Apply.prototype.assertIteratedExprsAreNotNullable = function(grammar) {
  4160. this.args.forEach(function(arg) {
  4161. arg.assertIteratedExprsAreNotNullable(grammar);
  4162. });
  4163. };
  4164. },{"./common":44,"./errors":45,"./pexprs":64}],52:[function(require,module,exports){
  4165. 'use strict';
  4166. // --------------------------------------------------------------------
  4167. // Imports
  4168. // --------------------------------------------------------------------
  4169. var common = require('./common');
  4170. var nodes = require('./nodes');
  4171. var pexprs = require('./pexprs');
  4172. // --------------------------------------------------------------------
  4173. // Operations
  4174. // --------------------------------------------------------------------
  4175. pexprs.PExpr.prototype.check = common.abstract('check');
  4176. pexprs.any.check = function(grammar, vals) {
  4177. return vals.length >= 1;
  4178. };
  4179. pexprs.end.check = function(grammar, vals) {
  4180. return vals[0] instanceof nodes.Node &&
  4181. vals[0].isTerminal() &&
  4182. vals[0].primitiveValue === undefined;
  4183. };
  4184. pexprs.Terminal.prototype.check = function(grammar, vals) {
  4185. return vals[0] instanceof nodes.Node &&
  4186. vals[0].isTerminal() &&
  4187. vals[0].primitiveValue === this.obj;
  4188. };
  4189. pexprs.Range.prototype.check = function(grammar, vals) {
  4190. return vals[0] instanceof nodes.Node &&
  4191. vals[0].isTerminal() &&
  4192. typeof vals[0].primitiveValue === typeof this.from;
  4193. };
  4194. pexprs.Param.prototype.check = function(grammar, vals) {
  4195. return vals.length >= 1;
  4196. };
  4197. pexprs.Alt.prototype.check = function(grammar, vals) {
  4198. for (var i = 0; i < this.terms.length; i++) {
  4199. var term = this.terms[i];
  4200. if (term.check(grammar, vals)) {
  4201. return true;
  4202. }
  4203. }
  4204. return false;
  4205. };
  4206. pexprs.Seq.prototype.check = function(grammar, vals) {
  4207. var pos = 0;
  4208. for (var i = 0; i < this.factors.length; i++) {
  4209. var factor = this.factors[i];
  4210. if (factor.check(grammar, vals.slice(pos))) {
  4211. pos += factor.getArity();
  4212. } else {
  4213. return false;
  4214. }
  4215. }
  4216. return true;
  4217. };
  4218. pexprs.Iter.prototype.check = function(grammar, vals) {
  4219. var arity = this.getArity();
  4220. var columns = vals.slice(0, arity);
  4221. if (columns.length !== arity) {
  4222. return false;
  4223. }
  4224. var rowCount = columns[0].length;
  4225. var i;
  4226. for (i = 1; i < arity; i++) {
  4227. if (columns[i].length !== rowCount) {
  4228. return false;
  4229. }
  4230. }
  4231. for (i = 0; i < rowCount; i++) {
  4232. var row = [];
  4233. for (var j = 0; j < arity; j++) {
  4234. row.push(columns[j][i]);
  4235. }
  4236. if (!this.expr.check(grammar, row)) {
  4237. return false;
  4238. }
  4239. }
  4240. return true;
  4241. };
  4242. pexprs.Not.prototype.check = function(grammar, vals) {
  4243. return true;
  4244. };
  4245. pexprs.Lookahead.prototype.check =
  4246. pexprs.Lex.prototype.check = function(grammar, vals) {
  4247. return this.expr.check(grammar, vals);
  4248. };
  4249. pexprs.Apply.prototype.check = function(grammar, vals) {
  4250. if (!(vals[0] instanceof nodes.Node &&
  4251. vals[0].grammar === grammar &&
  4252. vals[0].ctorName === this.ruleName)) {
  4253. return false;
  4254. }
  4255. // TODO: think about *not* doing the following checks, i.e., trusting that the rule
  4256. // was correctly constructed.
  4257. var ruleNode = vals[0];
  4258. var body = grammar.rules[this.ruleName].body;
  4259. return body.check(grammar, ruleNode.children) && ruleNode.numChildren() === body.getArity();
  4260. };
  4261. pexprs.UnicodeChar.prototype.check = function(grammar, vals) {
  4262. return vals[0] instanceof nodes.Node &&
  4263. vals[0].isTerminal() &&
  4264. typeof vals[0].primitiveValue === 'string';
  4265. };
  4266. },{"./common":44,"./nodes":47,"./pexprs":64}],53:[function(require,module,exports){
  4267. 'use strict';
  4268. // --------------------------------------------------------------------
  4269. // Imports
  4270. // --------------------------------------------------------------------
  4271. var Trace = require('./Trace');
  4272. var common = require('./common');
  4273. var errors = require('./errors');
  4274. var nodes = require('./nodes');
  4275. var pexprs = require('./pexprs');
  4276. var TerminalNode = nodes.TerminalNode;
  4277. var NonterminalNode = nodes.NonterminalNode;
  4278. var IterationNode = nodes.IterationNode;
  4279. // --------------------------------------------------------------------
  4280. // Operations
  4281. // --------------------------------------------------------------------
  4282. /*
  4283. Evaluate the expression and return `true` if it succeeds, `false` otherwise. This method should
  4284. only be called directly by `State.prototype.eval(expr)`, which also updates the data structures
  4285. that are used for tracing. (Making those updates in a method of `State` enables the trace-specific
  4286. data structures to be "secrets" of that class, which is good for modularity.)
  4287. The contract of this method is as follows:
  4288. * When the return value is `true`,
  4289. - the state object will have `expr.getArity()` more bindings than it did before the call.
  4290. * When the return value is `false`,
  4291. - the state object may have more bindings than it did before the call, and
  4292. - its input stream's position may be anywhere.
  4293. Note that `State.prototype.eval(expr)`, unlike this method, guarantees that neither the state
  4294. object's bindings nor its input stream's position will change if the expression fails to match.
  4295. */
  4296. pexprs.PExpr.prototype.eval = common.abstract('eval'); // function(state) { ... }
  4297. pexprs.any.eval = function(state) {
  4298. var inputStream = state.inputStream;
  4299. var origPos = inputStream.pos;
  4300. var ch = inputStream.next();
  4301. if (ch) {
  4302. state.pushBinding(new TerminalNode(state.grammar, ch), origPos);
  4303. return true;
  4304. } else {
  4305. state.processFailure(origPos, this);
  4306. return false;
  4307. }
  4308. };
  4309. pexprs.end.eval = function(state) {
  4310. var inputStream = state.inputStream;
  4311. var origPos = inputStream.pos;
  4312. if (inputStream.atEnd()) {
  4313. state.pushBinding(new TerminalNode(state.grammar, undefined), origPos);
  4314. return true;
  4315. } else {
  4316. state.processFailure(origPos, this);
  4317. return false;
  4318. }
  4319. };
  4320. pexprs.Terminal.prototype.eval = function(state) {
  4321. var inputStream = state.inputStream;
  4322. var origPos = inputStream.pos;
  4323. if (!inputStream.matchString(this.obj)) {
  4324. state.processFailure(origPos, this);
  4325. return false;
  4326. } else {
  4327. state.pushBinding(new TerminalNode(state.grammar, this.obj), origPos);
  4328. return true;
  4329. }
  4330. };
  4331. pexprs.Range.prototype.eval = function(state) {
  4332. var inputStream = state.inputStream;
  4333. var origPos = inputStream.pos;
  4334. var ch = inputStream.next();
  4335. if (ch && this.from <= ch && ch <= this.to) {
  4336. state.pushBinding(new TerminalNode(state.grammar, ch), origPos);
  4337. return true;
  4338. } else {
  4339. state.processFailure(origPos, this);
  4340. return false;
  4341. }
  4342. };
  4343. pexprs.Param.prototype.eval = function(state) {
  4344. return state.eval(state.currentApplication().args[this.index]);
  4345. };
  4346. pexprs.Lex.prototype.eval = function(state) {
  4347. state.enterLexifiedContext();
  4348. var ans = state.eval(this.expr);
  4349. state.exitLexifiedContext();
  4350. return ans;
  4351. };
  4352. pexprs.Alt.prototype.eval = function(state) {
  4353. for (var idx = 0; idx < this.terms.length; idx++) {
  4354. if (state.eval(this.terms[idx])) {
  4355. return true;
  4356. }
  4357. }
  4358. return false;
  4359. };
  4360. pexprs.Seq.prototype.eval = function(state) {
  4361. for (var idx = 0; idx < this.factors.length; idx++) {
  4362. var factor = this.factors[idx];
  4363. if (!state.eval(factor)) {
  4364. return false;
  4365. }
  4366. }
  4367. return true;
  4368. };
  4369. pexprs.Iter.prototype.eval = function(state) {
  4370. var inputStream = state.inputStream;
  4371. var origPos = inputStream.pos;
  4372. var arity = this.getArity();
  4373. var cols = [];
  4374. var colOffsets = [];
  4375. while (cols.length < arity) {
  4376. cols.push([]);
  4377. colOffsets.push([]);
  4378. }
  4379. var numMatches = 0;
  4380. var prevPos = origPos;
  4381. var idx;
  4382. while (numMatches < this.maxNumMatches && state.eval(this.expr)) {
  4383. if (inputStream.pos === prevPos) {
  4384. throw errors.kleeneExprHasNullableOperand(this, state._applicationStack);
  4385. }
  4386. prevPos = inputStream.pos;
  4387. numMatches++;
  4388. var row = state._bindings.splice(state._bindings.length - arity, arity);
  4389. var rowOffsets = state._bindingOffsets.splice(state._bindingOffsets.length - arity, arity);
  4390. for (idx = 0; idx < row.length; idx++) {
  4391. cols[idx].push(row[idx]);
  4392. colOffsets[idx].push(rowOffsets[idx]);
  4393. }
  4394. }
  4395. if (numMatches < this.minNumMatches) {
  4396. return false;
  4397. }
  4398. var offset = state.posToOffset(origPos);
  4399. var matchLength = 0;
  4400. if (numMatches > 0) {
  4401. var lastCol = cols[arity - 1];
  4402. var lastColOffsets = colOffsets[arity - 1];
  4403. var endOffset =
  4404. lastColOffsets[lastColOffsets.length - 1] + lastCol[lastCol.length - 1].matchLength;
  4405. offset = colOffsets[0][0];
  4406. matchLength = endOffset - offset;
  4407. }
  4408. var isOptional = this instanceof pexprs.Opt;
  4409. for (idx = 0; idx < cols.length; idx++) {
  4410. state._bindings.push(
  4411. new IterationNode(state.grammar, cols[idx], colOffsets[idx], matchLength, isOptional));
  4412. state._bindingOffsets.push(offset);
  4413. }
  4414. return true;
  4415. };
  4416. pexprs.Not.prototype.eval = function(state) {
  4417. /*
  4418. TODO:
  4419. - Right now we're just throwing away all of the failures that happen inside a `not`, and
  4420. recording `this` as a failed expression.
  4421. - Double negation should be equivalent to lookahead, but that's not the case right now wrt
  4422. failures. E.g., ~~'foo' produces a failure for ~~'foo', but maybe it should produce
  4423. a failure for 'foo' instead.
  4424. */
  4425. var inputStream = state.inputStream;
  4426. var origPos = inputStream.pos;
  4427. state.pushFailuresInfo();
  4428. var ans = state.eval(this.expr);
  4429. state.popFailuresInfo();
  4430. if (ans) {
  4431. state.processFailure(origPos, this);
  4432. return false;
  4433. }
  4434. inputStream.pos = origPos;
  4435. return true;
  4436. };
  4437. pexprs.Lookahead.prototype.eval = function(state) {
  4438. var inputStream = state.inputStream;
  4439. var origPos = inputStream.pos;
  4440. if (state.eval(this.expr)) {
  4441. inputStream.pos = origPos;
  4442. return true;
  4443. } else {
  4444. return false;
  4445. }
  4446. };
  4447. pexprs.Apply.prototype.eval = function(state) {
  4448. var caller = state.currentApplication();
  4449. var actuals = caller ? caller.args : [];
  4450. var app = this.substituteParams(actuals);
  4451. var posInfo = state.getCurrentPosInfo();
  4452. if (posInfo.isActive(app)) {
  4453. // This rule is already active at this position, i.e., it is left-recursive.
  4454. return app.handleCycle(state);
  4455. }
  4456. var memoKey = app.toMemoKey();
  4457. var memoRec = posInfo.memo[memoKey];
  4458. if (memoRec && posInfo.shouldUseMemoizedResult(memoRec)) {
  4459. if (state.hasNecessaryInfo(memoRec)) {
  4460. return state.useMemoizedResult(state.inputStream.pos, memoRec);
  4461. }
  4462. delete posInfo.memo[memoKey];
  4463. }
  4464. return app.reallyEval(state);
  4465. };
  4466. pexprs.Apply.prototype.handleCycle = function(state) {
  4467. var posInfo = state.getCurrentPosInfo();
  4468. var currentLeftRecursion = posInfo.currentLeftRecursion;
  4469. var memoKey = this.toMemoKey();
  4470. var memoRec = posInfo.memo[memoKey];
  4471. if (currentLeftRecursion && currentLeftRecursion.headApplication.toMemoKey() === memoKey) {
  4472. // We already know about this left recursion, but it's possible there are "involved
  4473. // applications" that we don't already know about, so...
  4474. memoRec.updateInvolvedApplicationMemoKeys();
  4475. } else if (!memoRec) {
  4476. // New left recursion detected! Memoize a failure to try to get a seed parse.
  4477. memoRec = posInfo.memoize(
  4478. memoKey,
  4479. {matchLength: 0, examinedLength: 0, value: false, rightmostFailureOffset: -1});
  4480. posInfo.startLeftRecursion(this, memoRec);
  4481. }
  4482. return state.useMemoizedResult(state.inputStream.pos, memoRec);
  4483. };
  4484. pexprs.Apply.prototype.reallyEval = function(state) {
  4485. var inputStream = state.inputStream;
  4486. var origPos = inputStream.pos;
  4487. var origPosInfo = state.getCurrentPosInfo();
  4488. var ruleInfo = state.grammar.rules[this.ruleName];
  4489. var body = ruleInfo.body;
  4490. var description = ruleInfo.description;
  4491. state.enterApplication(origPosInfo, this);
  4492. if (description) {
  4493. state.pushFailuresInfo();
  4494. }
  4495. // Reset the input stream's examinedLength property so that we can track
  4496. // the examined length of this particular application.
  4497. var origInputStreamExaminedLength = inputStream.examinedLength;
  4498. inputStream.examinedLength = 0;
  4499. var value = this.evalOnce(body, state);
  4500. var currentLR = origPosInfo.currentLeftRecursion;
  4501. var memoKey = this.toMemoKey();
  4502. var isHeadOfLeftRecursion = currentLR && currentLR.headApplication.toMemoKey() === memoKey;
  4503. var memoRec;
  4504. if (isHeadOfLeftRecursion) {
  4505. value = this.growSeedResult(body, state, origPos, currentLR, value);
  4506. origPosInfo.endLeftRecursion();
  4507. memoRec = currentLR;
  4508. memoRec.examinedLength = inputStream.examinedLength - origPos;
  4509. memoRec.rightmostFailureOffset = state._getRightmostFailureOffset();
  4510. origPosInfo.memoize(memoKey, memoRec); // updates origPosInfo's maxExaminedLength
  4511. } else if (!currentLR || !currentLR.isInvolved(memoKey)) {
  4512. // This application is not involved in left recursion, so it's ok to memoize it.
  4513. memoRec = origPosInfo.memoize(memoKey, {
  4514. matchLength: inputStream.pos - origPos,
  4515. examinedLength: inputStream.examinedLength - origPos,
  4516. value: value,
  4517. failuresAtRightmostPosition: state.cloneRecordedFailures(),
  4518. rightmostFailureOffset: state._getRightmostFailureOffset()
  4519. });
  4520. }
  4521. var succeeded = !!value;
  4522. if (description) {
  4523. state.popFailuresInfo();
  4524. if (!succeeded) {
  4525. state.processFailure(origPos, this);
  4526. }
  4527. if (memoRec) {
  4528. memoRec.failuresAtRightmostPosition = state.cloneRecordedFailures();
  4529. }
  4530. }
  4531. // Record trace information in the memo table, so that it is available if the memoized result
  4532. // is used later.
  4533. if (state.isTracing() && memoRec) {
  4534. var entry = state.getTraceEntry(origPos, this, succeeded, succeeded ? [value] : []);
  4535. if (isHeadOfLeftRecursion) {
  4536. common.assert(entry.terminatingLREntry != null || !succeeded);
  4537. entry.isHeadOfLeftRecursion = true;
  4538. }
  4539. memoRec.traceEntry = entry;
  4540. }
  4541. // Fix the input stream's examinedLength -- it should be the maximum examined length
  4542. // across all applications, not just this one.
  4543. inputStream.examinedLength = Math.max(inputStream.examinedLength, origInputStreamExaminedLength);
  4544. state.exitApplication(origPosInfo, value);
  4545. return succeeded;
  4546. };
  4547. pexprs.Apply.prototype.evalOnce = function(expr, state) {
  4548. var inputStream = state.inputStream;
  4549. var origPos = inputStream.pos;
  4550. if (state.eval(expr)) {
  4551. var arity = expr.getArity();
  4552. var bindings = state._bindings.splice(state._bindings.length - arity, arity);
  4553. var offsets = state._bindingOffsets.splice(state._bindingOffsets.length - arity, arity);
  4554. return new NonterminalNode(
  4555. state.grammar, this.ruleName, bindings, offsets, inputStream.pos - origPos);
  4556. } else {
  4557. return false;
  4558. }
  4559. };
  4560. pexprs.Apply.prototype.growSeedResult = function(body, state, origPos, lrMemoRec, newValue) {
  4561. if (!newValue) {
  4562. return false;
  4563. }
  4564. var inputStream = state.inputStream;
  4565. while (true) {
  4566. lrMemoRec.matchLength = inputStream.pos - origPos;
  4567. lrMemoRec.value = newValue;
  4568. lrMemoRec.failuresAtRightmostPosition = state.cloneRecordedFailures();
  4569. if (state.isTracing()) {
  4570. // Before evaluating the body again, add a trace node for this application to the memo entry.
  4571. // Its only child is a copy of the trace node from `newValue`, which will always be the last
  4572. // element in `state.trace`.
  4573. var seedTrace = state.trace[state.trace.length - 1];
  4574. lrMemoRec.traceEntry = new Trace(
  4575. state.input, origPos, inputStream.pos, this, true, [newValue], [seedTrace.clone()]);
  4576. }
  4577. inputStream.pos = origPos;
  4578. newValue = this.evalOnce(body, state);
  4579. if (inputStream.pos - origPos <= lrMemoRec.matchLength) {
  4580. break;
  4581. }
  4582. if (state.isTracing()) {
  4583. state.trace.splice(-2, 1); // Drop the trace for the old seed.
  4584. }
  4585. }
  4586. if (state.isTracing()) {
  4587. // The last entry is for an unused result -- pop it and save it in the "real" entry.
  4588. lrMemoRec.traceEntry.recordLRTermination(state.trace.pop(), newValue);
  4589. }
  4590. inputStream.pos = origPos + lrMemoRec.matchLength;
  4591. return lrMemoRec.value;
  4592. };
  4593. pexprs.UnicodeChar.prototype.eval = function(state) {
  4594. var inputStream = state.inputStream;
  4595. var origPos = inputStream.pos;
  4596. var ch = inputStream.next();
  4597. if (ch && this.pattern.test(ch)) {
  4598. state.pushBinding(new TerminalNode(state.grammar, ch), origPos);
  4599. return true;
  4600. } else {
  4601. state.processFailure(origPos, this);
  4602. return false;
  4603. }
  4604. };
  4605. },{"./Trace":43,"./common":44,"./errors":45,"./nodes":47,"./pexprs":64}],54:[function(require,module,exports){
  4606. 'use strict';
  4607. // --------------------------------------------------------------------
  4608. // Imports
  4609. // --------------------------------------------------------------------
  4610. var common = require('./common');
  4611. var pexprs = require('./pexprs');
  4612. // --------------------------------------------------------------------
  4613. // Helpers
  4614. // --------------------------------------------------------------------
  4615. function flatten(listOfLists) {
  4616. return Array.prototype.concat.apply([], listOfLists);
  4617. }
  4618. // --------------------------------------------------------------------
  4619. // Operations
  4620. // --------------------------------------------------------------------
  4621. pexprs.PExpr.prototype.generateExample = common.abstract('generateExample');
  4622. function categorizeExamples(examples) {
  4623. // A list of rules that the system needs examples of, in order to generate an example
  4624. // for the current rule
  4625. var examplesNeeded = examples.filter(function(example) {
  4626. return example.hasOwnProperty('examplesNeeded');
  4627. })
  4628. .map(function(example) { return example.examplesNeeded; });
  4629. examplesNeeded = flatten(examplesNeeded);
  4630. var uniqueExamplesNeeded = {};
  4631. for (var i = 0; i < examplesNeeded.length; i++) {
  4632. var currentExampleNeeded = examplesNeeded[i];
  4633. uniqueExamplesNeeded[currentExampleNeeded] = true;
  4634. }
  4635. examplesNeeded = Object.keys(uniqueExamplesNeeded);
  4636. // A list of successfully generated examples
  4637. var successfulExamples = examples.filter(function(example) {
  4638. return example.hasOwnProperty('value');
  4639. })
  4640. .map(function(item) { return item.value; });
  4641. // This flag returns true if the system cannot generate the rule it is currently
  4642. // attempting to generate, regardless of whether or not it has the examples it needs.
  4643. // Currently, this is only used in overriding generators to prevent the system from
  4644. // generating examples for certain rules (e.g. 'ident').
  4645. var needHelp = examples.some(function(item) { return item.needHelp; });
  4646. return {
  4647. examplesNeeded: examplesNeeded,
  4648. successfulExamples: successfulExamples,
  4649. needHelp: needHelp
  4650. };
  4651. }
  4652. pexprs.any.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4653. return {value: String.fromCharCode(Math.floor(Math.random() * 255))};
  4654. };
  4655. // Assumes that terminal's object is always a string
  4656. pexprs.Terminal.prototype.generateExample = function(grammar, examples, inSyntacticContext) {
  4657. return {value: this.obj};
  4658. };
  4659. pexprs.Range.prototype.generateExample = function(grammar, examples, inSyntacticContext) {
  4660. var rangeSize = this.to.charCodeAt(0) - this.from.charCodeAt(0);
  4661. return {value: String.fromCharCode(
  4662. this.from.charCodeAt(0) + Math.floor(rangeSize * Math.random())
  4663. )};
  4664. };
  4665. pexprs.Param.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4666. return actuals[this.index].generateExample(grammar, examples, inSyntacticContext, actuals);
  4667. };
  4668. pexprs.Alt.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4669. // items -> termExamples
  4670. var termExamples = this.terms.map(function(term) {
  4671. return term.generateExample(grammar, examples, inSyntacticContext, actuals);
  4672. });
  4673. var categorizedExamples = categorizeExamples(termExamples);
  4674. var examplesNeeded = categorizedExamples.examplesNeeded;
  4675. var successfulExamples = categorizedExamples.successfulExamples;
  4676. var needHelp = categorizedExamples.needHelp;
  4677. var ans = {};
  4678. // Alt can contain both an example and a request for examples
  4679. if (successfulExamples.length > 0) {
  4680. var i = Math.floor(Math.random() * successfulExamples.length);
  4681. ans.value = successfulExamples[i];
  4682. }
  4683. if (examplesNeeded.length > 0) {
  4684. ans.examplesNeeded = examplesNeeded;
  4685. }
  4686. ans.needHelp = needHelp;
  4687. return ans;
  4688. };
  4689. pexprs.Seq.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4690. var factorExamples = this.factors.map(function(factor) {
  4691. return factor.generateExample(grammar, examples, inSyntacticContext, actuals);
  4692. });
  4693. var categorizedExamples = categorizeExamples(factorExamples);
  4694. var examplesNeeded = categorizedExamples.examplesNeeded;
  4695. var successfulExamples = categorizedExamples.successfulExamples;
  4696. var needHelp = categorizedExamples.needHelp;
  4697. var ans = {};
  4698. // In a Seq, all pieces must succeed in order to have a successful example.
  4699. if (examplesNeeded.length > 0 || needHelp) {
  4700. ans.examplesNeeded = examplesNeeded;
  4701. ans.needHelp = needHelp;
  4702. } else {
  4703. ans.value = successfulExamples.join(inSyntacticContext ? ' ' : '');
  4704. }
  4705. return ans;
  4706. };
  4707. pexprs.Iter.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4708. var rangeTimes = Math.min(this.maxNumMatches - this.minNumMatches, 3);
  4709. var numTimes = Math.floor(Math.random() * (rangeTimes + 1) + this.minNumMatches);
  4710. var items = [];
  4711. for (var i = 0; i < numTimes; i++) {
  4712. items.push(this.expr.generateExample(grammar, examples, inSyntacticContext, actuals));
  4713. }
  4714. var categorizedExamples = categorizeExamples(items);
  4715. var examplesNeeded = categorizedExamples.examplesNeeded;
  4716. var successfulExamples = categorizedExamples.successfulExamples;
  4717. var ans = {};
  4718. // It's always either one or the other.
  4719. // TODO: instead of ' ', call 'spaces.generateExample()'
  4720. ans.value = successfulExamples.join(inSyntacticContext ? ' ' : '');
  4721. if (examplesNeeded.length > 0) {
  4722. ans.examplesNeeded = examplesNeeded;
  4723. }
  4724. return ans;
  4725. };
  4726. // Right now, 'Not' and 'Lookahead' generate nothing and assume that whatever follows will
  4727. // work according to the encoded constraints.
  4728. pexprs.Not.prototype.generateExample = function(grammar, examples, inSyntacticContext) {
  4729. return {value: ''};
  4730. };
  4731. pexprs.Lookahead.prototype.generateExample = function(grammar, examples, inSyntacticContext) {
  4732. return {value: ''};
  4733. };
  4734. pexprs.Lex.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4735. return this.expr.generateExample(grammar, examples, false, actuals);
  4736. };
  4737. pexprs.Apply.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {
  4738. var ans = {};
  4739. var ruleName = this.substituteParams(actuals).toString();
  4740. if (!examples.hasOwnProperty(ruleName)) {
  4741. ans.examplesNeeded = [ruleName];
  4742. } else {
  4743. var relevantExamples = examples[ruleName];
  4744. var i = Math.floor(Math.random() * relevantExamples.length);
  4745. ans.value = relevantExamples[i];
  4746. }
  4747. return ans;
  4748. };
  4749. pexprs.UnicodeChar.prototype.generateExample = function(
  4750. grammar, examples, inSyntacticContext, actuals) {
  4751. var char;
  4752. switch (this.category) {
  4753. case 'Lu': char = 'Á'; break;
  4754. case 'Ll': char = 'ŏ'; break;
  4755. case 'Lt': char = 'Dž'; break;
  4756. case 'Lm': char = 'ˮ'; break;
  4757. case 'Lo': char = 'ƻ'; break;
  4758. case 'Nl': char = 'ↂ'; break;
  4759. case 'Nd': char = '½'; break;
  4760. case 'Mn': char = '\u0487'; break;
  4761. case 'Mc': char = 'ि'; break;
  4762. case 'Pc': char = '⁀'; break;
  4763. case 'Zs': char = '\u2001'; break;
  4764. case 'L': char = 'Á'; break;
  4765. case 'Ltmo': char = 'Dž'; break;
  4766. }
  4767. return {value: char}; // 💩
  4768. };
  4769. },{"./common":44,"./pexprs":64}],55:[function(require,module,exports){
  4770. 'use strict';
  4771. // --------------------------------------------------------------------
  4772. // Imports
  4773. // --------------------------------------------------------------------
  4774. var common = require('./common');
  4775. var pexprs = require('./pexprs');
  4776. // --------------------------------------------------------------------
  4777. // Operations
  4778. // --------------------------------------------------------------------
  4779. pexprs.PExpr.prototype.getArity = common.abstract('getArity');
  4780. pexprs.any.getArity =
  4781. pexprs.end.getArity =
  4782. pexprs.Terminal.prototype.getArity =
  4783. pexprs.Range.prototype.getArity =
  4784. pexprs.Param.prototype.getArity =
  4785. pexprs.Apply.prototype.getArity =
  4786. pexprs.UnicodeChar.prototype.getArity = function() {
  4787. return 1;
  4788. };
  4789. pexprs.Alt.prototype.getArity = function() {
  4790. // This is ok b/c all terms must have the same arity -- this property is
  4791. // checked by the Grammar constructor.
  4792. return this.terms.length === 0 ? 0 : this.terms[0].getArity();
  4793. };
  4794. pexprs.Seq.prototype.getArity = function() {
  4795. var arity = 0;
  4796. for (var idx = 0; idx < this.factors.length; idx++) {
  4797. arity += this.factors[idx].getArity();
  4798. }
  4799. return arity;
  4800. };
  4801. pexprs.Iter.prototype.getArity = function() {
  4802. return this.expr.getArity();
  4803. };
  4804. pexprs.Not.prototype.getArity = function() {
  4805. return 0;
  4806. };
  4807. pexprs.Lookahead.prototype.getArity =
  4808. pexprs.Lex.prototype.getArity = function() {
  4809. return this.expr.getArity();
  4810. };
  4811. },{"./common":44,"./pexprs":64}],56:[function(require,module,exports){
  4812. 'use strict';
  4813. // --------------------------------------------------------------------
  4814. // Imports
  4815. // --------------------------------------------------------------------
  4816. var common = require('./common');
  4817. var pexprs = require('./pexprs');
  4818. // --------------------------------------------------------------------
  4819. // Operations
  4820. // --------------------------------------------------------------------
  4821. /*
  4822. Called at grammar creation time to rewrite a rule body, replacing each reference to a formal
  4823. parameter with a `Param` node. Returns a PExpr -- either a new one, or the original one if
  4824. it was modified in place.
  4825. */
  4826. pexprs.PExpr.prototype.introduceParams = common.abstract('introduceParams');
  4827. pexprs.any.introduceParams =
  4828. pexprs.end.introduceParams =
  4829. pexprs.Terminal.prototype.introduceParams =
  4830. pexprs.Range.prototype.introduceParams =
  4831. pexprs.Param.prototype.introduceParams =
  4832. pexprs.UnicodeChar.prototype.introduceParams = function(formals) {
  4833. return this;
  4834. };
  4835. pexprs.Alt.prototype.introduceParams = function(formals) {
  4836. this.terms.forEach(function(term, idx, terms) {
  4837. terms[idx] = term.introduceParams(formals);
  4838. });
  4839. return this;
  4840. };
  4841. pexprs.Seq.prototype.introduceParams = function(formals) {
  4842. this.factors.forEach(function(factor, idx, factors) {
  4843. factors[idx] = factor.introduceParams(formals);
  4844. });
  4845. return this;
  4846. };
  4847. pexprs.Iter.prototype.introduceParams =
  4848. pexprs.Not.prototype.introduceParams =
  4849. pexprs.Lookahead.prototype.introduceParams =
  4850. pexprs.Lex.prototype.introduceParams = function(formals) {
  4851. this.expr = this.expr.introduceParams(formals);
  4852. return this;
  4853. };
  4854. pexprs.Apply.prototype.introduceParams = function(formals) {
  4855. var index = formals.indexOf(this.ruleName);
  4856. if (index >= 0) {
  4857. if (this.args.length > 0) {
  4858. // TODO: Should this be supported? See issue #64.
  4859. throw new Error('Parameterized rules cannot be passed as arguments to another rule.');
  4860. }
  4861. return new pexprs.Param(index).withSource(this.source);
  4862. } else {
  4863. this.args.forEach(function(arg, idx, args) {
  4864. args[idx] = arg.introduceParams(formals);
  4865. });
  4866. return this;
  4867. }
  4868. };
  4869. },{"./common":44,"./pexprs":64}],57:[function(require,module,exports){
  4870. 'use strict';
  4871. // --------------------------------------------------------------------
  4872. // Imports
  4873. // --------------------------------------------------------------------
  4874. var common = require('./common');
  4875. var pexprs = require('./pexprs');
  4876. // --------------------------------------------------------------------
  4877. // Operations
  4878. // --------------------------------------------------------------------
  4879. // Returns `true` if this parsing expression may accept without consuming any input.
  4880. pexprs.PExpr.prototype.isNullable = function(grammar) {
  4881. return this._isNullable(grammar, Object.create(null));
  4882. };
  4883. pexprs.PExpr.prototype._isNullable = common.abstract('_isNullable');
  4884. pexprs.any._isNullable =
  4885. pexprs.Range.prototype._isNullable =
  4886. pexprs.Param.prototype._isNullable =
  4887. pexprs.Plus.prototype._isNullable =
  4888. pexprs.UnicodeChar.prototype._isNullable = function(grammar, memo) {
  4889. return false;
  4890. };
  4891. pexprs.end._isNullable = function(grammar, memo) {
  4892. return true;
  4893. };
  4894. pexprs.Terminal.prototype._isNullable = function(grammar, memo) {
  4895. if (typeof this.obj === 'string') {
  4896. // This is an over-simplification: it's only correct if the input is a string. If it's an array
  4897. // or an object, then the empty string parsing expression is not nullable.
  4898. return this.obj === '';
  4899. } else {
  4900. return false;
  4901. }
  4902. };
  4903. pexprs.Alt.prototype._isNullable = function(grammar, memo) {
  4904. return this.terms.length === 0 ||
  4905. this.terms.some(function(term) { return term._isNullable(grammar, memo); });
  4906. };
  4907. pexprs.Seq.prototype._isNullable = function(grammar, memo) {
  4908. return this.factors.every(function(factor) { return factor._isNullable(grammar, memo); });
  4909. };
  4910. pexprs.Star.prototype._isNullable =
  4911. pexprs.Opt.prototype._isNullable =
  4912. pexprs.Not.prototype._isNullable =
  4913. pexprs.Lookahead.prototype._isNullable = function(grammar, memo) {
  4914. return true;
  4915. };
  4916. pexprs.Lex.prototype._isNullable = function(grammar, memo) {
  4917. return this.expr._isNullable(grammar, memo);
  4918. };
  4919. pexprs.Apply.prototype._isNullable = function(grammar, memo) {
  4920. var key = this.toMemoKey();
  4921. if (!Object.prototype.hasOwnProperty.call(memo, key)) {
  4922. var body = grammar.rules[this.ruleName].body;
  4923. var inlined = body.substituteParams(this.args);
  4924. memo[key] = false; // Prevent infinite recursion for recursive rules.
  4925. memo[key] = inlined._isNullable(grammar, memo);
  4926. }
  4927. return memo[key];
  4928. };
  4929. },{"./common":44,"./pexprs":64}],58:[function(require,module,exports){
  4930. 'use strict';
  4931. // --------------------------------------------------------------------
  4932. // Imports
  4933. // --------------------------------------------------------------------
  4934. var common = require('./common');
  4935. var pexprs = require('./pexprs');
  4936. // --------------------------------------------------------------------
  4937. // Private stuff
  4938. // --------------------------------------------------------------------
  4939. function getMetaInfo(expr, grammarInterval) {
  4940. var metaInfo = {};
  4941. if (expr.source && grammarInterval) {
  4942. var adjusted = expr.source.relativeTo(grammarInterval);
  4943. metaInfo.sourceInterval = [adjusted.startIdx, adjusted.endIdx];
  4944. }
  4945. return metaInfo;
  4946. }
  4947. // --------------------------------------------------------------------
  4948. // Operations
  4949. // --------------------------------------------------------------------
  4950. pexprs.PExpr.prototype.outputRecipe = common.abstract('outputRecipe');
  4951. pexprs.any.outputRecipe = function(formals, grammarInterval) {
  4952. return ['any', getMetaInfo(this, grammarInterval)];
  4953. };
  4954. pexprs.end.outputRecipe = function(formals, grammarInterval) {
  4955. return ['end', getMetaInfo(this, grammarInterval)];
  4956. };
  4957. pexprs.Terminal.prototype.outputRecipe = function(formals, grammarInterval) {
  4958. return [
  4959. 'terminal',
  4960. getMetaInfo(this, grammarInterval),
  4961. this.obj
  4962. ];
  4963. };
  4964. pexprs.Range.prototype.outputRecipe = function(formals, grammarInterval) {
  4965. return [
  4966. 'range',
  4967. getMetaInfo(this, grammarInterval),
  4968. this.from,
  4969. this.to
  4970. ];
  4971. };
  4972. pexprs.Param.prototype.outputRecipe = function(formals, grammarInterval) {
  4973. return [
  4974. 'param',
  4975. getMetaInfo(this, grammarInterval),
  4976. this.index
  4977. ];
  4978. };
  4979. pexprs.Alt.prototype.outputRecipe = function(formals, grammarInterval) {
  4980. return [
  4981. 'alt',
  4982. getMetaInfo(this, grammarInterval)
  4983. ].concat(this.terms.map(function(term) {
  4984. return term.outputRecipe(formals, grammarInterval);
  4985. }));
  4986. };
  4987. pexprs.Extend.prototype.outputRecipe = function(formals, grammarInterval) {
  4988. var extension = this.terms[0]; // [extension, orginal]
  4989. return extension.outputRecipe(formals, grammarInterval);
  4990. };
  4991. pexprs.Seq.prototype.outputRecipe = function(formals, grammarInterval) {
  4992. return [
  4993. 'seq',
  4994. getMetaInfo(this, grammarInterval)
  4995. ].concat(this.factors.map(function(factor) {
  4996. return factor.outputRecipe(formals, grammarInterval);
  4997. }));
  4998. };
  4999. pexprs.Star.prototype.outputRecipe =
  5000. pexprs.Plus.prototype.outputRecipe =
  5001. pexprs.Opt.prototype.outputRecipe =
  5002. pexprs.Not.prototype.outputRecipe =
  5003. pexprs.Lookahead.prototype.outputRecipe =
  5004. pexprs.Lex.prototype.outputRecipe = function(formals, grammarInterval) {
  5005. return [
  5006. this.constructor.name.toLowerCase(),
  5007. getMetaInfo(this, grammarInterval),
  5008. this.expr.outputRecipe(formals, grammarInterval)
  5009. ];
  5010. };
  5011. pexprs.Apply.prototype.outputRecipe = function(formals, grammarInterval) {
  5012. return [
  5013. 'app',
  5014. getMetaInfo(this, grammarInterval),
  5015. this.ruleName,
  5016. this.args.map(function(arg) {
  5017. return arg.outputRecipe(formals, grammarInterval);
  5018. })
  5019. ];
  5020. };
  5021. pexprs.UnicodeChar.prototype.outputRecipe = function(formals, grammarInterval) {
  5022. return [
  5023. 'unicodeChar',
  5024. getMetaInfo(this, grammarInterval),
  5025. this.category
  5026. ];
  5027. };
  5028. },{"./common":44,"./pexprs":64}],59:[function(require,module,exports){
  5029. 'use strict';
  5030. // --------------------------------------------------------------------
  5031. // Imports
  5032. // --------------------------------------------------------------------
  5033. var common = require('./common');
  5034. var pexprs = require('./pexprs');
  5035. // --------------------------------------------------------------------
  5036. // Operations
  5037. // --------------------------------------------------------------------
  5038. /*
  5039. Returns a PExpr that results from recursively replacing every formal parameter (i.e., instance
  5040. of `Param`) inside this PExpr with its actual value from `actuals` (an Array).
  5041. The receiver must not be modified; a new PExpr must be returned if any replacement is necessary.
  5042. */
  5043. // function(actuals) { ... }
  5044. pexprs.PExpr.prototype.substituteParams = common.abstract('substituteParams');
  5045. pexprs.any.substituteParams =
  5046. pexprs.end.substituteParams =
  5047. pexprs.Terminal.prototype.substituteParams =
  5048. pexprs.Range.prototype.substituteParams =
  5049. pexprs.UnicodeChar.prototype.substituteParams = function(actuals) {
  5050. return this;
  5051. };
  5052. pexprs.Param.prototype.substituteParams = function(actuals) {
  5053. return actuals[this.index];
  5054. };
  5055. pexprs.Alt.prototype.substituteParams = function(actuals) {
  5056. return new pexprs.Alt(
  5057. this.terms.map(function(term) { return term.substituteParams(actuals); }));
  5058. };
  5059. pexprs.Seq.prototype.substituteParams = function(actuals) {
  5060. return new pexprs.Seq(
  5061. this.factors.map(function(factor) { return factor.substituteParams(actuals); }));
  5062. };
  5063. pexprs.Iter.prototype.substituteParams =
  5064. pexprs.Not.prototype.substituteParams =
  5065. pexprs.Lookahead.prototype.substituteParams =
  5066. pexprs.Lex.prototype.substituteParams = function(actuals) {
  5067. return new this.constructor(this.expr.substituteParams(actuals));
  5068. };
  5069. pexprs.Apply.prototype.substituteParams = function(actuals) {
  5070. if (this.args.length === 0) {
  5071. // Avoid making a copy of this application, as an optimization
  5072. return this;
  5073. } else {
  5074. var args = this.args.map(function(arg) { return arg.substituteParams(actuals); });
  5075. return new pexprs.Apply(this.ruleName, args);
  5076. }
  5077. };
  5078. },{"./common":44,"./pexprs":64}],60:[function(require,module,exports){
  5079. 'use strict';
  5080. // --------------------------------------------------------------------
  5081. // Imports
  5082. // --------------------------------------------------------------------
  5083. var common = require('./common');
  5084. var pexprs = require('./pexprs');
  5085. var copyWithoutDuplicates = common.copyWithoutDuplicates;
  5086. // --------------------------------------------------------------------
  5087. // Private stuff
  5088. // --------------------------------------------------------------------
  5089. function isRestrictedJSIdentifier(str) {
  5090. return /^[a-zA-Z_$][0-9a-zA-Z_$]*$/.test(str);
  5091. }
  5092. function resolveDuplicatedNames(argumentNameList) {
  5093. // `count` is used to record the number of times each argument name occurs in the list,
  5094. // this is useful for checking duplicated argument name. It maps argument names to ints.
  5095. var count = Object.create(null);
  5096. argumentNameList.forEach(function(argName) {
  5097. count[argName] = (count[argName] || 0) + 1;
  5098. });
  5099. // Append subscripts ('_1', '_2', ...) to duplicate argument names.
  5100. Object.keys(count).forEach(function(dupArgName) {
  5101. if (count[dupArgName] <= 1) {
  5102. return;
  5103. }
  5104. // This name shows up more than once, so add subscripts.
  5105. var subscript = 1;
  5106. argumentNameList.forEach(function(argName, idx) {
  5107. if (argName === dupArgName) {
  5108. argumentNameList[idx] = argName + '_' + subscript++;
  5109. }
  5110. });
  5111. });
  5112. }
  5113. // --------------------------------------------------------------------
  5114. // Operations
  5115. // --------------------------------------------------------------------
  5116. /*
  5117. Returns a list of strings that will be used as the default argument names for its receiver
  5118. (a pexpr) in a semantic action. This is used exclusively by the Semantics Editor.
  5119. `firstArgIndex` is the 1-based index of the first argument name that will be generated for this
  5120. pexpr. It enables us to name arguments positionally, e.g., if the second argument is a
  5121. non-alphanumeric terminal like "+", it will be named '$2'.
  5122. `noDupCheck` is true if the caller of `toArgumentNameList` is not a top level caller. It enables
  5123. us to avoid nested duplication subscripts appending, e.g., '_1_1', '_1_2', by only checking
  5124. duplicates at the top level.
  5125. Here is a more elaborate example that illustrates how this method works:
  5126. `(a "+" b).toArgumentNameList(1)` evaluates to `['a', '$2', 'b']` with the following recursive
  5127. calls:
  5128. (a).toArgumentNameList(1) -> ['a'],
  5129. ("+").toArgumentNameList(2) -> ['$2'],
  5130. (b).toArgumentNameList(3) -> ['b']
  5131. Notes:
  5132. * This method must only be called on well-formed expressions, e.g., the receiver must
  5133. not have any Alt sub-expressions with inconsistent arities.
  5134. * e.getArity() === e.toArgumentNameList(1).length
  5135. */
  5136. // function(firstArgIndex, noDupCheck) { ... }
  5137. pexprs.PExpr.prototype.toArgumentNameList = common.abstract('toArgumentNameList');
  5138. pexprs.any.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5139. return ['any'];
  5140. };
  5141. pexprs.end.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5142. return ['end'];
  5143. };
  5144. pexprs.Terminal.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5145. if (typeof this.obj === 'string' && /^[_a-zA-Z0-9]+$/.test(this.obj)) {
  5146. // If this terminal is a valid suffix for a JS identifier, just prepend it with '_'
  5147. return ['_' + this.obj];
  5148. } else {
  5149. // Otherwise, name it positionally.
  5150. return ['$' + firstArgIndex];
  5151. }
  5152. };
  5153. pexprs.Range.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5154. var argName = this.from + '_to_' + this.to;
  5155. // If the `argName` is not valid then try to prepend a `_`.
  5156. if (!isRestrictedJSIdentifier(argName)) {
  5157. argName = '_' + argName;
  5158. }
  5159. // If the `argName` still not valid after prepending a `_`, then name it positionally.
  5160. if (!isRestrictedJSIdentifier(argName)) {
  5161. argName = '$' + firstArgIndex;
  5162. }
  5163. return [argName];
  5164. };
  5165. pexprs.Alt.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5166. // `termArgNameLists` is an array of arrays where each row is the
  5167. // argument name list that corresponds to a term in this alternation.
  5168. var termArgNameLists = this.terms.map(function(term) {
  5169. return term.toArgumentNameList(firstArgIndex, true);
  5170. });
  5171. var argumentNameList = [];
  5172. var numArgs = termArgNameLists[0].length;
  5173. for (var colIdx = 0; colIdx < numArgs; colIdx++) {
  5174. var col = [];
  5175. for (var rowIdx = 0; rowIdx < this.terms.length; rowIdx++) {
  5176. col.push(termArgNameLists[rowIdx][colIdx]);
  5177. }
  5178. var uniqueNames = copyWithoutDuplicates(col);
  5179. argumentNameList.push(uniqueNames.join('_or_'));
  5180. }
  5181. if (!noDupCheck) {
  5182. resolveDuplicatedNames(argumentNameList);
  5183. }
  5184. return argumentNameList;
  5185. };
  5186. pexprs.Seq.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5187. // Generate the argument name list, without worrying about duplicates.
  5188. var argumentNameList = [];
  5189. this.factors.forEach(function(factor) {
  5190. var factorArgumentNameList = factor.toArgumentNameList(firstArgIndex, true);
  5191. argumentNameList = argumentNameList.concat(factorArgumentNameList);
  5192. // Shift the firstArgIndex to take this factor's argument names into account.
  5193. firstArgIndex += factorArgumentNameList.length;
  5194. });
  5195. if (!noDupCheck) {
  5196. resolveDuplicatedNames(argumentNameList);
  5197. }
  5198. return argumentNameList;
  5199. };
  5200. pexprs.Iter.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5201. var argumentNameList = this.expr.toArgumentNameList(firstArgIndex, noDupCheck)
  5202. .map(function(exprArgumentString) {
  5203. return exprArgumentString[exprArgumentString.length - 1] === 's' ?
  5204. exprArgumentString + 'es' :
  5205. exprArgumentString + 's';
  5206. });
  5207. if (!noDupCheck) {
  5208. resolveDuplicatedNames(argumentNameList);
  5209. }
  5210. return argumentNameList;
  5211. };
  5212. pexprs.Opt.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5213. return this.expr.toArgumentNameList(firstArgIndex, noDupCheck).map(function(argName) {
  5214. return 'opt' + argName[0].toUpperCase() + argName.slice(1);
  5215. });
  5216. };
  5217. pexprs.Not.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5218. return [];
  5219. };
  5220. pexprs.Lookahead.prototype.toArgumentNameList =
  5221. pexprs.Lex.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5222. return this.expr.toArgumentNameList(firstArgIndex, noDupCheck);
  5223. };
  5224. pexprs.Apply.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5225. return [this.ruleName];
  5226. };
  5227. pexprs.UnicodeChar.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5228. return ['$' + firstArgIndex];
  5229. };
  5230. pexprs.Param.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {
  5231. return ['param' + this.index];
  5232. };
  5233. // "Value pexprs" (Value, Str, Arr, Obj) are going away soon, so we don't worry about them here.
  5234. },{"./common":44,"./pexprs":64}],61:[function(require,module,exports){
  5235. 'use strict';
  5236. // --------------------------------------------------------------------
  5237. // Imports
  5238. // --------------------------------------------------------------------
  5239. var common = require('./common');
  5240. var pexprs = require('./pexprs');
  5241. // --------------------------------------------------------------------
  5242. // Operations
  5243. // --------------------------------------------------------------------
  5244. // Returns a string representing the PExpr, for use as a UI label, etc.
  5245. pexprs.PExpr.prototype.toDisplayString = common.abstract('toDisplayString');
  5246. pexprs.Alt.prototype.toDisplayString =
  5247. pexprs.Seq.prototype.toDisplayString = function() {
  5248. if (this.source) {
  5249. return this.source.trimmed().contents;
  5250. }
  5251. return '[' + this.constructor.name + ']';
  5252. };
  5253. pexprs.any.toDisplayString =
  5254. pexprs.end.toDisplayString =
  5255. pexprs.Iter.prototype.toDisplayString =
  5256. pexprs.Not.prototype.toDisplayString =
  5257. pexprs.Lookahead.prototype.toDisplayString =
  5258. pexprs.Lex.prototype.toDisplayString =
  5259. pexprs.Terminal.prototype.toDisplayString =
  5260. pexprs.Range.prototype.toDisplayString =
  5261. pexprs.Param.prototype.toDisplayString = function() {
  5262. return this.toString();
  5263. };
  5264. pexprs.Apply.prototype.toDisplayString = function() {
  5265. if (this.args.length > 0) {
  5266. var ps = this.args.map(function(arg) { return arg.toDisplayString(); });
  5267. return this.ruleName + '<' + ps.join(',') + '>';
  5268. } else {
  5269. return this.ruleName;
  5270. }
  5271. };
  5272. pexprs.UnicodeChar.prototype.toDisplayString = function() {
  5273. return 'Unicode [' + this.category + '] character';
  5274. };
  5275. },{"./common":44,"./pexprs":64}],62:[function(require,module,exports){
  5276. 'use strict';
  5277. // --------------------------------------------------------------------
  5278. // Imports
  5279. // --------------------------------------------------------------------
  5280. var Failure = require('./Failure');
  5281. var common = require('./common');
  5282. var pexprs = require('./pexprs');
  5283. // --------------------------------------------------------------------
  5284. // Operations
  5285. // --------------------------------------------------------------------
  5286. pexprs.PExpr.prototype.toFailure = common.abstract('toFailure');
  5287. pexprs.any.toFailure = function(grammar) {
  5288. return new Failure(this, 'any object', 'description');
  5289. };
  5290. pexprs.end.toFailure = function(grammar) {
  5291. return new Failure(this, 'end of input', 'description');
  5292. };
  5293. pexprs.Terminal.prototype.toFailure = function(grammar) {
  5294. return new Failure(this, this.obj, 'string');
  5295. };
  5296. pexprs.Range.prototype.toFailure = function(grammar) {
  5297. // TODO: come up with something better
  5298. return new Failure(this, JSON.stringify(this.from) + '..' + JSON.stringify(this.to), 'code');
  5299. };
  5300. pexprs.Not.prototype.toFailure = function(grammar) {
  5301. var description = this.expr === pexprs.any ?
  5302. 'nothing' :
  5303. 'not ' + this.expr.toFailure(grammar);
  5304. return new Failure(this, description, 'description');
  5305. };
  5306. pexprs.Lookahead.prototype.toFailure = function(grammar) {
  5307. return this.expr.toFailure(grammar);
  5308. };
  5309. pexprs.Apply.prototype.toFailure = function(grammar) {
  5310. var description = grammar.rules[this.ruleName].description;
  5311. if (!description) {
  5312. var article = (/^[aeiouAEIOU]/.test(this.ruleName) ? 'an' : 'a');
  5313. description = article + ' ' + this.ruleName;
  5314. }
  5315. return new Failure(this, description, 'description');
  5316. };
  5317. pexprs.UnicodeChar.prototype.toFailure = function(grammar) {
  5318. return new Failure(this, 'a Unicode [' + this.category + '] character', 'description');
  5319. };
  5320. pexprs.Alt.prototype.toFailure = function(grammar) {
  5321. var fs = this.terms.map(function(t) { return t.toFailure(grammar); });
  5322. var description = '(' + fs.join(' or ') + ')';
  5323. return new Failure(this, description, 'description');
  5324. };
  5325. pexprs.Seq.prototype.toFailure = function(grammar) {
  5326. var fs = this.factors.map(function(f) { return f.toFailure(grammar); });
  5327. var description = '(' + fs.join(' ') + ')';
  5328. return new Failure(this, description, 'description');
  5329. };
  5330. pexprs.Iter.prototype.toFailure = function(grammar) {
  5331. var description = '(' + this.expr.toFailure(grammar) + this.operator + ')';
  5332. return new Failure(this, description, 'description');
  5333. };
  5334. },{"./Failure":32,"./common":44,"./pexprs":64}],63:[function(require,module,exports){
  5335. 'use strict';
  5336. // --------------------------------------------------------------------
  5337. // Imports
  5338. // --------------------------------------------------------------------
  5339. var common = require('./common');
  5340. var pexprs = require('./pexprs');
  5341. // --------------------------------------------------------------------
  5342. // Operations
  5343. // --------------------------------------------------------------------
  5344. /*
  5345. e1.toString() === e2.toString() ==> e1 and e2 are semantically equivalent.
  5346. Note that this is not an iff (<==>): e.g.,
  5347. (~"b" "a").toString() !== ("a").toString(), even though
  5348. ~"b" "a" and "a" are interchangeable in any grammar,
  5349. both in terms of the languages they accept and their arities.
  5350. */
  5351. pexprs.PExpr.prototype.toString = common.abstract('toString');
  5352. pexprs.any.toString = function() {
  5353. return 'any';
  5354. };
  5355. pexprs.end.toString = function() {
  5356. return 'end';
  5357. };
  5358. pexprs.Terminal.prototype.toString = function() {
  5359. return JSON.stringify(this.obj);
  5360. };
  5361. pexprs.Range.prototype.toString = function() {
  5362. return JSON.stringify(this.from) + '..' + JSON.stringify(this.to);
  5363. };
  5364. pexprs.Param.prototype.toString = function() {
  5365. return '$' + this.index;
  5366. };
  5367. pexprs.Lex.prototype.toString = function() {
  5368. return '#(' + this.expr.toString() + ')';
  5369. };
  5370. pexprs.Alt.prototype.toString = function() {
  5371. return this.terms.length === 1 ?
  5372. this.terms[0].toString() :
  5373. '(' + this.terms.map(function(term) { return term.toString(); }).join(' | ') + ')';
  5374. };
  5375. pexprs.Seq.prototype.toString = function() {
  5376. return this.factors.length === 1 ?
  5377. this.factors[0].toString() :
  5378. '(' + this.factors.map(function(factor) { return factor.toString(); }).join(' ') + ')';
  5379. };
  5380. pexprs.Iter.prototype.toString = function() {
  5381. return this.expr + this.operator;
  5382. };
  5383. pexprs.Not.prototype.toString = function() {
  5384. return '~' + this.expr;
  5385. };
  5386. pexprs.Lookahead.prototype.toString = function() {
  5387. return '&' + this.expr;
  5388. };
  5389. pexprs.Apply.prototype.toString = function() {
  5390. if (this.args.length > 0) {
  5391. var ps = this.args.map(function(arg) { return arg.toString(); });
  5392. return this.ruleName + '<' + ps.join(',') + '>';
  5393. } else {
  5394. return this.ruleName;
  5395. }
  5396. };
  5397. pexprs.UnicodeChar.prototype.toString = function() {
  5398. return '\\p{' + this.category + '}';
  5399. };
  5400. },{"./common":44,"./pexprs":64}],64:[function(require,module,exports){
  5401. 'use strict';
  5402. // --------------------------------------------------------------------
  5403. // Imports
  5404. // --------------------------------------------------------------------
  5405. var UnicodeCategories = require('../third_party/UnicodeCategories');
  5406. var common = require('./common');
  5407. var inherits = require('inherits');
  5408. // --------------------------------------------------------------------
  5409. // Private stuff
  5410. // --------------------------------------------------------------------
  5411. // General stuff
  5412. function PExpr() {
  5413. throw new Error("PExpr cannot be instantiated -- it's abstract");
  5414. }
  5415. // Set the `source` property to the interval containing the source for this expression.
  5416. PExpr.prototype.withSource = function(interval) {
  5417. if (interval) {
  5418. this.source = interval.trimmed();
  5419. }
  5420. return this;
  5421. };
  5422. // Any
  5423. var any = Object.create(PExpr.prototype);
  5424. // End
  5425. var end = Object.create(PExpr.prototype);
  5426. // Terminals
  5427. function Terminal(obj) {
  5428. this.obj = obj;
  5429. }
  5430. inherits(Terminal, PExpr);
  5431. // Ranges
  5432. function Range(from, to) {
  5433. this.from = from;
  5434. this.to = to;
  5435. }
  5436. inherits(Range, PExpr);
  5437. // Parameters
  5438. function Param(index) {
  5439. this.index = index;
  5440. }
  5441. inherits(Param, PExpr);
  5442. // Alternation
  5443. function Alt(terms) {
  5444. this.terms = terms;
  5445. }
  5446. inherits(Alt, PExpr);
  5447. // Extend is an implementation detail of rule extension
  5448. function Extend(superGrammar, name, body) {
  5449. this.superGrammar = superGrammar;
  5450. this.name = name;
  5451. this.body = body;
  5452. var origBody = superGrammar.rules[name].body;
  5453. this.terms = [body, origBody];
  5454. }
  5455. inherits(Extend, Alt);
  5456. // Sequences
  5457. function Seq(factors) {
  5458. this.factors = factors;
  5459. }
  5460. inherits(Seq, PExpr);
  5461. // Iterators and optionals
  5462. function Iter(expr) {
  5463. this.expr = expr;
  5464. }
  5465. inherits(Iter, PExpr);
  5466. function Star(expr) {
  5467. this.expr = expr;
  5468. }
  5469. inherits(Star, Iter);
  5470. function Plus(expr) {
  5471. this.expr = expr;
  5472. }
  5473. inherits(Plus, Iter);
  5474. function Opt(expr) {
  5475. this.expr = expr;
  5476. }
  5477. inherits(Opt, Iter);
  5478. Star.prototype.operator = '*';
  5479. Plus.prototype.operator = '+';
  5480. Opt.prototype.operator = '?';
  5481. Star.prototype.minNumMatches = 0;
  5482. Plus.prototype.minNumMatches = 1;
  5483. Opt.prototype.minNumMatches = 0;
  5484. Star.prototype.maxNumMatches = Number.POSITIVE_INFINITY;
  5485. Plus.prototype.maxNumMatches = Number.POSITIVE_INFINITY;
  5486. Opt.prototype.maxNumMatches = 1;
  5487. // Predicates
  5488. function Not(expr) {
  5489. this.expr = expr;
  5490. }
  5491. inherits(Not, PExpr);
  5492. function Lookahead(expr) {
  5493. this.expr = expr;
  5494. }
  5495. inherits(Lookahead, PExpr);
  5496. // "Lexification"
  5497. function Lex(expr) {
  5498. this.expr = expr;
  5499. }
  5500. inherits(Lex, PExpr);
  5501. // Rule application
  5502. function Apply(ruleName, optArgs) {
  5503. this.ruleName = ruleName;
  5504. this.args = optArgs || [];
  5505. }
  5506. inherits(Apply, PExpr);
  5507. Apply.prototype.isSyntactic = function() {
  5508. return common.isSyntactic(this.ruleName);
  5509. };
  5510. // This method just caches the result of `this.toString()` in a non-enumerable property.
  5511. Apply.prototype.toMemoKey = function() {
  5512. if (!this._memoKey) {
  5513. Object.defineProperty(this, '_memoKey', {value: this.toString()});
  5514. }
  5515. return this._memoKey;
  5516. };
  5517. // Unicode character
  5518. function UnicodeChar(category) {
  5519. this.category = category;
  5520. this.pattern = UnicodeCategories[category];
  5521. }
  5522. inherits(UnicodeChar, PExpr);
  5523. // --------------------------------------------------------------------
  5524. // Exports
  5525. // --------------------------------------------------------------------
  5526. exports.PExpr = PExpr;
  5527. exports.any = any;
  5528. exports.end = end;
  5529. exports.Terminal = Terminal;
  5530. exports.Range = Range;
  5531. exports.Param = Param;
  5532. exports.Alt = Alt;
  5533. exports.Extend = Extend;
  5534. exports.Seq = Seq;
  5535. exports.Iter = Iter;
  5536. exports.Star = Star;
  5537. exports.Plus = Plus;
  5538. exports.Opt = Opt;
  5539. exports.Not = Not;
  5540. exports.Lookahead = Lookahead;
  5541. exports.Lex = Lex;
  5542. exports.Apply = Apply;
  5543. exports.UnicodeChar = UnicodeChar;
  5544. // --------------------------------------------------------------------
  5545. // Extensions
  5546. // --------------------------------------------------------------------
  5547. require('./pexprs-allowsSkippingPrecedingSpace');
  5548. require('./pexprs-assertAllApplicationsAreValid');
  5549. require('./pexprs-assertChoicesHaveUniformArity');
  5550. require('./pexprs-assertIteratedExprsAreNotNullable');
  5551. require('./pexprs-check');
  5552. require('./pexprs-eval');
  5553. require('./pexprs-getArity');
  5554. require('./pexprs-generateExample');
  5555. require('./pexprs-outputRecipe');
  5556. require('./pexprs-introduceParams');
  5557. require('./pexprs-isNullable');
  5558. require('./pexprs-substituteParams');
  5559. require('./pexprs-toDisplayString');
  5560. require('./pexprs-toArgumentNameList');
  5561. require('./pexprs-toFailure');
  5562. require('./pexprs-toString');
  5563. },{"../third_party/UnicodeCategories":67,"./common":44,"./pexprs-allowsSkippingPrecedingSpace":48,"./pexprs-assertAllApplicationsAreValid":49,"./pexprs-assertChoicesHaveUniformArity":50,"./pexprs-assertIteratedExprsAreNotNullable":51,"./pexprs-check":52,"./pexprs-eval":53,"./pexprs-generateExample":54,"./pexprs-getArity":55,"./pexprs-introduceParams":56,"./pexprs-isNullable":57,"./pexprs-outputRecipe":58,"./pexprs-substituteParams":59,"./pexprs-toArgumentNameList":60,"./pexprs-toDisplayString":61,"./pexprs-toFailure":62,"./pexprs-toString":63,"inherits":27}],65:[function(require,module,exports){
  5564. 'use strict';
  5565. // --------------------------------------------------------------------
  5566. // Imports
  5567. // --------------------------------------------------------------------
  5568. var common = require('./common');
  5569. // --------------------------------------------------------------------
  5570. // Private stuff
  5571. // --------------------------------------------------------------------
  5572. // Given an array of numbers `arr`, return an array of the numbers as strings,
  5573. // right-justified and padded to the same length.
  5574. function padNumbersToEqualLength(arr) {
  5575. var maxLen = 0;
  5576. var strings = arr.map(function(n) {
  5577. var str = n.toString();
  5578. maxLen = Math.max(maxLen, str.length);
  5579. return str;
  5580. });
  5581. return strings.map(function(s) { return common.padLeft(s, maxLen); });
  5582. }
  5583. // Produce a new string that would be the result of copying the contents
  5584. // of the string `src` onto `dest` at offset `offest`.
  5585. function strcpy(dest, src, offset) {
  5586. var origDestLen = dest.length;
  5587. var start = dest.slice(0, offset);
  5588. var end = dest.slice(offset + src.length);
  5589. return (start + src + end).substr(0, origDestLen);
  5590. }
  5591. // --------------------------------------------------------------------
  5592. // Exports
  5593. // --------------------------------------------------------------------
  5594. var builtInRulesCallbacks = [];
  5595. // Since Grammar.BuiltInRules is bootstrapped, most of Ohm can't directly depend it.
  5596. // This function allows modules that do depend on the built-in rules to register a callback
  5597. // that will be called later in the initialization process.
  5598. exports.awaitBuiltInRules = function(cb) {
  5599. builtInRulesCallbacks.push(cb);
  5600. };
  5601. exports.announceBuiltInRules = function(grammar) {
  5602. builtInRulesCallbacks.forEach(function(cb) {
  5603. cb(grammar);
  5604. });
  5605. builtInRulesCallbacks = null;
  5606. };
  5607. // Return an object with the line and column information for the given
  5608. // offset in `str`.
  5609. exports.getLineAndColumn = function(str, offset) {
  5610. var lineNum = 1;
  5611. var colNum = 1;
  5612. var currOffset = 0;
  5613. var lineStartOffset = 0;
  5614. var nextLine = null;
  5615. var prevLine = null;
  5616. var prevLineStartOffset = -1;
  5617. while (currOffset < offset) {
  5618. var c = str.charAt(currOffset++);
  5619. if (c === '\n') {
  5620. lineNum++;
  5621. colNum = 1;
  5622. prevLineStartOffset = lineStartOffset;
  5623. lineStartOffset = currOffset;
  5624. } else if (c !== '\r') {
  5625. colNum++;
  5626. }
  5627. }
  5628. // Find the end of the target line.
  5629. var lineEndOffset = str.indexOf('\n', lineStartOffset);
  5630. if (lineEndOffset === -1) {
  5631. lineEndOffset = str.length;
  5632. } else {
  5633. // Get the next line.
  5634. var nextLineEndOffset = str.indexOf('\n', lineEndOffset + 1);
  5635. nextLine = nextLineEndOffset === -1 ? str.slice(lineEndOffset)
  5636. : str.slice(lineEndOffset, nextLineEndOffset);
  5637. // Strip leading and trailing EOL char(s).
  5638. nextLine = nextLine.replace(/^\r?\n/, '').replace(/\r$/, '');
  5639. }
  5640. // Get the previous line.
  5641. if (prevLineStartOffset >= 0) {
  5642. prevLine = str.slice(prevLineStartOffset, lineStartOffset)
  5643. .replace(/\r?\n$/, ''); // Strip trailing EOL char(s).
  5644. }
  5645. // Get the target line, stripping a trailing carriage return if necessary.
  5646. var line = str.slice(lineStartOffset, lineEndOffset).replace(/\r$/, '');
  5647. return {
  5648. lineNum: lineNum,
  5649. colNum: colNum,
  5650. line: line,
  5651. prevLine: prevLine,
  5652. nextLine: nextLine
  5653. };
  5654. };
  5655. // Return a nicely-formatted string describing the line and column for the
  5656. // given offset in `str`.
  5657. exports.getLineAndColumnMessage = function(str, offset /* ...ranges */) {
  5658. var repeatStr = common.repeatStr;
  5659. var lineAndCol = exports.getLineAndColumn(str, offset);
  5660. var sb = new common.StringBuffer();
  5661. sb.append('Line ' + lineAndCol.lineNum + ', col ' + lineAndCol.colNum + ':\n');
  5662. // An array of the previous, current, and next line numbers as strings of equal length.
  5663. var lineNumbers = padNumbersToEqualLength([
  5664. lineAndCol.prevLine == null ? 0 : lineAndCol.lineNum - 1,
  5665. lineAndCol.lineNum,
  5666. lineAndCol.nextLine == null ? 0 : lineAndCol.lineNum + 1
  5667. ]);
  5668. // Helper for appending formatting input lines to the buffer.
  5669. function appendLine(num, content, prefix) {
  5670. sb.append(prefix + lineNumbers[num] + ' | ' + content + '\n');
  5671. }
  5672. // Include the previous line for context if possible.
  5673. if (lineAndCol.prevLine != null) {
  5674. appendLine(0, lineAndCol.prevLine, ' ');
  5675. }
  5676. // Line that the error occurred on.
  5677. appendLine(1, lineAndCol.line, '> ');
  5678. // Build up the line that points to the offset and possible indicates one or more ranges.
  5679. // Start with a blank line, and indicate each range by overlaying a string of `~` chars.
  5680. var lineLen = lineAndCol.line.length;
  5681. var indicationLine = repeatStr(' ', lineLen + 1);
  5682. var ranges = Array.prototype.slice.call(arguments, 2);
  5683. for (var i = 0; i < ranges.length; ++i) {
  5684. var startIdx = ranges[i][0];
  5685. var endIdx = ranges[i][1];
  5686. common.assert(startIdx >= 0 && startIdx <= endIdx, 'range start must be >= 0 and <= end');
  5687. var lineStartOffset = offset - lineAndCol.colNum + 1;
  5688. startIdx = Math.max(0, startIdx - lineStartOffset);
  5689. endIdx = Math.min(endIdx - lineStartOffset, lineLen);
  5690. indicationLine = strcpy(indicationLine, repeatStr('~', endIdx - startIdx), startIdx);
  5691. }
  5692. var gutterWidth = 2 + lineNumbers[1].length + 3;
  5693. sb.append(repeatStr(' ', gutterWidth));
  5694. indicationLine = strcpy(indicationLine, '^', lineAndCol.colNum - 1);
  5695. sb.append(indicationLine.replace(/ +$/, '') + '\n');
  5696. // Include the next line for context if possible.
  5697. if (lineAndCol.nextLine != null) {
  5698. appendLine(2, lineAndCol.nextLine, ' ');
  5699. }
  5700. return sb.contents();
  5701. };
  5702. },{"./common":44}],66:[function(require,module,exports){
  5703. (function (browserifyGlobalOhmVersion){
  5704. /* global browserifyGlobalOhmVersion */
  5705. 'use strict';
  5706. // When running under Node, read the version from package.json. For the browser,
  5707. // use a special global variable defined in the build process (see bin/build-debug.js).
  5708. module.exports = typeof browserifyGlobalOhmVersion === 'string'
  5709. ? browserifyGlobalOhmVersion
  5710. : require('../package.json').version;
  5711. }).call(this,"0.14.0")
  5712. },{"../package.json":undefined}],67:[function(require,module,exports){
  5713. // Based on https://github.com/mathiasbynens/unicode-9.0.0.
  5714. // These are just categories that are used in ES5/ES2015.
  5715. // The full list of Unicode categories is here: http://www.fileformat.info/info/unicode/category/index.htm.
  5716. module.exports = {
  5717. // Letters
  5718. Lu: /[A-Z\xC0-\xD6\xD8-\xDE\u0100\u0102\u0104\u0106\u0108\u010A\u010C\u010E\u0110\u0112\u0114\u0116\u0118\u011A\u011C\u011E\u0120\u0122\u0124\u0126\u0128\u012A\u012C\u012E\u0130\u0132\u0134\u0136\u0139\u013B\u013D\u013F\u0141\u0143\u0145\u0147\u014A\u014C\u014E\u0150\u0152\u0154\u0156\u0158\u015A\u015C\u015E\u0160\u0162\u0164\u0166\u0168\u016A\u016C\u016E\u0170\u0172\u0174\u0176\u0178\u0179\u017B\u017D\u0181\u0182\u0184\u0186\u0187\u0189-\u018B\u018E-\u0191\u0193\u0194\u0196-\u0198\u019C\u019D\u019F\u01A0\u01A2\u01A4\u01A6\u01A7\u01A9\u01AC\u01AE\u01AF\u01B1-\u01B3\u01B5\u01B7\u01B8\u01BC\u01C4\u01C7\u01CA\u01CD\u01CF\u01D1\u01D3\u01D5\u01D7\u01D9\u01DB\u01DE\u01E0\u01E2\u01E4\u01E6\u01E8\u01EA\u01EC\u01EE\u01F1\u01F4\u01F6-\u01F8\u01FA\u01FC\u01FE\u0200\u0202\u0204\u0206\u0208\u020A\u020C\u020E\u0210\u0212\u0214\u0216\u0218\u021A\u021C\u021E\u0220\u0222\u0224\u0226\u0228\u022A\u022C\u022E\u0230\u0232\u023A\u023B\u023D\u023E\u0241\u0243-\u0246\u0248\u024A\u024C\u024E\u0370\u0372\u0376\u037F\u0386\u0388-\u038A\u038C\u038E\u038F\u0391-\u03A1\u03A3-\u03AB\u03CF\u03D2-\u03D4\u03D8\u03DA\u03DC\u03DE\u03E0\u03E2\u03E4\u03E6\u03E8\u03EA\u03EC\u03EE\u03F4\u03F7\u03F9\u03FA\u03FD-\u042F\u0460\u0462\u0464\u0466\u0468\u046A\u046C\u046E\u0470\u0472\u0474\u0476\u0478\u047A\u047C\u047E\u0480\u048A\u048C\u048E\u0490\u0492\u0494\u0496\u0498\u049A\u049C\u049E\u04A0\u04A2\u04A4\u04A6\u04A8\u04AA\u04AC\u04AE\u04B0\u04B2\u04B4\u04B6\u04B8\u04BA\u04BC\u04BE\u04C0\u04C1\u04C3\u04C5\u04C7\u04C9\u04CB\u04CD\u04D0\u04D2\u04D4\u04D6\u04D8\u04DA\u04DC\u04DE\u04E0\u04E2\u04E4\u04E6\u04E8\u04EA\u04EC\u04EE\u04F0\u04F2\u04F4\u04F6\u04F8\u04FA\u04FC\u04FE\u0500\u0502\u0504\u0506\u0508\u050A\u050C\u050E\u0510\u0512\u0514\u0516\u0518\u051A\u051C\u051E\u0520\u0522\u0524\u0526\u0528\u052A\u052C\u052E\u0531-\u0556\u10A0-\u10C5\u10C7\u10CD\u13A0-\u13F5\u1E00\u1E02\u1E04\u1E06\u1E08\u1E0A\u1E0C\u1E0E\u1E10\u1E12\u1E14\u1E16\u1E18\u1E1A\u1E1C\u1E1E\u1E20\u1E22\u1E24\u1E26\u1E28\u1E2A\u1E2C\u1E2E\u1E30\u1E32\u1E34\u1E36\u1E38\u1E3A\u1E3C\u1E3E\u1E40\u1E42\u1E44\u1E46\u1E48\u1E4A\u1E4C\u1E4E\u1E50\u1E52\u1E54\u1E56\u1E58\u1E5A\u1E5C\u1E5E\u1E60\u1E62\u1E64\u1E66\u1E68\u1E6A\u1E6C\u1E6E\u1E70\u1E72\u1E74\u1E76\u1E78\u1E7A\u1E7C\u1E7E\u1E80\u1E82\u1E84\u1E86\u1E88\u1E8A\u1E8C\u1E8E\u1E90\u1E92\u1E94\u1E9E\u1EA0\u1EA2\u1EA4\u1EA6\u1EA8\u1EAA\u1EAC\u1EAE\u1EB0\u1EB2\u1EB4\u1EB6\u1EB8\u1EBA\u1EBC\u1EBE\u1EC0\u1EC2\u1EC4\u1EC6\u1EC8\u1ECA\u1ECC\u1ECE\u1ED0\u1ED2\u1ED4\u1ED6\u1ED8\u1EDA\u1EDC\u1EDE\u1EE0\u1EE2\u1EE4\u1EE6\u1EE8\u1EEA\u1EEC\u1EEE\u1EF0\u1EF2\u1EF4\u1EF6\u1EF8\u1EFA\u1EFC\u1EFE\u1F08-\u1F0F\u1F18-\u1F1D\u1F28-\u1F2F\u1F38-\u1F3F\u1F48-\u1F4D\u1F59\u1F5B\u1F5D\u1F5F\u1F68-\u1F6F\u1FB8-\u1FBB\u1FC8-\u1FCB\u1FD8-\u1FDB\u1FE8-\u1FEC\u1FF8-\u1FFB\u2102\u2107\u210B-\u210D\u2110-\u2112\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u2130-\u2133\u213E\u213F\u2145\u2183\u2C00-\u2C2E\u2C60\u2C62-\u2C64\u2C67\u2C69\u2C6B\u2C6D-\u2C70\u2C72\u2C75\u2C7E-\u2C80\u2C82\u2C84\u2C86\u2C88\u2C8A\u2C8C\u2C8E\u2C90\u2C92\u2C94\u2C96\u2C98\u2C9A\u2C9C\u2C9E\u2CA0\u2CA2\u2CA4\u2CA6\u2CA8\u2CAA\u2CAC\u2CAE\u2CB0\u2CB2\u2CB4\u2CB6\u2CB8\u2CBA\u2CBC\u2CBE\u2CC0\u2CC2\u2CC4\u2CC6\u2CC8\u2CCA\u2CCC\u2CCE\u2CD0\u2CD2\u2CD4\u2CD6\u2CD8\u2CDA\u2CDC\u2CDE\u2CE0\u2CE2\u2CEB\u2CED\u2CF2\uA640\uA642\uA644\uA646\uA648\uA64A\uA64C\uA64E\uA650\uA652\uA654\uA656\uA658\uA65A\uA65C\uA65E\uA660\uA662\uA664\uA666\uA668\uA66A\uA66C\uA680\uA682\uA684\uA686\uA688\uA68A\uA68C\uA68E\uA690\uA692\uA694\uA696\uA698\uA69A\uA722\uA724\uA726\uA728\uA72A\uA72C\uA72E\uA732\uA734\uA736\uA738\uA73A\uA73C\uA73E\uA740\uA742\uA744\uA746\uA748\uA74A\uA74C\uA74E\uA750\uA752\uA754\uA756\uA758\uA75A\uA75C\uA75E\uA760\uA762\uA764\uA766\uA768\uA76A\uA76C\uA76E\uA779\uA77B\uA77D\uA77E\uA780\uA782\uA784\uA786\uA78B\uA78D\uA790\uA792\uA796\uA798\uA79A\uA79C\uA79E\uA7A0\uA7A2\uA7A4\uA7A6\uA7A8\uA7AA-\uA7AE\uA7B0-\uA7B4\uA7B6\uFF21-\uFF3A]|\uD801[\uDC00-\uDC27\uDCB0-\uDCD3]|\uD803[\uDC80-\uDCB2]|\uD806[\uDCA0-\uDCBF]|\uD835[\uDC00-\uDC19\uDC34-\uDC4D\uDC68-\uDC81\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB5\uDCD0-\uDCE9\uDD04\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD38\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD6C-\uDD85\uDDA0-\uDDB9\uDDD4-\uDDED\uDE08-\uDE21\uDE3C-\uDE55\uDE70-\uDE89\uDEA8-\uDEC0\uDEE2-\uDEFA\uDF1C-\uDF34\uDF56-\uDF6E\uDF90-\uDFA8\uDFCA]|\uD83A[\uDD00-\uDD21]/,
  5719. Ll: /[a-z\xB5\xDF-\xF6\xF8-\xFF\u0101\u0103\u0105\u0107\u0109\u010B\u010D\u010F\u0111\u0113\u0115\u0117\u0119\u011B\u011D\u011F\u0121\u0123\u0125\u0127\u0129\u012B\u012D\u012F\u0131\u0133\u0135\u0137\u0138\u013A\u013C\u013E\u0140\u0142\u0144\u0146\u0148\u0149\u014B\u014D\u014F\u0151\u0153\u0155\u0157\u0159\u015B\u015D\u015F\u0161\u0163\u0165\u0167\u0169\u016B\u016D\u016F\u0171\u0173\u0175\u0177\u017A\u017C\u017E-\u0180\u0183\u0185\u0188\u018C\u018D\u0192\u0195\u0199-\u019B\u019E\u01A1\u01A3\u01A5\u01A8\u01AA\u01AB\u01AD\u01B0\u01B4\u01B6\u01B9\u01BA\u01BD-\u01BF\u01C6\u01C9\u01CC\u01CE\u01D0\u01D2\u01D4\u01D6\u01D8\u01DA\u01DC\u01DD\u01DF\u01E1\u01E3\u01E5\u01E7\u01E9\u01EB\u01ED\u01EF\u01F0\u01F3\u01F5\u01F9\u01FB\u01FD\u01FF\u0201\u0203\u0205\u0207\u0209\u020B\u020D\u020F\u0211\u0213\u0215\u0217\u0219\u021B\u021D\u021F\u0221\u0223\u0225\u0227\u0229\u022B\u022D\u022F\u0231\u0233-\u0239\u023C\u023F\u0240\u0242\u0247\u0249\u024B\u024D\u024F-\u0293\u0295-\u02AF\u0371\u0373\u0377\u037B-\u037D\u0390\u03AC-\u03CE\u03D0\u03D1\u03D5-\u03D7\u03D9\u03DB\u03DD\u03DF\u03E1\u03E3\u03E5\u03E7\u03E9\u03EB\u03ED\u03EF-\u03F3\u03F5\u03F8\u03FB\u03FC\u0430-\u045F\u0461\u0463\u0465\u0467\u0469\u046B\u046D\u046F\u0471\u0473\u0475\u0477\u0479\u047B\u047D\u047F\u0481\u048B\u048D\u048F\u0491\u0493\u0495\u0497\u0499\u049B\u049D\u049F\u04A1\u04A3\u04A5\u04A7\u04A9\u04AB\u04AD\u04AF\u04B1\u04B3\u04B5\u04B7\u04B9\u04BB\u04BD\u04BF\u04C2\u04C4\u04C6\u04C8\u04CA\u04CC\u04CE\u04CF\u04D1\u04D3\u04D5\u04D7\u04D9\u04DB\u04DD\u04DF\u04E1\u04E3\u04E5\u04E7\u04E9\u04EB\u04ED\u04EF\u04F1\u04F3\u04F5\u04F7\u04F9\u04FB\u04FD\u04FF\u0501\u0503\u0505\u0507\u0509\u050B\u050D\u050F\u0511\u0513\u0515\u0517\u0519\u051B\u051D\u051F\u0521\u0523\u0525\u0527\u0529\u052B\u052D\u052F\u0561-\u0587\u13F8-\u13FD\u1C80-\u1C88\u1D00-\u1D2B\u1D6B-\u1D77\u1D79-\u1D9A\u1E01\u1E03\u1E05\u1E07\u1E09\u1E0B\u1E0D\u1E0F\u1E11\u1E13\u1E15\u1E17\u1E19\u1E1B\u1E1D\u1E1F\u1E21\u1E23\u1E25\u1E27\u1E29\u1E2B\u1E2D\u1E2F\u1E31\u1E33\u1E35\u1E37\u1E39\u1E3B\u1E3D\u1E3F\u1E41\u1E43\u1E45\u1E47\u1E49\u1E4B\u1E4D\u1E4F\u1E51\u1E53\u1E55\u1E57\u1E59\u1E5B\u1E5D\u1E5F\u1E61\u1E63\u1E65\u1E67\u1E69\u1E6B\u1E6D\u1E6F\u1E71\u1E73\u1E75\u1E77\u1E79\u1E7B\u1E7D\u1E7F\u1E81\u1E83\u1E85\u1E87\u1E89\u1E8B\u1E8D\u1E8F\u1E91\u1E93\u1E95-\u1E9D\u1E9F\u1EA1\u1EA3\u1EA5\u1EA7\u1EA9\u1EAB\u1EAD\u1EAF\u1EB1\u1EB3\u1EB5\u1EB7\u1EB9\u1EBB\u1EBD\u1EBF\u1EC1\u1EC3\u1EC5\u1EC7\u1EC9\u1ECB\u1ECD\u1ECF\u1ED1\u1ED3\u1ED5\u1ED7\u1ED9\u1EDB\u1EDD\u1EDF\u1EE1\u1EE3\u1EE5\u1EE7\u1EE9\u1EEB\u1EED\u1EEF\u1EF1\u1EF3\u1EF5\u1EF7\u1EF9\u1EFB\u1EFD\u1EFF-\u1F07\u1F10-\u1F15\u1F20-\u1F27\u1F30-\u1F37\u1F40-\u1F45\u1F50-\u1F57\u1F60-\u1F67\u1F70-\u1F7D\u1F80-\u1F87\u1F90-\u1F97\u1FA0-\u1FA7\u1FB0-\u1FB4\u1FB6\u1FB7\u1FBE\u1FC2-\u1FC4\u1FC6\u1FC7\u1FD0-\u1FD3\u1FD6\u1FD7\u1FE0-\u1FE7\u1FF2-\u1FF4\u1FF6\u1FF7\u210A\u210E\u210F\u2113\u212F\u2134\u2139\u213C\u213D\u2146-\u2149\u214E\u2184\u2C30-\u2C5E\u2C61\u2C65\u2C66\u2C68\u2C6A\u2C6C\u2C71\u2C73\u2C74\u2C76-\u2C7B\u2C81\u2C83\u2C85\u2C87\u2C89\u2C8B\u2C8D\u2C8F\u2C91\u2C93\u2C95\u2C97\u2C99\u2C9B\u2C9D\u2C9F\u2CA1\u2CA3\u2CA5\u2CA7\u2CA9\u2CAB\u2CAD\u2CAF\u2CB1\u2CB3\u2CB5\u2CB7\u2CB9\u2CBB\u2CBD\u2CBF\u2CC1\u2CC3\u2CC5\u2CC7\u2CC9\u2CCB\u2CCD\u2CCF\u2CD1\u2CD3\u2CD5\u2CD7\u2CD9\u2CDB\u2CDD\u2CDF\u2CE1\u2CE3\u2CE4\u2CEC\u2CEE\u2CF3\u2D00-\u2D25\u2D27\u2D2D\uA641\uA643\uA645\uA647\uA649\uA64B\uA64D\uA64F\uA651\uA653\uA655\uA657\uA659\uA65B\uA65D\uA65F\uA661\uA663\uA665\uA667\uA669\uA66B\uA66D\uA681\uA683\uA685\uA687\uA689\uA68B\uA68D\uA68F\uA691\uA693\uA695\uA697\uA699\uA69B\uA723\uA725\uA727\uA729\uA72B\uA72D\uA72F-\uA731\uA733\uA735\uA737\uA739\uA73B\uA73D\uA73F\uA741\uA743\uA745\uA747\uA749\uA74B\uA74D\uA74F\uA751\uA753\uA755\uA757\uA759\uA75B\uA75D\uA75F\uA761\uA763\uA765\uA767\uA769\uA76B\uA76D\uA76F\uA771-\uA778\uA77A\uA77C\uA77F\uA781\uA783\uA785\uA787\uA78C\uA78E\uA791\uA793-\uA795\uA797\uA799\uA79B\uA79D\uA79F\uA7A1\uA7A3\uA7A5\uA7A7\uA7A9\uA7B5\uA7B7\uA7FA\uAB30-\uAB5A\uAB60-\uAB65\uAB70-\uABBF\uFB00-\uFB06\uFB13-\uFB17\uFF41-\uFF5A]|\uD801[\uDC28-\uDC4F\uDCD8-\uDCFB]|\uD803[\uDCC0-\uDCF2]|\uD806[\uDCC0-\uDCDF]|\uD835[\uDC1A-\uDC33\uDC4E-\uDC54\uDC56-\uDC67\uDC82-\uDC9B\uDCB6-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDCCF\uDCEA-\uDD03\uDD1E-\uDD37\uDD52-\uDD6B\uDD86-\uDD9F\uDDBA-\uDDD3\uDDEE-\uDE07\uDE22-\uDE3B\uDE56-\uDE6F\uDE8A-\uDEA5\uDEC2-\uDEDA\uDEDC-\uDEE1\uDEFC-\uDF14\uDF16-\uDF1B\uDF36-\uDF4E\uDF50-\uDF55\uDF70-\uDF88\uDF8A-\uDF8F\uDFAA-\uDFC2\uDFC4-\uDFC9\uDFCB]|\uD83A[\uDD22-\uDD43]/,
  5720. Lt: /[\u01C5\u01C8\u01CB\u01F2\u1F88-\u1F8F\u1F98-\u1F9F\u1FA8-\u1FAF\u1FBC\u1FCC\u1FFC]/,
  5721. Lm: /[\u02B0-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0374\u037A\u0559\u0640\u06E5\u06E6\u07F4\u07F5\u07FA\u081A\u0824\u0828\u0971\u0E46\u0EC6\u10FC\u17D7\u1843\u1AA7\u1C78-\u1C7D\u1D2C-\u1D6A\u1D78\u1D9B-\u1DBF\u2071\u207F\u2090-\u209C\u2C7C\u2C7D\u2D6F\u2E2F\u3005\u3031-\u3035\u303B\u309D\u309E\u30FC-\u30FE\uA015\uA4F8-\uA4FD\uA60C\uA67F\uA69C\uA69D\uA717-\uA71F\uA770\uA788\uA7F8\uA7F9\uA9CF\uA9E6\uAA70\uAADD\uAAF3\uAAF4\uAB5C-\uAB5F\uFF70\uFF9E\uFF9F]|\uD81A[\uDF40-\uDF43]|\uD81B[\uDF93-\uDF9F\uDFE0]/,
  5722. Lo: /[\xAA\xBA\u01BB\u01C0-\u01C3\u0294\u05D0-\u05EA\u05F0-\u05F2\u0620-\u063F\u0641-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u0800-\u0815\u0840-\u0858\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0972-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E45\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10D0-\u10FA\u10FD-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17DC\u1820-\u1842\u1844-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C77\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u2135-\u2138\u2D30-\u2D67\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3006\u303C\u3041-\u3096\u309F\u30A1-\u30FA\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA014\uA016-\uA48C\uA4D0-\uA4F7\uA500-\uA60B\uA610-\uA61F\uA62A\uA62B\uA66E\uA6A0-\uA6E5\uA78F\uA7F7\uA7FB-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9E0-\uA9E4\uA9E7-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA6F\uAA71-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB\uAADC\uAAE0-\uAAEA\uAAF2\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF66-\uFF6F\uFF71-\uFF9D\uFFA0-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF40\uDF42-\uDF49\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF]|\uD801[\uDC50-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCFF\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F]|\uD808[\uDC00-\uDF99]|\uD809[\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1]|\uD87E[\uDC00-\uDE1D]/,
  5723. // Numbers
  5724. Nl: /[\u16EE-\u16F0\u2160-\u2182\u2185-\u2188\u3007\u3021-\u3029\u3038-\u303A\uA6E6-\uA6EF]|\uD800[\uDD40-\uDD74\uDF41\uDF4A\uDFD1-\uDFD5]|\uD809[\uDC00-\uDC6E]/,
  5725. Nd: /[0-9\u0660-\u0669\u06F0-\u06F9\u07C0-\u07C9\u0966-\u096F\u09E6-\u09EF\u0A66-\u0A6F\u0AE6-\u0AEF\u0B66-\u0B6F\u0BE6-\u0BEF\u0C66-\u0C6F\u0CE6-\u0CEF\u0D66-\u0D6F\u0DE6-\u0DEF\u0E50-\u0E59\u0ED0-\u0ED9\u0F20-\u0F29\u1040-\u1049\u1090-\u1099\u17E0-\u17E9\u1810-\u1819\u1946-\u194F\u19D0-\u19D9\u1A80-\u1A89\u1A90-\u1A99\u1B50-\u1B59\u1BB0-\u1BB9\u1C40-\u1C49\u1C50-\u1C59\uA620-\uA629\uA8D0-\uA8D9\uA900-\uA909\uA9D0-\uA9D9\uA9F0-\uA9F9\uAA50-\uAA59\uABF0-\uABF9\uFF10-\uFF19]|\uD801[\uDCA0-\uDCA9]|\uD804[\uDC66-\uDC6F\uDCF0-\uDCF9\uDD36-\uDD3F\uDDD0-\uDDD9\uDEF0-\uDEF9]|[\uD805\uD807][\uDC50-\uDC59\uDCD0-\uDCD9\uDE50-\uDE59\uDEC0-\uDEC9\uDF30-\uDF39]|\uD806[\uDCE0-\uDCE9]|\uD81A[\uDE60-\uDE69\uDF50-\uDF59]|\uD835[\uDFCE-\uDFFF]|\uD83A[\uDD50-\uDD59]/,
  5726. // Marks
  5727. Mn: /[\u0300-\u036F\u0483-\u0487\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08D4-\u08E1\u08E3-\u0902\u093A\u093C\u0941-\u0948\u094D\u0951-\u0957\u0962\u0963\u0981\u09BC\u09C1-\u09C4\u09CD\u09E2\u09E3\u0A01\u0A02\u0A3C\u0A41\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81\u0A82\u0ABC\u0AC1-\u0AC5\u0AC7\u0AC8\u0ACD\u0AE2\u0AE3\u0B01\u0B3C\u0B3F\u0B41-\u0B44\u0B4D\u0B56\u0B62\u0B63\u0B82\u0BC0\u0BCD\u0C00\u0C3E-\u0C40\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81\u0CBC\u0CBF\u0CC6\u0CCC\u0CCD\u0CE2\u0CE3\u0D01\u0D41-\u0D44\u0D4D\u0D62\u0D63\u0DCA\u0DD2-\u0DD4\u0DD6\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F71-\u0F7E\u0F80-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102D-\u1030\u1032-\u1037\u1039\u103A\u103D\u103E\u1058\u1059\u105E-\u1060\u1071-\u1074\u1082\u1085\u1086\u108D\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4\u17B5\u17B7-\u17BD\u17C6\u17C9-\u17D3\u17DD\u180B-\u180D\u1885\u1886\u18A9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193B\u1A17\u1A18\u1A1B\u1A56\u1A58-\u1A5E\u1A60\u1A62\u1A65-\u1A6C\u1A73-\u1A7C\u1A7F\u1AB0-\u1ABD\u1B00-\u1B03\u1B34\u1B36-\u1B3A\u1B3C\u1B42\u1B6B-\u1B73\u1B80\u1B81\u1BA2-\u1BA5\u1BA8\u1BA9\u1BAB-\u1BAD\u1BE6\u1BE8\u1BE9\u1BED\u1BEF-\u1BF1\u1C2C-\u1C33\u1C36\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE0\u1CE2-\u1CE8\u1CED\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFB-\u1DFF\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302D\u3099\u309A\uA66F\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA825\uA826\uA8C4\uA8C5\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA951\uA980-\uA982\uA9B3\uA9B6-\uA9B9\uA9BC\uA9E5\uAA29-\uAA2E\uAA31\uAA32\uAA35\uAA36\uAA43\uAA4C\uAA7C\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEC\uAAED\uAAF6\uABE5\uABE8\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD804[\uDC01\uDC38-\uDC46\uDC7F-\uDC81\uDCB3-\uDCB6\uDCB9\uDCBA\uDD00-\uDD02\uDD27-\uDD2B\uDD2D-\uDD34\uDD73\uDD80\uDD81\uDDB6-\uDDBE\uDDCA-\uDDCC\uDE2F-\uDE31\uDE34\uDE36\uDE37\uDE3E\uDEDF\uDEE3-\uDEEA\uDF00\uDF01\uDF3C\uDF40\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC38-\uDC3F\uDC42-\uDC44\uDC46\uDCB3-\uDCB8\uDCBA\uDCBF\uDCC0\uDCC2\uDCC3\uDDB2-\uDDB5\uDDBC\uDDBD\uDDBF\uDDC0\uDDDC\uDDDD\uDE33-\uDE3A\uDE3D\uDE3F\uDE40\uDEAB\uDEAD\uDEB0-\uDEB5\uDEB7\uDF1D-\uDF1F\uDF22-\uDF25\uDF27-\uDF2B]|\uD807[\uDC30-\uDC36\uDC38-\uDC3D\uDC3F\uDC92-\uDCA7\uDCAA-\uDCB0\uDCB2\uDCB3\uDCB5\uDCB6]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF8F-\uDF92]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD67-\uDD69\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDCD0-\uDCD6\uDD44-\uDD4A]|\uDB40[\uDD00-\uDDEF]/,
  5728. Mc: /[\u0903-\u0903]|[\u093E-\u0940]|[\u0949-\u094C]|[\u0982-\u0983]|[\u09BE-\u09C0]|[\u09C7-\u09C8]|[\u09CB-\u09CC]|[\u09D7-\u09D7]|[\u0A3E-\u0A40]|[\u0A83-\u0A83]|[\u0ABE-\u0AC0]|[\u0AC9-\u0AC9]|[\u0ACB-\u0ACC]|[\u0B02-\u0B03]|[\u0B3E-\u0B3E]|[\u0B40-\u0B40]|[\u0B47-\u0B48]|[\u0B4B-\u0B4C]|[\u0B57-\u0B57]|[\u0B83-\u0B83]|[\u0BBE-\u0BBF]|[\u0BC1-\u0BC2]|[\u0BC6-\u0BC8]|[\u0BCA-\u0BCC]|[\u0BD7-\u0BD7]|[\u0C01-\u0C03]|[\u0C41-\u0C44]|[\u0C82-\u0C83]|[\u0CBE-\u0CBE]|[\u0CC0-\u0CC4]|[\u0CC7-\u0CC8]|[\u0CCA-\u0CCB]|[\u0CD5-\u0CD6]|[\u0D02-\u0D03]|[\u0D3E-\u0D40]|[\u0D46-\u0D48]|[\u0D4A-\u0D4C]|[\u0D57-\u0D57]|[\u0F3E-\u0F3F]|[\u0F7F-\u0F7F]/,
  5729. // Punctuation, Connector
  5730. Pc: /[_\u203F\u2040\u2054\uFE33\uFE34\uFE4D-\uFE4F\uFF3F]/,
  5731. // Separator, Space
  5732. Zs: /[ \xA0\u1680\u2000-\u200A\u202F\u205F\u3000]/,
  5733. // These two are not real Unicode categories, but our useful for Ohm.
  5734. // L is a combination of all the letter categories.
  5735. // Ltmo is a combination of Lt, Lm, and Lo.
  5736. L: /[A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF40\uDF42-\uDF49\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F]|\uD808[\uDC00-\uDF99]|\uD809[\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1]|\uD87E[\uDC00-\uDE1D]/,
  5737. Ltmo: /[\u01C5\u01C8\u01CB\u01F2\u1F88-\u1F8F\u1F98-\u1F9F\u1FA8-\u1FAF\u1FBC\u1FCC\u1FFC]|[\u02B0-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0374\u037A\u0559\u0640\u06E5\u06E6\u07F4\u07F5\u07FA\u081A\u0824\u0828\u0971\u0E46\u0EC6\u10FC\u17D7\u1843\u1AA7\u1C78-\u1C7D\u1D2C-\u1D6A\u1D78\u1D9B-\u1DBF\u2071\u207F\u2090-\u209C\u2C7C\u2C7D\u2D6F\u2E2F\u3005\u3031-\u3035\u303B\u309D\u309E\u30FC-\u30FE\uA015\uA4F8-\uA4FD\uA60C\uA67F\uA69C\uA69D\uA717-\uA71F\uA770\uA788\uA7F8\uA7F9\uA9CF\uA9E6\uAA70\uAADD\uAAF3\uAAF4\uAB5C-\uAB5F\uFF70\uFF9E\uFF9F]|\uD81A[\uDF40-\uDF43]|\uD81B[\uDF93-\uDF9F\uDFE0]|[\xAA\xBA\u01BB\u01C0-\u01C3\u0294\u05D0-\u05EA\u05F0-\u05F2\u0620-\u063F\u0641-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u0800-\u0815\u0840-\u0858\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0972-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E45\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10D0-\u10FA\u10FD-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17DC\u1820-\u1842\u1844-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C77\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u2135-\u2138\u2D30-\u2D67\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3006\u303C\u3041-\u3096\u309F\u30A1-\u30FA\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FD5\uA000-\uA014\uA016-\uA48C\uA4D0-\uA4F7\uA500-\uA60B\uA610-\uA61F\uA62A\uA62B\uA66E\uA6A0-\uA6E5\uA78F\uA7F7\uA7FB-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9E0-\uA9E4\uA9E7-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA6F\uAA71-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB\uAADC\uAAE0-\uAAEA\uAAF2\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF66-\uFF6F\uFF71-\uFF9D\uFFA0-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF40\uDF42-\uDF49\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF]|\uD801[\uDC50-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCFF\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F]|\uD808[\uDC00-\uDF99]|\uD809[\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1]|\uD87E[\uDC00-\uDE1D]/
  5738. };
  5739. },{}]},{},[46])(46)
  5740. });
  5741. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","dist/built-in-rules.js","dist/ohm-grammar.js","dist/operations-and-attributes.js","extras/VisitorFamily.js","extras/index.js","extras/semantics-toAST.js","node_modules/d/index.js","node_modules/es5-ext/function/noop.js","node_modules/es5-ext/object/assign/index.js","node_modules/es5-ext/object/assign/is-implemented.js","node_modules/es5-ext/object/assign/shim.js","node_modules/es5-ext/object/is-callable.js","node_modules/es5-ext/object/is-value.js","node_modules/es5-ext/object/keys/index.js","node_modules/es5-ext/object/keys/is-implemented.js","node_modules/es5-ext/object/keys/shim.js","node_modules/es5-ext/object/normalize-options.js","node_modules/es5-ext/object/valid-value.js","node_modules/es5-ext/string/#/contains/index.js","node_modules/es5-ext/string/#/contains/is-implemented.js","node_modules/es5-ext/string/#/contains/shim.js","node_modules/es6-symbol/index.js","node_modules/es6-symbol/is-implemented.js","node_modules/es6-symbol/is-symbol.js","node_modules/es6-symbol/polyfill.js","node_modules/es6-symbol/validate-symbol.js","node_modules/inherits/inherits_browser.js","node_modules/is-buffer/index.js","node_modules/util-extend/extend.js","src/Builder.js","src/CaseInsensitiveTerminal.js","src/Failure.js","src/Grammar.js","src/GrammarDecl.js","src/InputStream.js","src/Interval.js","src/MatchResult.js","src/MatchState.js","src/Matcher.js","src/Namespace.js","src/PosInfo.js","src/Semantics.js","src/Trace.js","src/common.js","src/errors.js","src/main.js","src/nodes.js","src/pexprs-allowsSkippingPrecedingSpace.js","src/pexprs-assertAllApplicationsAreValid.js","src/pexprs-assertChoicesHaveUniformArity.js","src/pexprs-assertIteratedExprsAreNotNullable.js","src/pexprs-check.js","src/pexprs-eval.js","src/pexprs-generateExample.js","src/pexprs-getArity.js","src/pexprs-introduceParams.js","src/pexprs-isNullable.js","src/pexprs-outputRecipe.js","src/pexprs-substituteParams.js","src/pexprs-toArgumentNameList.js","src/pexprs-toDisplayString.js","src/pexprs-toFailure.js","src/pexprs-toString.js","src/pexprs.js","src/util.js","src/version.js","third_party/UnicodeCategories.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtuBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7XA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACpKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var ohm = require('..');\nmodule.exports = ohm.makeRecipe([\"grammar\",{\"source\":\"BuiltInRules {\\n\\n  alnum  (an alpha-numeric character)\\n    = letter\\n    | digit\\n\\n  letter  (a letter)\\n    = lower\\n    | upper\\n    | unicodeLtmo\\n\\n  digit  (a digit)\\n    = \\\"0\\\"..\\\"9\\\"\\n\\n  hexDigit  (a hexadecimal digit)\\n    = digit\\n    | \\\"a\\\"..\\\"f\\\"\\n    | \\\"A\\\"..\\\"F\\\"\\n\\n  ListOf<elem, sep>\\n    = NonemptyListOf<elem, sep>\\n    | EmptyListOf<elem, sep>\\n\\n  NonemptyListOf<elem, sep>\\n    = elem (sep elem)*\\n\\n  EmptyListOf<elem, sep>\\n    = /* nothing */\\n\\n  listOf<elem, sep>\\n    = nonemptyListOf<elem, sep>\\n    | emptyListOf<elem, sep>\\n\\n  nonemptyListOf<elem, sep>\\n    = elem (sep elem)*\\n\\n  emptyListOf<elem, sep>\\n    = /* nothing */\\n\\n}\"},\"BuiltInRules\",null,null,{\"alnum\":[\"define\",{\"sourceInterval\":[18,78]},\"an alpha-numeric character\",[],[\"alt\",{\"sourceInterval\":[60,78]},[\"app\",{\"sourceInterval\":[60,66]},\"letter\",[]],[\"app\",{\"sourceInterval\":[73,78]},\"digit\",[]]]],\"letter\":[\"define\",{\"sourceInterval\":[82,142]},\"a letter\",[],[\"alt\",{\"sourceInterval\":[107,142]},[\"app\",{\"sourceInterval\":[107,112]},\"lower\",[]],[\"app\",{\"sourceInterval\":[119,124]},\"upper\",[]],[\"app\",{\"sourceInterval\":[131,142]},\"unicodeLtmo\",[]]]],\"digit\":[\"define\",{\"sourceInterval\":[146,177]},\"a digit\",[],[\"range\",{\"sourceInterval\":[169,177]},\"0\",\"9\"]],\"hexDigit\":[\"define\",{\"sourceInterval\":[181,254]},\"a hexadecimal digit\",[],[\"alt\",{\"sourceInterval\":[219,254]},[\"app\",{\"sourceInterval\":[219,224]},\"digit\",[]],[\"range\",{\"sourceInterval\":[231,239]},\"a\",\"f\"],[\"range\",{\"sourceInterval\":[246,254]},\"A\",\"F\"]]],\"ListOf\":[\"define\",{\"sourceInterval\":[258,336]},null,[\"elem\",\"sep\"],[\"alt\",{\"sourceInterval\":[282,336]},[\"app\",{\"sourceInterval\":[282,307]},\"NonemptyListOf\",[[\"param\",{},0],[\"param\",{},1]]],[\"app\",{\"sourceInterval\":[314,336]},\"EmptyListOf\",[[\"param\",{},0],[\"param\",{},1]]]]],\"NonemptyListOf\":[\"define\",{\"sourceInterval\":[340,388]},null,[\"elem\",\"sep\"],[\"seq\",{\"sourceInterval\":[372,388]},[\"param\",{},0],[\"star\",{\"sourceInterval\":[377,388]},[\"seq\",{\"sourceInterval\":[378,386]},[\"param\",{},1],[\"param\",{},0]]]]],\"EmptyListOf\":[\"define\",{\"sourceInterval\":[392,434]},null,[\"elem\",\"sep\"],[\"seq\",{\"sourceInterval\":[438,438]}]],\"listOf\":[\"define\",{\"sourceInterval\":[438,516]},null,[\"elem\",\"sep\"],[\"alt\",{\"sourceInterval\":[462,516]},[\"app\",{\"sourceInterval\":[462,487]},\"nonemptyListOf\",[[\"param\",{},0],[\"param\",{},1]]],[\"app\",{\"sourceInterval\":[494,516]},\"emptyListOf\",[[\"param\",{},0],[\"param\",{},1]]]]],\"nonemptyListOf\":[\"define\",{\"sourceInterval\":[520,568]},null,[\"elem\",\"sep\"],[\"seq\",{\"sourceInterval\":[552,568]},[\"param\",{},0],[\"star\",{\"sourceInterval\":[557,568]},[\"seq\",{\"sourceInterval\":[558,566]},[\"param\",{},1],[\"param\",{},0]]]]],\"emptyListOf\":[\"define\",{\"sourceInterval\":[572,614]},null,[\"elem\",\"sep\"],[\"seq\",{\"sourceInterval\":[616,616]}]]}]);\n","var ohm = require('..');\nmodule.exports = ohm.makeRecipe([\"grammar\",{\"source\":\"Ohm {\\n\\n  Grammars\\n    = Grammar*\\n\\n  Grammar\\n    = ident SuperGrammar? \\\"{\\\" Rule* \\\"}\\\"\\n\\n  SuperGrammar\\n    = \\\"<:\\\" ident\\n\\n  Rule\\n    = ident Formals? ruleDescr? \\\"=\\\"  RuleBody  -- define\\n    | ident Formals?            \\\":=\\\" RuleBody  -- override\\n    | ident Formals?            \\\"+=\\\" RuleBody  -- extend\\n\\n  RuleBody\\n    = \\\"|\\\"? NonemptyListOf<TopLevelTerm, \\\"|\\\">\\n\\n  TopLevelTerm\\n    = Seq caseName  -- inline\\n    | Seq\\n\\n  Formals\\n    = \\\"<\\\" ListOf<ident, \\\",\\\"> \\\">\\\"\\n\\n  Params\\n    = \\\"<\\\" ListOf<Seq, \\\",\\\"> \\\">\\\"\\n\\n  Alt\\n    = NonemptyListOf<Seq, \\\"|\\\">\\n\\n  Seq\\n    = Iter*\\n\\n  Iter\\n    = Pred \\\"*\\\"  -- star\\n    | Pred \\\"+\\\"  -- plus\\n    | Pred \\\"?\\\"  -- opt\\n    | Pred\\n\\n  Pred\\n    = \\\"~\\\" Lex  -- not\\n    | \\\"&\\\" Lex  -- lookahead\\n    | Lex\\n\\n  Lex\\n    = \\\"#\\\" Base  -- lex\\n    | Base\\n\\n  Base\\n    = ident Params? ~(ruleDescr? \\\"=\\\" | \\\":=\\\" | \\\"+=\\\")  -- application\\n    | oneCharTerminal \\\"..\\\" oneCharTerminal           -- range\\n    | terminal                                       -- terminal\\n    | \\\"(\\\" Alt \\\")\\\"                                    -- paren\\n\\n  ruleDescr  (a rule description)\\n    = \\\"(\\\" ruleDescrText \\\")\\\"\\n\\n  ruleDescrText\\n    = (~\\\")\\\" any)*\\n\\n  caseName\\n    = \\\"--\\\" (~\\\"\\\\n\\\" space)* name (~\\\"\\\\n\\\" space)* (\\\"\\\\n\\\" | &\\\"}\\\")\\n\\n  name  (a name)\\n    = nameFirst nameRest*\\n\\n  nameFirst\\n    = \\\"_\\\"\\n    | letter\\n\\n  nameRest\\n    = \\\"_\\\"\\n    | alnum\\n\\n  ident  (an identifier)\\n    = name\\n\\n  terminal\\n    = \\\"\\\\\\\"\\\" terminalChar* \\\"\\\\\\\"\\\"\\n\\n  oneCharTerminal\\n    = \\\"\\\\\\\"\\\" terminalChar \\\"\\\\\\\"\\\"\\n\\n  terminalChar\\n    = escapeChar\\n    | ~\\\"\\\\\\\\\\\" ~\\\"\\\\\\\"\\\" ~\\\"\\\\n\\\" any\\n\\n  escapeChar  (an escape sequence)\\n    = \\\"\\\\\\\\\\\\\\\\\\\"                                     -- backslash\\n    | \\\"\\\\\\\\\\\\\\\"\\\"                                     -- doubleQuote\\n    | \\\"\\\\\\\\\\\\'\\\"                                     -- singleQuote\\n    | \\\"\\\\\\\\b\\\"                                      -- backspace\\n    | \\\"\\\\\\\\n\\\"                                      -- lineFeed\\n    | \\\"\\\\\\\\r\\\"                                      -- carriageReturn\\n    | \\\"\\\\\\\\t\\\"                                      -- tab\\n    | \\\"\\\\\\\\u\\\" hexDigit hexDigit hexDigit hexDigit  -- unicodeEscape\\n    | \\\"\\\\\\\\x\\\" hexDigit hexDigit                    -- hexEscape\\n\\n  space\\n   += comment\\n\\n  comment\\n    = \\\"//\\\" (~\\\"\\\\n\\\" any)* \\\"\\\\n\\\"  -- singleLine\\n    | \\\"/*\\\" (~\\\"*/\\\" any)* \\\"*/\\\"  -- multiLine\\n\\n  tokens = token*\\n\\n  token = caseName | comment | ident | operator | punctuation | terminal | any\\n\\n  operator = \\\"<:\\\" | \\\"=\\\" | \\\":=\\\" | \\\"+=\\\" | \\\"*\\\" | \\\"+\\\" | \\\"?\\\" | \\\"~\\\" | \\\"&\\\"\\n\\n  punctuation = \\\"<\\\" | \\\">\\\" | \\\",\\\" | \\\"--\\\"\\n}\"},\"Ohm\",null,\"Grammars\",{\"Grammars\":[\"define\",{\"sourceInterval\":[9,32]},null,[],[\"star\",{\"sourceInterval\":[24,32]},[\"app\",{\"sourceInterval\":[24,31]},\"Grammar\",[]]]],\"Grammar\":[\"define\",{\"sourceInterval\":[36,83]},null,[],[\"seq\",{\"sourceInterval\":[50,83]},[\"app\",{\"sourceInterval\":[50,55]},\"ident\",[]],[\"opt\",{\"sourceInterval\":[56,69]},[\"app\",{\"sourceInterval\":[56,68]},\"SuperGrammar\",[]]],[\"terminal\",{\"sourceInterval\":[70,73]},\"{\"],[\"star\",{\"sourceInterval\":[74,79]},[\"app\",{\"sourceInterval\":[74,78]},\"Rule\",[]]],[\"terminal\",{\"sourceInterval\":[80,83]},\"}\"]]],\"SuperGrammar\":[\"define\",{\"sourceInterval\":[87,116]},null,[],[\"seq\",{\"sourceInterval\":[106,116]},[\"terminal\",{\"sourceInterval\":[106,110]},\"<:\"],[\"app\",{\"sourceInterval\":[111,116]},\"ident\",[]]]],\"Rule_define\":[\"define\",{\"sourceInterval\":[131,181]},null,[],[\"seq\",{\"sourceInterval\":[131,170]},[\"app\",{\"sourceInterval\":[131,136]},\"ident\",[]],[\"opt\",{\"sourceInterval\":[137,145]},[\"app\",{\"sourceInterval\":[137,144]},\"Formals\",[]]],[\"opt\",{\"sourceInterval\":[146,156]},[\"app\",{\"sourceInterval\":[146,155]},\"ruleDescr\",[]]],[\"terminal\",{\"sourceInterval\":[157,160]},\"=\"],[\"app\",{\"sourceInterval\":[162,170]},\"RuleBody\",[]]]],\"Rule_override\":[\"define\",{\"sourceInterval\":[188,240]},null,[],[\"seq\",{\"sourceInterval\":[188,227]},[\"app\",{\"sourceInterval\":[188,193]},\"ident\",[]],[\"opt\",{\"sourceInterval\":[194,202]},[\"app\",{\"sourceInterval\":[194,201]},\"Formals\",[]]],[\"terminal\",{\"sourceInterval\":[214,218]},\":=\"],[\"app\",{\"sourceInterval\":[219,227]},\"RuleBody\",[]]]],\"Rule_extend\":[\"define\",{\"sourceInterval\":[247,297]},null,[],[\"seq\",{\"sourceInterval\":[247,286]},[\"app\",{\"sourceInterval\":[247,252]},\"ident\",[]],[\"opt\",{\"sourceInterval\":[253,261]},[\"app\",{\"sourceInterval\":[253,260]},\"Formals\",[]]],[\"terminal\",{\"sourceInterval\":[273,277]},\"+=\"],[\"app\",{\"sourceInterval\":[278,286]},\"RuleBody\",[]]]],\"Rule\":[\"define\",{\"sourceInterval\":[120,297]},null,[],[\"alt\",{\"sourceInterval\":[131,297]},[\"app\",{\"sourceInterval\":[131,170]},\"Rule_define\",[]],[\"app\",{\"sourceInterval\":[188,227]},\"Rule_override\",[]],[\"app\",{\"sourceInterval\":[247,286]},\"Rule_extend\",[]]]],\"RuleBody\":[\"define\",{\"sourceInterval\":[301,354]},null,[],[\"seq\",{\"sourceInterval\":[316,354]},[\"opt\",{\"sourceInterval\":[316,320]},[\"terminal\",{\"sourceInterval\":[316,319]},\"|\"]],[\"app\",{\"sourceInterval\":[321,354]},\"NonemptyListOf\",[[\"app\",{\"sourceInterval\":[336,348]},\"TopLevelTerm\",[]],[\"terminal\",{\"sourceInterval\":[350,353]},\"|\"]]]]],\"TopLevelTerm_inline\":[\"define\",{\"sourceInterval\":[377,400]},null,[],[\"seq\",{\"sourceInterval\":[377,389]},[\"app\",{\"sourceInterval\":[377,380]},\"Seq\",[]],[\"app\",{\"sourceInterval\":[381,389]},\"caseName\",[]]]],\"TopLevelTerm\":[\"define\",{\"sourceInterval\":[358,410]},null,[],[\"alt\",{\"sourceInterval\":[377,410]},[\"app\",{\"sourceInterval\":[377,389]},\"TopLevelTerm_inline\",[]],[\"app\",{\"sourceInterval\":[407,410]},\"Seq\",[]]]],\"Formals\":[\"define\",{\"sourceInterval\":[414,454]},null,[],[\"seq\",{\"sourceInterval\":[428,454]},[\"terminal\",{\"sourceInterval\":[428,431]},\"<\"],[\"app\",{\"sourceInterval\":[432,450]},\"ListOf\",[[\"app\",{\"sourceInterval\":[439,444]},\"ident\",[]],[\"terminal\",{\"sourceInterval\":[446,449]},\",\"]]],[\"terminal\",{\"sourceInterval\":[451,454]},\">\"]]],\"Params\":[\"define\",{\"sourceInterval\":[458,495]},null,[],[\"seq\",{\"sourceInterval\":[471,495]},[\"terminal\",{\"sourceInterval\":[471,474]},\"<\"],[\"app\",{\"sourceInterval\":[475,491]},\"ListOf\",[[\"app\",{\"sourceInterval\":[482,485]},\"Seq\",[]],[\"terminal\",{\"sourceInterval\":[487,490]},\",\"]]],[\"terminal\",{\"sourceInterval\":[492,495]},\">\"]]],\"Alt\":[\"define\",{\"sourceInterval\":[499,533]},null,[],[\"app\",{\"sourceInterval\":[509,533]},\"NonemptyListOf\",[[\"app\",{\"sourceInterval\":[524,527]},\"Seq\",[]],[\"terminal\",{\"sourceInterval\":[529,532]},\"|\"]]]],\"Seq\":[\"define\",{\"sourceInterval\":[537,552]},null,[],[\"star\",{\"sourceInterval\":[547,552]},[\"app\",{\"sourceInterval\":[547,551]},\"Iter\",[]]]],\"Iter_star\":[\"define\",{\"sourceInterval\":[567,584]},null,[],[\"seq\",{\"sourceInterval\":[567,575]},[\"app\",{\"sourceInterval\":[567,571]},\"Pred\",[]],[\"terminal\",{\"sourceInterval\":[572,575]},\"*\"]]],\"Iter_plus\":[\"define\",{\"sourceInterval\":[591,608]},null,[],[\"seq\",{\"sourceInterval\":[591,599]},[\"app\",{\"sourceInterval\":[591,595]},\"Pred\",[]],[\"terminal\",{\"sourceInterval\":[596,599]},\"+\"]]],\"Iter_opt\":[\"define\",{\"sourceInterval\":[615,631]},null,[],[\"seq\",{\"sourceInterval\":[615,623]},[\"app\",{\"sourceInterval\":[615,619]},\"Pred\",[]],[\"terminal\",{\"sourceInterval\":[620,623]},\"?\"]]],\"Iter\":[\"define\",{\"sourceInterval\":[556,642]},null,[],[\"alt\",{\"sourceInterval\":[567,642]},[\"app\",{\"sourceInterval\":[567,575]},\"Iter_star\",[]],[\"app\",{\"sourceInterval\":[591,599]},\"Iter_plus\",[]],[\"app\",{\"sourceInterval\":[615,623]},\"Iter_opt\",[]],[\"app\",{\"sourceInterval\":[638,642]},\"Pred\",[]]]],\"Pred_not\":[\"define\",{\"sourceInterval\":[657,672]},null,[],[\"seq\",{\"sourceInterval\":[657,664]},[\"terminal\",{\"sourceInterval\":[657,660]},\"~\"],[\"app\",{\"sourceInterval\":[661,664]},\"Lex\",[]]]],\"Pred_lookahead\":[\"define\",{\"sourceInterval\":[679,700]},null,[],[\"seq\",{\"sourceInterval\":[679,686]},[\"terminal\",{\"sourceInterval\":[679,682]},\"&\"],[\"app\",{\"sourceInterval\":[683,686]},\"Lex\",[]]]],\"Pred\":[\"define\",{\"sourceInterval\":[646,710]},null,[],[\"alt\",{\"sourceInterval\":[657,710]},[\"app\",{\"sourceInterval\":[657,664]},\"Pred_not\",[]],[\"app\",{\"sourceInterval\":[679,686]},\"Pred_lookahead\",[]],[\"app\",{\"sourceInterval\":[707,710]},\"Lex\",[]]]],\"Lex_lex\":[\"define\",{\"sourceInterval\":[724,740]},null,[],[\"seq\",{\"sourceInterval\":[724,732]},[\"terminal\",{\"sourceInterval\":[724,727]},\"#\"],[\"app\",{\"sourceInterval\":[728,732]},\"Base\",[]]]],\"Lex\":[\"define\",{\"sourceInterval\":[714,751]},null,[],[\"alt\",{\"sourceInterval\":[724,751]},[\"app\",{\"sourceInterval\":[724,732]},\"Lex_lex\",[]],[\"app\",{\"sourceInterval\":[747,751]},\"Base\",[]]]],\"Base_application\":[\"define\",{\"sourceInterval\":[766,827]},null,[],[\"seq\",{\"sourceInterval\":[766,811]},[\"app\",{\"sourceInterval\":[766,771]},\"ident\",[]],[\"opt\",{\"sourceInterval\":[772,779]},[\"app\",{\"sourceInterval\":[772,778]},\"Params\",[]]],[\"not\",{\"sourceInterval\":[780,811]},[\"alt\",{\"sourceInterval\":[782,810]},[\"seq\",{\"sourceInterval\":[782,796]},[\"opt\",{\"sourceInterval\":[782,792]},[\"app\",{\"sourceInterval\":[782,791]},\"ruleDescr\",[]]],[\"terminal\",{\"sourceInterval\":[793,796]},\"=\"]],[\"terminal\",{\"sourceInterval\":[799,803]},\":=\"],[\"terminal\",{\"sourceInterval\":[806,810]},\"+=\"]]]]],\"Base_range\":[\"define\",{\"sourceInterval\":[834,889]},null,[],[\"seq\",{\"sourceInterval\":[834,870]},[\"app\",{\"sourceInterval\":[834,849]},\"oneCharTerminal\",[]],[\"terminal\",{\"sourceInterval\":[850,854]},\"..\"],[\"app\",{\"sourceInterval\":[855,870]},\"oneCharTerminal\",[]]]],\"Base_terminal\":[\"define\",{\"sourceInterval\":[896,954]},null,[],[\"app\",{\"sourceInterval\":[896,904]},\"terminal\",[]]],\"Base_paren\":[\"define\",{\"sourceInterval\":[961,1016]},null,[],[\"seq\",{\"sourceInterval\":[961,972]},[\"terminal\",{\"sourceInterval\":[961,964]},\"(\"],[\"app\",{\"sourceInterval\":[965,968]},\"Alt\",[]],[\"terminal\",{\"sourceInterval\":[969,972]},\")\"]]],\"Base\":[\"define\",{\"sourceInterval\":[755,1016]},null,[],[\"alt\",{\"sourceInterval\":[766,1016]},[\"app\",{\"sourceInterval\":[766,811]},\"Base_application\",[]],[\"app\",{\"sourceInterval\":[834,870]},\"Base_range\",[]],[\"app\",{\"sourceInterval\":[896,904]},\"Base_terminal\",[]],[\"app\",{\"sourceInterval\":[961,972]},\"Base_paren\",[]]]],\"ruleDescr\":[\"define\",{\"sourceInterval\":[1020,1079]},\"a rule description\",[],[\"seq\",{\"sourceInterval\":[1058,1079]},[\"terminal\",{\"sourceInterval\":[1058,1061]},\"(\"],[\"app\",{\"sourceInterval\":[1062,1075]},\"ruleDescrText\",[]],[\"terminal\",{\"sourceInterval\":[1076,1079]},\")\"]]],\"ruleDescrText\":[\"define\",{\"sourceInterval\":[1083,1114]},null,[],[\"star\",{\"sourceInterval\":[1103,1114]},[\"seq\",{\"sourceInterval\":[1104,1112]},[\"not\",{\"sourceInterval\":[1104,1108]},[\"terminal\",{\"sourceInterval\":[1105,1108]},\")\"]],[\"app\",{\"sourceInterval\":[1109,1112]},\"any\",[]]]]],\"caseName\":[\"define\",{\"sourceInterval\":[1118,1186]},null,[],[\"seq\",{\"sourceInterval\":[1133,1186]},[\"terminal\",{\"sourceInterval\":[1133,1137]},\"--\"],[\"star\",{\"sourceInterval\":[1138,1152]},[\"seq\",{\"sourceInterval\":[1139,1150]},[\"not\",{\"sourceInterval\":[1139,1144]},[\"terminal\",{\"sourceInterval\":[1140,1144]},\"\\n\"]],[\"app\",{\"sourceInterval\":[1145,1150]},\"space\",[]]]],[\"app\",{\"sourceInterval\":[1153,1157]},\"name\",[]],[\"star\",{\"sourceInterval\":[1158,1172]},[\"seq\",{\"sourceInterval\":[1159,1170]},[\"not\",{\"sourceInterval\":[1159,1164]},[\"terminal\",{\"sourceInterval\":[1160,1164]},\"\\n\"]],[\"app\",{\"sourceInterval\":[1165,1170]},\"space\",[]]]],[\"alt\",{\"sourceInterval\":[1174,1185]},[\"terminal\",{\"sourceInterval\":[1174,1178]},\"\\n\"],[\"lookahead\",{\"sourceInterval\":[1181,1185]},[\"terminal\",{\"sourceInterval\":[1182,1185]},\"}\"]]]]],\"name\":[\"define\",{\"sourceInterval\":[1190,1230]},\"a name\",[],[\"seq\",{\"sourceInterval\":[1211,1230]},[\"app\",{\"sourceInterval\":[1211,1220]},\"nameFirst\",[]],[\"star\",{\"sourceInterval\":[1221,1230]},[\"app\",{\"sourceInterval\":[1221,1229]},\"nameRest\",[]]]]],\"nameFirst\":[\"define\",{\"sourceInterval\":[1234,1266]},null,[],[\"alt\",{\"sourceInterval\":[1250,1266]},[\"terminal\",{\"sourceInterval\":[1250,1253]},\"_\"],[\"app\",{\"sourceInterval\":[1260,1266]},\"letter\",[]]]],\"nameRest\":[\"define\",{\"sourceInterval\":[1270,1300]},null,[],[\"alt\",{\"sourceInterval\":[1285,1300]},[\"terminal\",{\"sourceInterval\":[1285,1288]},\"_\"],[\"app\",{\"sourceInterval\":[1295,1300]},\"alnum\",[]]]],\"ident\":[\"define\",{\"sourceInterval\":[1304,1337]},\"an identifier\",[],[\"app\",{\"sourceInterval\":[1333,1337]},\"name\",[]]],\"terminal\":[\"define\",{\"sourceInterval\":[1341,1379]},null,[],[\"seq\",{\"sourceInterval\":[1356,1379]},[\"terminal\",{\"sourceInterval\":[1356,1360]},\"\\\"\"],[\"star\",{\"sourceInterval\":[1361,1374]},[\"app\",{\"sourceInterval\":[1361,1373]},\"terminalChar\",[]]],[\"terminal\",{\"sourceInterval\":[1375,1379]},\"\\\"\"]]],\"oneCharTerminal\":[\"define\",{\"sourceInterval\":[1383,1427]},null,[],[\"seq\",{\"sourceInterval\":[1405,1427]},[\"terminal\",{\"sourceInterval\":[1405,1409]},\"\\\"\"],[\"app\",{\"sourceInterval\":[1410,1422]},\"terminalChar\",[]],[\"terminal\",{\"sourceInterval\":[1423,1427]},\"\\\"\"]]],\"terminalChar\":[\"define\",{\"sourceInterval\":[1431,1488]},null,[],[\"alt\",{\"sourceInterval\":[1450,1488]},[\"app\",{\"sourceInterval\":[1450,1460]},\"escapeChar\",[]],[\"seq\",{\"sourceInterval\":[1467,1488]},[\"not\",{\"sourceInterval\":[1467,1472]},[\"terminal\",{\"sourceInterval\":[1468,1472]},\"\\\\\"]],[\"not\",{\"sourceInterval\":[1473,1478]},[\"terminal\",{\"sourceInterval\":[1474,1478]},\"\\\"\"]],[\"not\",{\"sourceInterval\":[1479,1484]},[\"terminal\",{\"sourceInterval\":[1480,1484]},\"\\n\"]],[\"app\",{\"sourceInterval\":[1485,1488]},\"any\",[]]]]],\"escapeChar_backslash\":[\"define\",{\"sourceInterval\":[1531,1586]},null,[],[\"terminal\",{\"sourceInterval\":[1531,1537]},\"\\\\\\\\\"]],\"escapeChar_doubleQuote\":[\"define\",{\"sourceInterval\":[1593,1650]},null,[],[\"terminal\",{\"sourceInterval\":[1593,1599]},\"\\\\\\\"\"]],\"escapeChar_singleQuote\":[\"define\",{\"sourceInterval\":[1657,1714]},null,[],[\"terminal\",{\"sourceInterval\":[1657,1663]},\"\\\\'\"]],\"escapeChar_backspace\":[\"define\",{\"sourceInterval\":[1721,1776]},null,[],[\"terminal\",{\"sourceInterval\":[1721,1726]},\"\\\\b\"]],\"escapeChar_lineFeed\":[\"define\",{\"sourceInterval\":[1783,1837]},null,[],[\"terminal\",{\"sourceInterval\":[1783,1788]},\"\\\\n\"]],\"escapeChar_carriageReturn\":[\"define\",{\"sourceInterval\":[1844,1904]},null,[],[\"terminal\",{\"sourceInterval\":[1844,1849]},\"\\\\r\"]],\"escapeChar_tab\":[\"define\",{\"sourceInterval\":[1911,1960]},null,[],[\"terminal\",{\"sourceInterval\":[1911,1916]},\"\\\\t\"]],\"escapeChar_unicodeEscape\":[\"define\",{\"sourceInterval\":[1967,2026]},null,[],[\"seq\",{\"sourceInterval\":[1967,2008]},[\"terminal\",{\"sourceInterval\":[1967,1972]},\"\\\\u\"],[\"app\",{\"sourceInterval\":[1973,1981]},\"hexDigit\",[]],[\"app\",{\"sourceInterval\":[1982,1990]},\"hexDigit\",[]],[\"app\",{\"sourceInterval\":[1991,1999]},\"hexDigit\",[]],[\"app\",{\"sourceInterval\":[2000,2008]},\"hexDigit\",[]]]],\"escapeChar_hexEscape\":[\"define\",{\"sourceInterval\":[2033,2088]},null,[],[\"seq\",{\"sourceInterval\":[2033,2056]},[\"terminal\",{\"sourceInterval\":[2033,2038]},\"\\\\x\"],[\"app\",{\"sourceInterval\":[2039,2047]},\"hexDigit\",[]],[\"app\",{\"sourceInterval\":[2048,2056]},\"hexDigit\",[]]]],\"escapeChar\":[\"define\",{\"sourceInterval\":[1492,2088]},\"an escape sequence\",[],[\"alt\",{\"sourceInterval\":[1531,2088]},[\"app\",{\"sourceInterval\":[1531,1537]},\"escapeChar_backslash\",[]],[\"app\",{\"sourceInterval\":[1593,1599]},\"escapeChar_doubleQuote\",[]],[\"app\",{\"sourceInterval\":[1657,1663]},\"escapeChar_singleQuote\",[]],[\"app\",{\"sourceInterval\":[1721,1726]},\"escapeChar_backspace\",[]],[\"app\",{\"sourceInterval\":[1783,1788]},\"escapeChar_lineFeed\",[]],[\"app\",{\"sourceInterval\":[1844,1849]},\"escapeChar_carriageReturn\",[]],[\"app\",{\"sourceInterval\":[1911,1916]},\"escapeChar_tab\",[]],[\"app\",{\"sourceInterval\":[1967,2008]},\"escapeChar_unicodeEscape\",[]],[\"app\",{\"sourceInterval\":[2033,2056]},\"escapeChar_hexEscape\",[]]]],\"space\":[\"extend\",{\"sourceInterval\":[2092,2111]},null,[],[\"app\",{\"sourceInterval\":[2104,2111]},\"comment\",[]]],\"comment_singleLine\":[\"define\",{\"sourceInterval\":[2129,2166]},null,[],[\"seq\",{\"sourceInterval\":[2129,2151]},[\"terminal\",{\"sourceInterval\":[2129,2133]},\"//\"],[\"star\",{\"sourceInterval\":[2134,2146]},[\"seq\",{\"sourceInterval\":[2135,2144]},[\"not\",{\"sourceInterval\":[2135,2140]},[\"terminal\",{\"sourceInterval\":[2136,2140]},\"\\n\"]],[\"app\",{\"sourceInterval\":[2141,2144]},\"any\",[]]]],[\"terminal\",{\"sourceInterval\":[2147,2151]},\"\\n\"]]],\"comment_multiLine\":[\"define\",{\"sourceInterval\":[2173,2209]},null,[],[\"seq\",{\"sourceInterval\":[2173,2195]},[\"terminal\",{\"sourceInterval\":[2173,2177]},\"/*\"],[\"star\",{\"sourceInterval\":[2178,2190]},[\"seq\",{\"sourceInterval\":[2179,2188]},[\"not\",{\"sourceInterval\":[2179,2184]},[\"terminal\",{\"sourceInterval\":[2180,2184]},\"*/\"]],[\"app\",{\"sourceInterval\":[2185,2188]},\"any\",[]]]],[\"terminal\",{\"sourceInterval\":[2191,2195]},\"*/\"]]],\"comment\":[\"define\",{\"sourceInterval\":[2115,2209]},null,[],[\"alt\",{\"sourceInterval\":[2129,2209]},[\"app\",{\"sourceInterval\":[2129,2151]},\"comment_singleLine\",[]],[\"app\",{\"sourceInterval\":[2173,2195]},\"comment_multiLine\",[]]]],\"tokens\":[\"define\",{\"sourceInterval\":[2213,2228]},null,[],[\"star\",{\"sourceInterval\":[2222,2228]},[\"app\",{\"sourceInterval\":[2222,2227]},\"token\",[]]]],\"token\":[\"define\",{\"sourceInterval\":[2232,2308]},null,[],[\"alt\",{\"sourceInterval\":[2240,2308]},[\"app\",{\"sourceInterval\":[2240,2248]},\"caseName\",[]],[\"app\",{\"sourceInterval\":[2251,2258]},\"comment\",[]],[\"app\",{\"sourceInterval\":[2261,2266]},\"ident\",[]],[\"app\",{\"sourceInterval\":[2269,2277]},\"operator\",[]],[\"app\",{\"sourceInterval\":[2280,2291]},\"punctuation\",[]],[\"app\",{\"sourceInterval\":[2294,2302]},\"terminal\",[]],[\"app\",{\"sourceInterval\":[2305,2308]},\"any\",[]]]],\"operator\":[\"define\",{\"sourceInterval\":[2312,2377]},null,[],[\"alt\",{\"sourceInterval\":[2323,2377]},[\"terminal\",{\"sourceInterval\":[2323,2327]},\"<:\"],[\"terminal\",{\"sourceInterval\":[2330,2333]},\"=\"],[\"terminal\",{\"sourceInterval\":[2336,2340]},\":=\"],[\"terminal\",{\"sourceInterval\":[2343,2347]},\"+=\"],[\"terminal\",{\"sourceInterval\":[2350,2353]},\"*\"],[\"terminal\",{\"sourceInterval\":[2356,2359]},\"+\"],[\"terminal\",{\"sourceInterval\":[2362,2365]},\"?\"],[\"terminal\",{\"sourceInterval\":[2368,2371]},\"~\"],[\"terminal\",{\"sourceInterval\":[2374,2377]},\"&\"]]],\"punctuation\":[\"define\",{\"sourceInterval\":[2381,2417]},null,[],[\"alt\",{\"sourceInterval\":[2395,2417]},[\"terminal\",{\"sourceInterval\":[2395,2398]},\"<\"],[\"terminal\",{\"sourceInterval\":[2401,2404]},\">\"],[\"terminal\",{\"sourceInterval\":[2407,2410]},\",\"],[\"terminal\",{\"sourceInterval\":[2413,2417]},\"--\"]]]}]);\n","var ohm = require('..');\nmodule.exports = ohm.makeRecipe([\"grammar\",{\"source\":\"OperationsAndAttributes {\\n\\n  AttributeSignature =\\n    name\\n\\n  OperationSignature =\\n    name Formals?\\n\\n  Formals\\n    = \\\"(\\\" ListOf<name, \\\",\\\"> \\\")\\\"\\n\\n  name  (a name)\\n    = nameFirst nameRest*\\n\\n  nameFirst\\n    = \\\"_\\\"\\n    | letter\\n\\n  nameRest\\n    = \\\"_\\\"\\n    | alnum\\n\\n}\"},\"OperationsAndAttributes\",null,\"AttributeSignature\",{\"AttributeSignature\":[\"define\",{\"sourceInterval\":[29,58]},null,[],[\"app\",{\"sourceInterval\":[54,58]},\"name\",[]]],\"OperationSignature\":[\"define\",{\"sourceInterval\":[62,100]},null,[],[\"seq\",{\"sourceInterval\":[87,100]},[\"app\",{\"sourceInterval\":[87,91]},\"name\",[]],[\"opt\",{\"sourceInterval\":[92,100]},[\"app\",{\"sourceInterval\":[92,99]},\"Formals\",[]]]]],\"Formals\":[\"define\",{\"sourceInterval\":[104,143]},null,[],[\"seq\",{\"sourceInterval\":[118,143]},[\"terminal\",{\"sourceInterval\":[118,121]},\"(\"],[\"app\",{\"sourceInterval\":[122,139]},\"ListOf\",[[\"app\",{\"sourceInterval\":[129,133]},\"name\",[]],[\"terminal\",{\"sourceInterval\":[135,138]},\",\"]]],[\"terminal\",{\"sourceInterval\":[140,143]},\")\"]]],\"name\":[\"define\",{\"sourceInterval\":[147,187]},\"a name\",[],[\"seq\",{\"sourceInterval\":[168,187]},[\"app\",{\"sourceInterval\":[168,177]},\"nameFirst\",[]],[\"star\",{\"sourceInterval\":[178,187]},[\"app\",{\"sourceInterval\":[178,186]},\"nameRest\",[]]]]],\"nameFirst\":[\"define\",{\"sourceInterval\":[191,223]},null,[],[\"alt\",{\"sourceInterval\":[207,223]},[\"terminal\",{\"sourceInterval\":[207,210]},\"_\"],[\"app\",{\"sourceInterval\":[217,223]},\"letter\",[]]]],\"nameRest\":[\"define\",{\"sourceInterval\":[227,257]},null,[],[\"alt\",{\"sourceInterval\":[242,257]},[\"terminal\",{\"sourceInterval\":[242,245]},\"_\"],[\"app\",{\"sourceInterval\":[252,257]},\"alnum\",[]]]]}]);\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar assert = require('../src/common').assert;\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Helpers\n\nfunction getProp(name, thing, fn) {\n  return fn(thing[name]);\n}\n\nfunction mapProp(name, thing, fn) {\n  return thing[name].map(fn);\n}\n\n// Returns a function that will walk a single property of a node.\n// `descriptor` is a string indicating the property name, optionally ending\n// with '[]' (e.g., 'children[]').\nfunction getPropWalkFn(descriptor) {\n  var parts = descriptor.split(/ ?\\[\\]/);\n  if (parts.length === 2) {\n    return mapProp.bind(null, parts[0]);\n  }\n  return getProp.bind(null, descriptor);\n}\n\nfunction getProps(walkFns, thing, fn) {\n  return walkFns.map(function(walkFn) {\n    return walkFn(thing, fn);\n  });\n}\n\nfunction getWalkFn(shape) {\n  if (typeof shape === 'string') {\n    return getProps.bind(null, [getPropWalkFn(shape)]);\n  } else if (Array.isArray(shape)) {\n    return getProps.bind(null, shape.map(getPropWalkFn));\n  } else {\n    assert(typeof shape === 'function', 'Expected a string, Array, or function');\n    assert(shape.length === 2, 'Expected a function of arity 2, got ' + shape.length);\n    return shape;\n  }\n}\n\nfunction isRestrictedIdentifier(str) {\n  return /^[a-zA-Z_][0-9a-zA-Z_]*$/.test(str);\n}\n\nfunction trim(s) {\n  return s.trim();\n}\n\nfunction parseSignature(sig) {\n  var parts = sig.split(/[()]/).map(trim);\n  if (parts.length === 3 && parts[2] === '') {\n    var name = parts[0];\n    var params = [];\n    if (parts[1].length > 0) {\n      params = parts[1].split(',').map(trim);\n    }\n    if (isRestrictedIdentifier(name) && params.every(isRestrictedIdentifier)) {\n      return {name: name, formals: params};\n    }\n  }\n  throw new Error('Invalid operation signature: ' + sig);\n}\n\n/*\n  A VisitorFamily contains a set of recursive operations that are defined over some kind of\n  tree structure. The `config` parameter specifies how to walk the tree:\n  - 'getTag' is function which, given a node in the tree, returns the node's 'tag' (type)\n  - 'shapes' an object that maps from a tag to a value that describes how to recursively\n    evaluate the operation for nodes of that type. The value can be:\n    * a string indicating the property name that holds that node's only child\n    * an Array of property names (or an empty array indicating a leaf type), or\n    * a function taking two arguments (node, fn), and returning an Array which is the result\n      of apply `fn` to each of the node's children.\n */\nfunction VisitorFamily(config) {\n  this._shapes = config.shapes;\n  this._getTag = config.getTag;\n\n  this.Adapter = function(thing, family) {\n    this._adaptee = thing;\n    this._family = family;\n  };\n  this.Adapter.prototype.valueOf = function() {\n    throw new Error('heeey!');\n  };\n  this.operations = {};\n\n  this._arities = Object.create(null);\n  this._getChildren = Object.create(null);\n\n  var self = this;\n  Object.keys(this._shapes).forEach(function(k) {\n    var shape = self._shapes[k];\n    self._getChildren[k] = getWalkFn(shape);\n\n    // A function means the arity isn't fixed, so don't put an entry in the arity map.\n    if (typeof shape !== 'function') {\n      self._arities[k] = Array.isArray(shape) ? shape.length : 1;\n    }\n  });\n  this._wrap = function(thing) { return new self.Adapter(thing, self); };\n}\n\nVisitorFamily.prototype.wrap = function(thing) {\n  return this._wrap(thing);\n};\n\nVisitorFamily.prototype._checkActionDict = function(dict) {\n  var self = this;\n  Object.keys(dict).forEach(function(k) {\n    assert(k in self._getChildren, \"Unrecognized action name '\" + k + \"'\");\n    var action = dict[k];\n    assert(typeof action === 'function', \"Key '\" + k + \"': expected function, got \" + action);\n    if (k in self._arities) {\n      var expected = self._arities[k];\n      var actual = dict[k].length;\n      assert(actual === expected,\n             \"Action '\" + k + \"' has the wrong arity: expected \" + expected + ', got ' + actual);\n    }\n  });\n};\n\nVisitorFamily.prototype.addOperation = function(signature, actions) {\n  var sig = parseSignature(signature);\n  var name = sig.name;\n  this._checkActionDict(actions);\n  this.operations[name] = {\n    name: name,\n    formals: sig.formals,\n    actions: actions\n  };\n\n  var family = this;\n  this.Adapter.prototype[name] = function() {\n    var tag = family._getTag(this._adaptee);\n    assert(tag in family._getChildren, \"getTag returned unrecognized tag '\" + tag + \"'\");\n    assert(tag in actions, \"No action for '\" + tag + \"' in operation '\" + name + \"'\");\n\n    // Create an \"arguments object\" from the arguments that were passed to this\n    // operation / attribute.\n    var args = Object.create(null);\n    for (var i = 0; i < arguments.length; i++) {\n      args[sig.formals[i]] = arguments[i];\n    }\n\n    var oldArgs = this.args;\n    this.args = args;\n    var ans = actions[tag].apply(this, family._getChildren[tag](this._adaptee, family._wrap));\n    this.args = oldArgs;\n    return ans;\n  };\n  return this;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = VisitorFamily;\n","'use strict';\n\nmodule.exports = {\n  VisitorFamily: require('./VisitorFamily'),\n  semanticsForToAST: require('./semantics-toAST').semantics,\n  toAST: require('./semantics-toAST').helper\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('../src/pexprs');\nvar MatchResult = require('../src/MatchResult');\nvar Grammar = require('../src/Grammar');\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\nvar defaultOperation = {\n  _terminal: function() {\n    return this.primitiveValue;\n  },\n\n  _nonterminal: function(children) {\n    var ctorName = this._node.ctorName;\n    var mapping = this.args.mapping;\n\n    // without customization\n    if (!mapping.hasOwnProperty(ctorName)) {\n      // intermediate node\n      if (this._node instanceof pexprs.Alt || this._node instanceof pexprs.Apply) {\n        return children[0].toAST(mapping);\n      }\n\n      // lexical rule\n      if (this.isLexical()) {\n        return this.sourceString;\n      }\n\n      // singular node (e.g. only surrounded by literals or lookaheads)\n      var realChildren = children.filter(function(child) {\n        return !child.isTerminal();\n      });\n      if (realChildren.length === 1) {\n        return realChildren[0].toAST(mapping);\n      }\n\n      // rest: terms with multiple children\n    }\n\n    // direct forward\n    if (typeof mapping[ctorName] === 'number') {\n      return children[mapping[ctorName]].toAST(mapping);\n    }\n\n    // named/mapped children or unnamed children ('0', '1', '2', ...)\n    var propMap = mapping[ctorName] || children;\n    var node = {\n      type: ctorName\n    };\n    for (var prop in propMap) {\n      var mappedProp = mapping[ctorName] && mapping[ctorName][prop];\n      if (typeof mappedProp === 'number') {\n        // direct forward\n        node[prop] = children[mappedProp].toAST(mapping);\n      } else if ((typeof mappedProp === 'string') || (typeof mappedProp === 'boolean') ||\n          (mappedProp === null)) {\n        // primitive value\n        node[prop] = mappedProp;\n      } else if ((typeof mappedProp === 'object') && (mappedProp instanceof Number)) {\n        // primitive number (must be unboxed)\n        node[prop] = Number(mappedProp);\n      } else if (typeof mappedProp === 'function') {\n        // computed value\n        node[prop] = mappedProp.call(this, children);\n      } else if (mappedProp === undefined) {\n        if (children[prop] && !children[prop].isTerminal()) {\n          node[prop] = children[prop].toAST(mapping);\n        } else {\n          // delete predefined 'type' properties, like 'type', if explicitely removed\n          delete node[prop];\n        }\n      }\n    }\n    return node;\n  },\n\n  _iter: function(children) {\n    if (this._node.isOptional()) {\n      if (this.numChildren === 0) {\n        return null;\n      } else {\n        return children[0].toAST(this.args.mapping);\n      }\n    }\n\n    return children.map(function(child) {\n      return child.toAST(this.args.mapping);\n    }, this);\n  },\n\n  NonemptyListOf: function(first, sep, rest) {\n    return [first.toAST(this.args.mapping)].concat(rest.toAST(this.args.mapping));\n  },\n\n  EmptyListOf: function() {\n    return [];\n  }\n};\n\n// Returns a plain JavaScript object that includes an abstract syntax tree (AST)\n// for the given match result `res` containg a concrete syntax tree (CST) and grammar.\n// The optional `mapping` parameter can be used to customize how the nodes of the CST\n// are mapped to the AST (see /doc/extras.md#toastmatchresult-mapping).\nfunction toAST(res, mapping) {\n  if (!(res instanceof MatchResult) || res.failed()) {\n    throw new Error('toAST() expects a succesfull MatchResult as first parameter');\n  }\n\n  mapping = extend({}, mapping);\n  var operation = extend({}, defaultOperation);\n  for (var termName in mapping) {\n    if (typeof mapping[termName] === 'function') {\n      operation[termName] = mapping[termName];\n      delete mapping[termName];\n    }\n  }\n  var g = res._cst.grammar;\n  var s = g.createSemantics().addOperation('toAST(mapping)', operation);\n  return s(res).toAST(mapping);\n}\n\n// Returns a semantics containg the toAST(mapping) operation for the given grammar g.\nfunction semanticsForToAST(g) {\n  if (!(g instanceof Grammar)) {\n    throw new Error('semanticsToAST() expects a Grammar as parameter');\n  }\n\n  return g.createSemantics().addOperation('toAST(mapping)', defaultOperation);\n}\n\nmodule.exports = {\n  helper: toAST,\n  semantics: semanticsForToAST\n};\n","'use strict';\n\nvar assign        = require('es5-ext/object/assign')\n  , normalizeOpts = require('es5-ext/object/normalize-options')\n  , isCallable    = require('es5-ext/object/is-callable')\n  , contains      = require('es5-ext/string/#/contains')\n\n  , d;\n\nd = module.exports = function (dscr, value/*, options*/) {\n\tvar c, e, w, options, desc;\n\tif ((arguments.length < 2) || (typeof dscr !== 'string')) {\n\t\toptions = value;\n\t\tvalue = dscr;\n\t\tdscr = null;\n\t} else {\n\t\toptions = arguments[2];\n\t}\n\tif (dscr == null) {\n\t\tc = w = true;\n\t\te = false;\n\t} else {\n\t\tc = contains.call(dscr, 'c');\n\t\te = contains.call(dscr, 'e');\n\t\tw = contains.call(dscr, 'w');\n\t}\n\n\tdesc = { value: value, configurable: c, enumerable: e, writable: w };\n\treturn !options ? desc : assign(normalizeOpts(options), desc);\n};\n\nd.gs = function (dscr, get, set/*, options*/) {\n\tvar c, e, options, desc;\n\tif (typeof dscr !== 'string') {\n\t\toptions = set;\n\t\tset = get;\n\t\tget = dscr;\n\t\tdscr = null;\n\t} else {\n\t\toptions = arguments[3];\n\t}\n\tif (get == null) {\n\t\tget = undefined;\n\t} else if (!isCallable(get)) {\n\t\toptions = get;\n\t\tget = set = undefined;\n\t} else if (set == null) {\n\t\tset = undefined;\n\t} else if (!isCallable(set)) {\n\t\toptions = set;\n\t\tset = undefined;\n\t}\n\tif (dscr == null) {\n\t\tc = true;\n\t\te = false;\n\t} else {\n\t\tc = contains.call(dscr, 'c');\n\t\te = contains.call(dscr, 'e');\n\t}\n\n\tdesc = { get: get, set: set, configurable: c, enumerable: e };\n\treturn !options ? desc : assign(normalizeOpts(options), desc);\n};\n","\"use strict\";\n\n// eslint-disable-next-line no-empty-function\nmodule.exports = function () {};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")()\n\t? Object.assign\n\t: require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\tvar assign = Object.assign, obj;\n\tif (typeof assign !== \"function\") return false;\n\tobj = { foo: \"raz\" };\n\tassign(obj, { bar: \"dwa\" }, { trzy: \"trzy\" });\n\treturn (obj.foo + obj.bar + obj.trzy) === \"razdwatrzy\";\n};\n","\"use strict\";\n\nvar keys  = require(\"../keys\")\n  , value = require(\"../valid-value\")\n  , max   = Math.max;\n\nmodule.exports = function (dest, src /*, …srcn*/) {\n\tvar error, i, length = max(arguments.length, 2), assign;\n\tdest = Object(value(dest));\n\tassign = function (key) {\n\t\ttry {\n\t\t\tdest[key] = src[key];\n\t\t} catch (e) {\n\t\t\tif (!error) error = e;\n\t\t}\n\t};\n\tfor (i = 1; i < length; ++i) {\n\t\tsrc = arguments[i];\n\t\tkeys(src).forEach(assign);\n\t}\n\tif (error !== undefined) throw error;\n\treturn dest;\n};\n","// Deprecated\n\n\"use strict\";\n\nmodule.exports = function (obj) {\n return typeof obj === \"function\";\n};\n","\"use strict\";\n\nvar _undefined = require(\"../function/noop\")(); // Support ES3 engines\n\nmodule.exports = function (val) {\n return (val !== _undefined) && (val !== null);\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")()\n\t? Object.keys\n\t: require(\"./shim\");\n","\"use strict\";\n\nmodule.exports = function () {\n\ttry {\n\t\tObject.keys(\"primitive\");\n\t\treturn true;\n\t} catch (e) {\n return false;\n}\n};\n","\"use strict\";\n\nvar isValue = require(\"../is-value\");\n\nvar keys = Object.keys;\n\nmodule.exports = function (object) {\n\treturn keys(isValue(object) ? Object(object) : object);\n};\n","\"use strict\";\n\nvar isValue = require(\"./is-value\");\n\nvar forEach = Array.prototype.forEach, create = Object.create;\n\nvar process = function (src, obj) {\n\tvar key;\n\tfor (key in src) obj[key] = src[key];\n};\n\n// eslint-disable-next-line no-unused-vars\nmodule.exports = function (opts1 /*, …options*/) {\n\tvar result = create(null);\n\tforEach.call(arguments, function (options) {\n\t\tif (!isValue(options)) return;\n\t\tprocess(Object(options), result);\n\t});\n\treturn result;\n};\n","\"use strict\";\n\nvar isValue = require(\"./is-value\");\n\nmodule.exports = function (value) {\n\tif (!isValue(value)) throw new TypeError(\"Cannot use null or undefined\");\n\treturn value;\n};\n","\"use strict\";\n\nmodule.exports = require(\"./is-implemented\")()\n\t? String.prototype.contains\n\t: require(\"./shim\");\n","\"use strict\";\n\nvar str = \"razdwatrzy\";\n\nmodule.exports = function () {\n\tif (typeof str.contains !== \"function\") return false;\n\treturn (str.contains(\"dwa\") === true) && (str.contains(\"foo\") === false);\n};\n","\"use strict\";\n\nvar indexOf = String.prototype.indexOf;\n\nmodule.exports = function (searchString/*, position*/) {\n\treturn indexOf.call(this, searchString, arguments[1]) > -1;\n};\n","'use strict';\n\nmodule.exports = require('./is-implemented')() ? Symbol : require('./polyfill');\n","'use strict';\n\nvar validTypes = { object: true, symbol: true };\n\nmodule.exports = function () {\n\tvar symbol;\n\tif (typeof Symbol !== 'function') return false;\n\tsymbol = Symbol('test symbol');\n\ttry { String(symbol); } catch (e) { return false; }\n\n\t// Return 'true' also for polyfills\n\tif (!validTypes[typeof Symbol.iterator]) return false;\n\tif (!validTypes[typeof Symbol.toPrimitive]) return false;\n\tif (!validTypes[typeof Symbol.toStringTag]) return false;\n\n\treturn true;\n};\n","'use strict';\n\nmodule.exports = function (x) {\n\tif (!x) return false;\n\tif (typeof x === 'symbol') return true;\n\tif (!x.constructor) return false;\n\tif (x.constructor.name !== 'Symbol') return false;\n\treturn (x[x.constructor.toStringTag] === 'Symbol');\n};\n","// ES2015 Symbol polyfill for environments that do not (or partially) support it\n\n'use strict';\n\nvar d              = require('d')\n  , validateSymbol = require('./validate-symbol')\n\n  , create = Object.create, defineProperties = Object.defineProperties\n  , defineProperty = Object.defineProperty, objPrototype = Object.prototype\n  , NativeSymbol, SymbolPolyfill, HiddenSymbol, globalSymbols = create(null)\n  , isNativeSafe;\n\nif (typeof Symbol === 'function') {\n\tNativeSymbol = Symbol;\n\ttry {\n\t\tString(NativeSymbol());\n\t\tisNativeSafe = true;\n\t} catch (ignore) {}\n}\n\nvar generateName = (function () {\n\tvar created = create(null);\n\treturn function (desc) {\n\t\tvar postfix = 0, name, ie11BugWorkaround;\n\t\twhile (created[desc + (postfix || '')]) ++postfix;\n\t\tdesc += (postfix || '');\n\t\tcreated[desc] = true;\n\t\tname = '@@' + desc;\n\t\tdefineProperty(objPrototype, name, d.gs(null, function (value) {\n\t\t\t// For IE11 issue see:\n\t\t\t// https://connect.microsoft.com/IE/feedbackdetail/view/1928508/\n\t\t\t//    ie11-broken-getters-on-dom-objects\n\t\t\t// https://github.com/medikoo/es6-symbol/issues/12\n\t\t\tif (ie11BugWorkaround) return;\n\t\t\tie11BugWorkaround = true;\n\t\t\tdefineProperty(this, name, d(value));\n\t\t\tie11BugWorkaround = false;\n\t\t}));\n\t\treturn name;\n\t};\n}());\n\n// Internal constructor (not one exposed) for creating Symbol instances.\n// This one is used to ensure that `someSymbol instanceof Symbol` always return false\nHiddenSymbol = function Symbol(description) {\n\tif (this instanceof HiddenSymbol) throw new TypeError('Symbol is not a constructor');\n\treturn SymbolPolyfill(description);\n};\n\n// Exposed `Symbol` constructor\n// (returns instances of HiddenSymbol)\nmodule.exports = SymbolPolyfill = function Symbol(description) {\n\tvar symbol;\n\tif (this instanceof Symbol) throw new TypeError('Symbol is not a constructor');\n\tif (isNativeSafe) return NativeSymbol(description);\n\tsymbol = create(HiddenSymbol.prototype);\n\tdescription = (description === undefined ? '' : String(description));\n\treturn defineProperties(symbol, {\n\t\t__description__: d('', description),\n\t\t__name__: d('', generateName(description))\n\t});\n};\ndefineProperties(SymbolPolyfill, {\n\tfor: d(function (key) {\n\t\tif (globalSymbols[key]) return globalSymbols[key];\n\t\treturn (globalSymbols[key] = SymbolPolyfill(String(key)));\n\t}),\n\tkeyFor: d(function (s) {\n\t\tvar key;\n\t\tvalidateSymbol(s);\n\t\tfor (key in globalSymbols) if (globalSymbols[key] === s) return key;\n\t}),\n\n\t// To ensure proper interoperability with other native functions (e.g. Array.from)\n\t// fallback to eventual native implementation of given symbol\n\thasInstance: d('', (NativeSymbol && NativeSymbol.hasInstance) || SymbolPolyfill('hasInstance')),\n\tisConcatSpreadable: d('', (NativeSymbol && NativeSymbol.isConcatSpreadable) ||\n\t\tSymbolPolyfill('isConcatSpreadable')),\n\titerator: d('', (NativeSymbol && NativeSymbol.iterator) || SymbolPolyfill('iterator')),\n\tmatch: d('', (NativeSymbol && NativeSymbol.match) || SymbolPolyfill('match')),\n\treplace: d('', (NativeSymbol && NativeSymbol.replace) || SymbolPolyfill('replace')),\n\tsearch: d('', (NativeSymbol && NativeSymbol.search) || SymbolPolyfill('search')),\n\tspecies: d('', (NativeSymbol && NativeSymbol.species) || SymbolPolyfill('species')),\n\tsplit: d('', (NativeSymbol && NativeSymbol.split) || SymbolPolyfill('split')),\n\ttoPrimitive: d('', (NativeSymbol && NativeSymbol.toPrimitive) || SymbolPolyfill('toPrimitive')),\n\ttoStringTag: d('', (NativeSymbol && NativeSymbol.toStringTag) || SymbolPolyfill('toStringTag')),\n\tunscopables: d('', (NativeSymbol && NativeSymbol.unscopables) || SymbolPolyfill('unscopables'))\n});\n\n// Internal tweaks for real symbol producer\ndefineProperties(HiddenSymbol.prototype, {\n\tconstructor: d(SymbolPolyfill),\n\ttoString: d('', function () { return this.__name__; })\n});\n\n// Proper implementation of methods exposed on Symbol.prototype\n// They won't be accessible on produced symbol instances as they derive from HiddenSymbol.prototype\ndefineProperties(SymbolPolyfill.prototype, {\n\ttoString: d(function () { return 'Symbol (' + validateSymbol(this).__description__ + ')'; }),\n\tvalueOf: d(function () { return validateSymbol(this); })\n});\ndefineProperty(SymbolPolyfill.prototype, SymbolPolyfill.toPrimitive, d('', function () {\n\tvar symbol = validateSymbol(this);\n\tif (typeof symbol === 'symbol') return symbol;\n\treturn symbol.toString();\n}));\ndefineProperty(SymbolPolyfill.prototype, SymbolPolyfill.toStringTag, d('c', 'Symbol'));\n\n// Proper implementaton of toPrimitive and toStringTag for returned symbol instances\ndefineProperty(HiddenSymbol.prototype, SymbolPolyfill.toStringTag,\n\td('c', SymbolPolyfill.prototype[SymbolPolyfill.toStringTag]));\n\n// Note: It's important to define `toPrimitive` as last one, as some implementations\n// implement `toPrimitive` natively without implementing `toStringTag` (or other specified symbols)\n// And that may invoke error in definition flow:\n// See: https://github.com/medikoo/es6-symbol/issues/13#issuecomment-164146149\ndefineProperty(HiddenSymbol.prototype, SymbolPolyfill.toPrimitive,\n\td('c', SymbolPolyfill.prototype[SymbolPolyfill.toPrimitive]));\n","'use strict';\n\nvar isSymbol = require('./is-symbol');\n\nmodule.exports = function (value) {\n\tif (!isSymbol(value)) throw new TypeError(value + \" is not a symbol\");\n\treturn value;\n};\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","/*!\n * Determine if an object is a Buffer\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nmodule.exports = function (obj) {\n  return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)\n}\n\nfunction isBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = extend;\nfunction extend(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || typeof add !== 'object') return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n}\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar GrammarDecl = require('./GrammarDecl');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Builder() {}\n\nBuilder.prototype = {\n  currentDecl: null,\n\n  newGrammar: function(name) {\n    return new GrammarDecl(name);\n  },\n\n  grammar: function(metaInfo, name, superGrammar, defaultStartRule, rules) {\n    var gDecl = new GrammarDecl(name);\n    if (superGrammar) {\n      gDecl.withSuperGrammar(this.fromRecipe(superGrammar));\n    }\n    if (defaultStartRule) {\n      gDecl.withDefaultStartRule(defaultStartRule);\n    }\n    if (metaInfo && metaInfo.source) {\n      gDecl.withSource(metaInfo.source);\n    }\n\n    var self = this;\n    this.currentDecl = gDecl;\n    Object.keys(rules).forEach(function(ruleName) {\n      var ruleRecipe = rules[ruleName];\n\n      var action = ruleRecipe[0]; // define/extend/override\n      var metaInfo = ruleRecipe[1];\n      var description = ruleRecipe[2];\n      var formals = ruleRecipe[3];\n      var body = self.fromRecipe(ruleRecipe[4]);\n\n      var source;\n      if (gDecl.source && metaInfo && metaInfo.sourceInterval) {\n        source = gDecl.source.subInterval(\n            metaInfo.sourceInterval[0],\n            metaInfo.sourceInterval[1] - metaInfo.sourceInterval[0]);\n      }\n      gDecl[action](ruleName, formals, body, description, source);\n    });\n    this.currentDecl = null;\n    return gDecl.build();\n  },\n\n  terminal: function(x) {\n    return new pexprs.Terminal(x);\n  },\n\n  range: function(from, to) {\n    return new pexprs.Range(from, to);\n  },\n\n  param: function(index) {\n    return new pexprs.Param(index);\n  },\n\n  alt: function(/* term1, term1, ... */) {\n    var terms = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (!(arg instanceof pexprs.PExpr)) {\n        arg = this.fromRecipe(arg);\n      }\n      if (arg instanceof pexprs.Alt) {\n        terms = terms.concat(arg.terms);\n      } else {\n        terms.push(arg);\n      }\n    }\n    return terms.length === 1 ? terms[0] : new pexprs.Alt(terms);\n  },\n\n  seq: function(/* factor1, factor2, ... */) {\n    var factors = [];\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var arg = arguments[idx];\n      if (!(arg instanceof pexprs.PExpr)) {\n        arg = this.fromRecipe(arg);\n      }\n      if (arg instanceof pexprs.Seq) {\n        factors = factors.concat(arg.factors);\n      } else {\n        factors.push(arg);\n      }\n    }\n    return factors.length === 1 ? factors[0] : new pexprs.Seq(factors);\n  },\n\n  star: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Star(expr);\n  },\n\n  plus: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Plus(expr);\n  },\n\n  opt: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Opt(expr);\n  },\n\n  not: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Not(expr);\n  },\n\n  la: function(expr) {\n    // TODO: temporary to still be able to read old recipes\n    return this.lookahead(expr);\n  },\n\n  lookahead: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Lookahead(expr);\n  },\n\n  lex: function(expr) {\n    if (!(expr instanceof pexprs.PExpr)) {\n      expr = this.fromRecipe(expr);\n    }\n    return new pexprs.Lex(expr);\n  },\n\n  app: function(ruleName, optParams) {\n    if (optParams && optParams.length > 0) {\n      optParams = optParams.map(function(param) {\n        return param instanceof pexprs.PExpr ? param :\n          this.fromRecipe(param);\n      }, this);\n    }\n    return new pexprs.Apply(ruleName, optParams);\n  },\n\n  fromRecipe: function(recipe) {\n    // the meta-info of 'grammar' is proccessed in Builder.grammar\n    var result = this[recipe[0]].apply(this,\n      recipe[0] === 'grammar' ? recipe.slice(1) : recipe.slice(2));\n\n    var metaInfo = recipe[1];\n    if (metaInfo) {\n      if (metaInfo.sourceInterval && this.currentDecl) {\n        result.withSource(\n          this.currentDecl.sourceInterval.apply(this.currentDecl, metaInfo.sourceInterval)\n        );\n      }\n    }\n    return result;\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Builder;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Failure = require('./Failure');\nvar TerminalNode = require('./nodes').TerminalNode;\nvar assert = require('./common').assert;\nvar inherits = require('inherits');\nvar pexprs = require('./pexprs');\n\nfunction CaseInsensitiveTerminal(param) {\n  this.obj = param;\n}\ninherits(CaseInsensitiveTerminal, pexprs.PExpr);\n\nCaseInsensitiveTerminal.prototype = {\n  _getString: function(state) {\n    var terminal = state.currentApplication().args[this.obj.index];\n    assert(terminal instanceof pexprs.Terminal, 'expected a Terminal expression');\n    return terminal.obj;\n  },\n\n  // Implementation of the PExpr API\n\n  allowsSkippingPrecedingSpace: function() {\n    return true;\n  },\n\n  eval: function(state) {\n    var inputStream = state.inputStream;\n    var origPos = inputStream.pos;\n    var matchStr = this._getString(state);\n    if (!inputStream.matchString(matchStr, true)) {\n      state.processFailure(origPos, this);\n      return false;\n    } else {\n      state.pushBinding(new TerminalNode(state.grammar, matchStr), origPos);\n      return true;\n    }\n  },\n\n  generateExample: function(grammar, examples, inSyntacticContext, actuals) {\n    // Start with a example generated from the Terminal...\n    var str = this.obj.generateExample(grammar, examples, inSyntacticContext, actuals).value;\n\n    // ...and randomly switch characters to uppercase/lowercase.\n    var value = '';\n    for (var i = 0; i < str.length; ++i) {\n      value += Math.random() < 0.5 ? str[i].toLocaleLowerCase() : str[i].toLocaleUpperCase();\n    }\n    return {value: value};\n  },\n\n  getArity: function() {\n    return 1;\n  },\n\n  substituteParams: function(actuals) {\n    return new CaseInsensitiveTerminal(this.obj.substituteParams(actuals));\n  },\n\n  toDisplayString: function() {\n    return this.obj.toDisplayString() + ' (case-insensitive)';\n  },\n\n  toFailure: function(grammar) {\n    return new Failure(this, this.obj.toFailure(grammar) + ' (case-insensitive)', 'description');\n  },\n\n  _isNullable: function(grammar, memo) {\n    return this.obj._isNullable(grammar, memo);\n  }\n};\n\nmodule.exports = CaseInsensitiveTerminal;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n/*\n  `Failure`s represent expressions that weren't matched while parsing. They are used to generate\n  error messages automatically. The interface of `Failure`s includes the collowing methods:\n\n  - getText() : String\n  - getType() : String  (one of {\"description\", \"string\", \"code\"})\n  - isDescription() : bool\n  - isStringTerminal() : bool\n  - isCode() : bool\n  - isFluffy() : bool\n  - makeFluffy() : void\n  - subsumes(Failure) : bool\n*/\n\nfunction isValidType(type) {\n  return type === 'description' || type === 'string' || type === 'code';\n}\n\nfunction Failure(pexpr, text, type) {\n  if (!isValidType(type)) {\n    throw new Error('invalid Failure type: ' + type);\n  }\n  this.pexpr = pexpr;\n  this.text = text;\n  this.type = type;\n  this.fluffy = false;\n}\n\nFailure.prototype.getPExpr = function() {\n  return this.pexpr;\n};\n\nFailure.prototype.getText = function() {\n  return this.text;\n};\n\nFailure.prototype.getType = function() {\n  return this.type;\n};\n\nFailure.prototype.isDescription = function() {\n  return this.type === 'description';\n};\n\nFailure.prototype.isStringTerminal = function() {\n  return this.type === 'string';\n};\n\nFailure.prototype.isCode = function() {\n  return this.type === 'code';\n};\n\nFailure.prototype.isFluffy = function() {\n  return this.fluffy;\n};\n\nFailure.prototype.makeFluffy = function() {\n  this.fluffy = true;\n};\n\nFailure.prototype.clearFluffy = function() {\n  this.fluffy = false;\n};\n\nFailure.prototype.subsumes = function(that) {\n  return this.getText() === that.getText() &&\n      this.type === that.type &&\n      (!this.isFluffy() || this.isFluffy() && that.isFluffy());\n};\n\nFailure.prototype.toString = function() {\n  return this.type === 'string' ?\n    JSON.stringify(this.getText()) :\n    this.getText();\n};\n\nFailure.prototype.clone = function() {\n  var failure = new Failure(this.pexpr, this.text, this.type);\n  if (this.isFluffy()) {\n    failure.makeFluffy();\n  }\n  return failure;\n};\n\nFailure.prototype.toKey = function() {\n  return this.toString() + '#' + this.type;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Failure;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar CaseInsensitiveTerminal = require('./CaseInsensitiveTerminal');\nvar Matcher = require('./Matcher');\nvar Semantics = require('./Semantics');\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction getSortedRuleValues(grammar) {\n  return Object.keys(grammar.rules).sort().map(function(name) { return grammar.rules[name]; });\n}\n\nfunction Grammar(\n    name,\n    superGrammar,\n    rules,\n    optDefaultStartRule) {\n  this.name = name;\n  this.superGrammar = superGrammar;\n  this.rules = rules;\n  if (optDefaultStartRule) {\n    if (!(optDefaultStartRule in rules)) {\n      throw new Error(\"Invalid start rule: '\" + optDefaultStartRule +\n                      \"' is not a rule in grammar '\" + name + \"'\");\n    }\n    this.defaultStartRule = optDefaultStartRule;\n  }\n}\n\nvar ohmGrammar;\nvar buildGrammar;\n\n// This method is called from main.js once Ohm has loaded.\nGrammar.initApplicationParser = function(grammar, builderFn) {\n  ohmGrammar = grammar;\n  buildGrammar = builderFn;\n};\n\nGrammar.prototype = {\n  matcher: function() {\n    return new Matcher(this);\n  },\n\n  // Return true if the grammar is a built-in grammar, otherwise false.\n  // NOTE: This might give an unexpected result if called before BuiltInRules is defined!\n  isBuiltIn: function() {\n    return this === Grammar.ProtoBuiltInRules || this === Grammar.BuiltInRules;\n  },\n\n  equals: function(g) {\n    if (this === g) {\n      return true;\n    }\n    // Do the cheapest comparisons first.\n    if (g == null ||\n        this.name !== g.name ||\n        this.defaultStartRule !== g.defaultStartRule ||\n        !(this.superGrammar === g.superGrammar || this.superGrammar.equals(g.superGrammar))) {\n      return false;\n    }\n    var myRules = getSortedRuleValues(this);\n    var otherRules = getSortedRuleValues(g);\n    return myRules.length === otherRules.length && myRules.every(function(rule, i) {\n      return rule.description === otherRules[i].description &&\n             rule.formals.join(',') === otherRules[i].formals.join(',') &&\n             rule.body.toString() === otherRules[i].body.toString();\n    });\n  },\n\n  match: function(input, optStartApplication) {\n    var m = this.matcher();\n    m.replaceInputRange(0, 0, input);\n    return m.match(optStartApplication);\n  },\n\n  trace: function(input, optStartApplication) {\n    var m = this.matcher();\n    m.replaceInputRange(0, 0, input);\n    return m.trace(optStartApplication);\n  },\n\n  semantics: function() {\n    // TODO: Remove this eventually! Deprecated in v0.12.\n    throw new Error('semantics() is deprecated -- use createSemantics() instead.');\n  },\n\n  createSemantics: function() {\n    return Semantics.createSemantics(this);\n  },\n\n  extendSemantics: function(superSemantics) {\n    return Semantics.createSemantics(this, superSemantics._getSemantics());\n  },\n\n  // Check that every key in `actionDict` corresponds to a semantic action, and that it maps to\n  // a function of the correct arity. If not, throw an exception.\n  _checkTopDownActionDict: function(what, name, actionDict) {\n    function isSpecialAction(a) {\n      return a === '_iter' || a === '_terminal' || a === '_nonterminal' || a === '_default';\n    }\n\n    var problems = [];\n    for (var k in actionDict) {\n      var v = actionDict[k];\n      if (!isSpecialAction(k) && !(k in this.rules)) {\n        problems.push(\"'\" + k + \"' is not a valid semantic action for '\" + this.name + \"'\");\n      } else if (typeof v !== 'function') {\n        problems.push(\n            \"'\" + k + \"' must be a function in an action dictionary for '\" + this.name + \"'\");\n      } else {\n        var actual = v.length;\n        var expected = this._topDownActionArity(k);\n        if (actual !== expected) {\n          problems.push(\n              \"Semantic action '\" + k + \"' has the wrong arity: \" +\n              'expected ' + expected + ', got ' + actual);\n        }\n      }\n    }\n    if (problems.length > 0) {\n      var prettyProblems = problems.map(function(problem) { return '- ' + problem; });\n      var error = new Error(\n          \"Found errors in the action dictionary of the '\" + name + \"' \" + what + ':\\n' +\n          prettyProblems.join('\\n'));\n      error.problems = problems;\n      throw error;\n    }\n  },\n\n  // Return the expected arity for a semantic action named `actionName`, which\n  // is either a rule name or a special action name like '_nonterminal'.\n  _topDownActionArity: function(actionName) {\n    if (actionName === '_iter' || actionName === '_nonterminal' || actionName === '_default') {\n      return 1;\n    } else if (actionName === '_terminal') {\n      return 0;\n    }\n    return this.rules[actionName].body.getArity();\n  },\n\n  _inheritsFrom: function(grammar) {\n    var g = this.superGrammar;\n    while (g) {\n      if (g.equals(grammar, true)) {\n        return true;\n      }\n      g = g.superGrammar;\n    }\n    return false;\n  },\n\n  toRecipe: function(optVarName) {\n    var metaInfo = {};\n    // Include the grammar source if it is available.\n    if (this.source) {\n      metaInfo.source = this.source.contents;\n    }\n\n    var superGrammar = null;\n    if (this.superGrammar && !this.superGrammar.isBuiltIn()) {\n      superGrammar = JSON.parse(this.superGrammar.toRecipe());\n    }\n\n    var startRule = null;\n    if (this.defaultStartRule) {\n      startRule = this.defaultStartRule;\n    }\n\n    var rules = {};\n    var self = this;\n    Object.keys(this.rules).forEach(function(ruleName) {\n      var ruleInfo = self.rules[ruleName];\n      var body = ruleInfo.body;\n      var isDefinition = !self.superGrammar || !self.superGrammar.rules[ruleName];\n\n      var operation;\n      if (isDefinition) {\n        operation = 'define';\n      } else {\n        operation = body instanceof pexprs.Extend ? 'extend' : 'override';\n      }\n\n      var metaInfo = {};\n      if (ruleInfo.source && self.source) {\n        var adjusted = ruleInfo.source.relativeTo(self.source);\n        metaInfo.sourceInterval = [adjusted.startIdx, adjusted.endIdx];\n      }\n\n      var description = isDefinition ? ruleInfo.description : null;\n      var bodyRecipe = body.outputRecipe(ruleInfo.formals, self.source);\n\n      rules[ruleName] = [\n        operation, // \"define\"/\"extend\"/\"override\"\n        metaInfo,\n        description,\n        ruleInfo.formals,\n        bodyRecipe\n      ];\n    });\n\n    return JSON.stringify([\n      'grammar',\n      metaInfo,\n      this.name,\n      superGrammar,\n      startRule,\n      rules\n    ]);\n  },\n\n  // TODO: Come up with better names for these methods.\n  // TODO: Write the analog of these methods for inherited attributes.\n  toOperationActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n  toAttributeActionDictionaryTemplate: function() {\n    return this._toOperationOrAttributeActionDictionaryTemplate();\n  },\n\n  _toOperationOrAttributeActionDictionaryTemplate: function() {\n    // TODO: add the super-grammar's templates at the right place, e.g., a case for AddExpr_plus\n    // should appear next to other cases of AddExpr.\n\n    var sb = new common.StringBuffer();\n    sb.append('{');\n\n    var first = true;\n    for (var ruleName in this.rules) {\n      var body = this.rules[ruleName].body;\n      if (first) {\n        first = false;\n      } else {\n        sb.append(',');\n      }\n      sb.append('\\n');\n      sb.append('  ');\n      this.addSemanticActionTemplate(ruleName, body, sb);\n    }\n\n    sb.append('\\n}');\n    return sb.contents();\n  },\n\n  addSemanticActionTemplate: function(ruleName, body, sb) {\n    sb.append(ruleName);\n    sb.append(': function(');\n    var arity = this._topDownActionArity(ruleName);\n    sb.append(common.repeat('_', arity).join(', '));\n    sb.append(') {\\n');\n    sb.append('  }');\n  },\n\n  // Parse a string which expresses a rule application in this grammar, and return the\n  // resulting Apply node.\n  parseApplication: function(str) {\n    var app;\n    if (str.indexOf('<') === -1) {\n      // simple application\n      app = new pexprs.Apply(str);\n    } else {\n      // parameterized application\n      var cst = ohmGrammar.match(str, 'Base_application');\n      app = buildGrammar(cst, {});\n    }\n\n    // Ensure that the application is valid.\n    if (!(app.ruleName in this.rules)) {\n      throw errors.undeclaredRule(app.ruleName, this.name);\n    }\n    var formals = this.rules[app.ruleName].formals;\n    if (formals.length !== app.args.length) {\n      var source = this.rules[app.ruleName].source;\n      throw errors.wrongNumberOfParameters(app.ruleName, formals.length, app.args.length, source);\n    }\n    return app;\n  }\n};\n\n// The following grammar contains a few rules that couldn't be written  in \"userland\".\n// At the bottom of src/main.js, we create a sub-grammar of this grammar that's called\n// `BuiltInRules`. That grammar contains several convenience rules, e.g., `letter` and\n// `digit`, and is implicitly the super-grammar of any grammar whose super-grammar\n// isn't specified.\nGrammar.ProtoBuiltInRules = new Grammar(\n  'ProtoBuiltInRules',  // name\n  undefined,  // supergrammar\n  {\n    any: {\n      body: pexprs.any,\n      formals: [],\n      description: 'any character',\n      primitive: true\n    },\n    end: {\n      body: pexprs.end,\n      formals: [],\n      description: 'end of input',\n      primitive: true\n    },\n\n    caseInsensitive: {\n      body: new CaseInsensitiveTerminal(new pexprs.Param(0)),\n      formals: ['str'],\n      primitive: true\n    },\n    lower: {\n      body: new pexprs.UnicodeChar('Ll'),\n      formals: [],\n      description: 'a lowercase letter',\n      primitive: true\n    },\n    upper: {\n      body: new pexprs.UnicodeChar('Lu'),\n      formals: [],\n      description: 'an uppercase letter',\n      primitive: true\n    },\n    // The union of Lt (titlecase), Lm (modifier), and Lo (other), i.e. any letter not in Ll or Lu.\n    unicodeLtmo: {\n      body: new pexprs.UnicodeChar('Ltmo'),\n      formals: [],\n      description: 'a Unicode character in Lt, Lm, or Lo',\n      primitive: true\n    },\n\n    // These rules are not truly primitive (they could be written in userland) but are defined\n    // here for bootstrapping purposes.\n    spaces: {\n      body: new pexprs.Star(new pexprs.Apply('space')),\n      formals: []\n    },\n    space: {\n      body: new pexprs.Range('\\x00', ' '),\n      formals: [],\n      description: 'a space'\n    }\n  }\n);\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Grammar;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Grammar = require('./Grammar');\nvar InputStream = require('./InputStream');\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Constructors\n\nfunction GrammarDecl(name) {\n  this.name = name;\n}\n\n// Helpers\n\nGrammarDecl.prototype.sourceInterval = function(startIdx, endIdx) {\n  return this.source.subInterval(startIdx, endIdx - startIdx);\n};\n\nGrammarDecl.prototype.ensureSuperGrammar = function() {\n  if (!this.superGrammar) {\n    this.withSuperGrammar(\n        // TODO: The conditional expression below is an ugly hack. It's kind of ok because\n        // I doubt anyone will ever try to declare a grammar called `BuiltInRules`. Still,\n        // we should try to find a better way to do this.\n        this.name === 'BuiltInRules' ?\n            Grammar.ProtoBuiltInRules :\n            Grammar.BuiltInRules);\n  }\n  return this.superGrammar;\n};\n\nGrammarDecl.prototype.installOverriddenOrExtendedRule = function(name, formals, body, source) {\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw errors.duplicateParameterNames(name, duplicateParameterNames, source);\n  }\n  var ruleInfo = this.ensureSuperGrammar().rules[name];\n  var expectedFormals = ruleInfo.formals;\n  var expectedNumFormals = expectedFormals ? expectedFormals.length : 0;\n  if (formals.length !== expectedNumFormals) {\n    throw errors.wrongNumberOfParameters(name, expectedNumFormals, formals.length, source);\n  }\n  return this.install(name, formals, body, ruleInfo.description, source);\n};\n\nGrammarDecl.prototype.install = function(name, formals, body, description, source) {\n  this.rules[name] = {\n    body: body.introduceParams(formals),\n    formals: formals,\n    description: description,\n    source: source\n  };\n  return this;\n};\n\n// Stuff that you should only do once\n\nGrammarDecl.prototype.withSuperGrammar = function(superGrammar) {\n  if (this.superGrammar) {\n    throw new Error('the super grammar of a GrammarDecl cannot be set more than once');\n  }\n  this.superGrammar = superGrammar;\n  this.rules = Object.create(superGrammar.rules);\n\n  // Grammars with an explicit supergrammar inherit a default start rule.\n  if (!superGrammar.isBuiltIn()) {\n    this.defaultStartRule = superGrammar.defaultStartRule;\n  }\n  return this;\n};\n\nGrammarDecl.prototype.withDefaultStartRule = function(ruleName) {\n  this.defaultStartRule = ruleName;\n  return this;\n};\n\nGrammarDecl.prototype.withSource = function(source) {\n  this.source = new InputStream(source).interval(0, source.length);\n  return this;\n};\n\n// Creates a Grammar instance, and if it passes the sanity checks, returns it.\nGrammarDecl.prototype.build = function() {\n  var grammar = new Grammar(\n      this.name,\n      this.ensureSuperGrammar(),\n      this.rules,\n      this.defaultStartRule);\n\n  // TODO: change the pexpr.prototype.assert... methods to make them add\n  // exceptions to an array that's provided as an arg. Then we'll be able to\n  // show more than one error of the same type at a time.\n  // TODO: include the offending pexpr in the errors, that way we can show\n  // the part of the source that caused it.\n  var grammarErrors = [];\n  var grammarHasInvalidApplications = false;\n  Object.keys(grammar.rules).forEach(function(ruleName) {\n    var body = grammar.rules[ruleName].body;\n    try {\n      body.assertChoicesHaveUniformArity(ruleName);\n    } catch (e) {\n      grammarErrors.push(e);\n    }\n    try {\n      body.assertAllApplicationsAreValid(ruleName, grammar);\n    } catch (e) {\n      grammarErrors.push(e);\n      grammarHasInvalidApplications = true;\n    }\n  });\n  if (!grammarHasInvalidApplications) {\n    // The following check can only be done if the grammar has no invalid applications.\n    Object.keys(grammar.rules).forEach(function(ruleName) {\n      var body = grammar.rules[ruleName].body;\n      try {\n        body.assertIteratedExprsAreNotNullable(grammar, []);\n      } catch (e) {\n        grammarErrors.push(e);\n      }\n    });\n  }\n  if (grammarErrors.length > 0) {\n    errors.throwErrors(grammarErrors);\n  }\n  if (this.source) {\n    grammar.source = this.source;\n  }\n\n  return grammar;\n};\n\n// Rule declarations\n\nGrammarDecl.prototype.define = function(name, formals, body, description, source) {\n  this.ensureSuperGrammar();\n  if (this.superGrammar.rules[name]) {\n    throw errors.duplicateRuleDeclaration(name, this.name, this.superGrammar.name, source);\n  } else if (this.rules[name]) {\n    throw errors.duplicateRuleDeclaration(name, this.name, this.name, source);\n  }\n  var duplicateParameterNames = common.getDuplicates(formals);\n  if (duplicateParameterNames.length > 0) {\n    throw errors.duplicateParameterNames(name, duplicateParameterNames, source);\n  }\n  return this.install(name, formals, body, description, source);\n};\n\nGrammarDecl.prototype.override = function(name, formals, body, descIgnored, source) {\n  var ruleInfo = this.ensureSuperGrammar().rules[name];\n  if (!ruleInfo) {\n    throw errors.cannotOverrideUndeclaredRule(name, this.superGrammar.name, source);\n  }\n  this.installOverriddenOrExtendedRule(name, formals, body, source);\n  return this;\n};\n\nGrammarDecl.prototype.extend = function(name, formals, fragment, descIgnored, source) {\n  var ruleInfo = this.ensureSuperGrammar().rules[name];\n  if (!ruleInfo) {\n    throw errors.cannotExtendUndeclaredRule(name, this.superGrammar.name, source);\n  }\n  var body = new pexprs.Extend(this.superGrammar, name, fragment);\n  body.source = fragment.source;\n  this.installOverriddenOrExtendedRule(name, formals, body, source);\n  return this;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = GrammarDecl;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Interval = require('./Interval');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction InputStream(source) {\n  this.source = source;\n  this.pos = 0;\n  this.examinedLength = 0;\n}\n\nInputStream.prototype = {\n  atEnd: function() {\n    var ans = this.pos === this.source.length;\n    this.examinedLength = Math.max(this.examinedLength, this.pos + 1);\n    return ans;\n  },\n\n  next: function() {\n    var ans = this.source[this.pos++];\n    this.examinedLength = Math.max(this.examinedLength, this.pos);\n    return ans;\n  },\n\n  matchString: function(s, optIgnoreCase) {\n    var idx;\n    if (optIgnoreCase) {\n      /*\n        Case-insensitive comparison is a tricky business. Some notable gotchas include the\n        \"Turkish I\" problem (http://www.i18nguy.com/unicode/turkish-i18n.html) and the fact\n        that the German Esszet (ß) turns into \"SS\" in upper case.\n\n        This is intended to be a locale-invariant comparison, which means it may not obey\n        locale-specific expectations (e.g. \"i\" => \"İ\").\n       */\n      for (idx = 0; idx < s.length; idx++) {\n        var actual = this.next();\n        var expected = s[idx];\n        if (actual == null || actual.toUpperCase() !== expected.toUpperCase()) {\n          return false;\n        }\n      }\n      return true;\n    }\n    // Default is case-sensitive comparison.\n    for (idx = 0; idx < s.length; idx++) {\n      if (this.next() !== s[idx]) { return false; }\n    }\n    return true;\n  },\n\n  sourceSlice: function(startIdx, endIdx) {\n    return this.source.slice(startIdx, endIdx);\n  },\n\n  interval: function(startIdx, optEndIdx) {\n    return new Interval(this.source, startIdx, optEndIdx ? optEndIdx : this.pos);\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = InputStream;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar assert = require('./common').assert;\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Interval(sourceString, startIdx, endIdx) {\n  this.sourceString = sourceString;\n  this.startIdx = startIdx;\n  this.endIdx = endIdx;\n}\n\nInterval.coverage = function(/* interval1, interval2, ... */) {\n  var sourceString = arguments[0].sourceString;\n  var startIdx = arguments[0].startIdx;\n  var endIdx = arguments[0].endIdx;\n  for (var idx = 1; idx < arguments.length; idx++) {\n    var interval = arguments[idx];\n    if (interval.sourceString !== sourceString) {\n      throw errors.intervalSourcesDontMatch();\n    } else {\n      startIdx = Math.min(startIdx, arguments[idx].startIdx);\n      endIdx = Math.max(endIdx, arguments[idx].endIdx);\n    }\n  }\n  return new Interval(sourceString, startIdx, endIdx);\n};\n\nInterval.prototype = {\n  coverageWith: function(/* interval1, interval2, ... */) {\n    var intervals = Array.prototype.slice.call(arguments);\n    intervals.push(this);\n    return Interval.coverage.apply(undefined, intervals);\n  },\n\n  collapsedLeft: function() {\n    return new Interval(this.sourceString, this.startIdx, this.startIdx);\n  },\n\n  collapsedRight: function() {\n    return new Interval(this.sourceString, this.endIdx, this.endIdx);\n  },\n\n  getLineAndColumnMessage: function() {\n    var range = [this.startIdx, this.endIdx];\n    return util.getLineAndColumnMessage(this.sourceString, this.startIdx, range);\n  },\n\n  // Returns an array of 0, 1, or 2 intervals that represents the result of the\n  // interval difference operation.\n  minus: function(that) {\n    if (this.sourceString !== that.sourceString) {\n      throw errors.intervalSourcesDontMatch();\n    } else if (this.startIdx === that.startIdx && this.endIdx === that.endIdx) {\n      // `this` and `that` are the same interval!\n      return [\n      ];\n    } else if (this.startIdx < that.startIdx && that.endIdx < this.endIdx) {\n      // `that` splits `this` into two intervals\n      return [\n        new Interval(this.sourceString, this.startIdx, that.startIdx),\n        new Interval(this.sourceString, that.endIdx, this.endIdx)\n      ];\n    } else if (this.startIdx < that.endIdx && that.endIdx < this.endIdx) {\n      // `that` contains a prefix of `this`\n      return [\n        new Interval(this.sourceString, that.endIdx, this.endIdx)\n      ];\n    } else if (this.startIdx < that.startIdx && that.startIdx < this.endIdx) {\n      // `that` contains a suffix of `this`\n      return [\n        new Interval(this.sourceString, this.startIdx, that.startIdx)\n      ];\n    } else {\n      // `that` and `this` do not overlap\n      return [\n        this\n      ];\n    }\n  },\n\n  // Returns a new Interval that has the same extent as this one, but which is relative\n  // to `that`, an Interval that fully covers this one.\n  relativeTo: function(that) {\n    if (this.sourceString !== that.sourceString) {\n      throw errors.intervalSourcesDontMatch();\n    }\n    assert(this.startIdx >= that.startIdx && this.endIdx <= that.endIdx,\n           'other interval does not cover this one');\n    return new Interval(this.sourceString,\n                        this.startIdx - that.startIdx,\n                        this.endIdx - that.startIdx);\n  },\n\n  // Returns a new Interval which contains the same contents as this one,\n  // but with whitespace trimmed from both ends. (This only makes sense when\n  // the input stream is a string.)\n  trimmed: function() {\n    var contents = this.contents;\n    var startIdx = this.startIdx + contents.match(/^\\s*/)[0].length;\n    var endIdx = this.endIdx - contents.match(/\\s*$/)[0].length;\n    return new Interval(this.sourceString, startIdx, endIdx);\n  },\n\n  subInterval: function(offset, len) {\n    var newStartIdx = this.startIdx + offset;\n    return new Interval(this.sourceString, newStartIdx, newStartIdx + len);\n  }\n};\n\nObject.defineProperties(Interval.prototype, {\n  contents: {\n    get: function() {\n      if (this._contents === undefined) {\n        this._contents = this.sourceString.slice(this.startIdx, this.endIdx);\n      }\n      return this._contents;\n    },\n    enumerable: true\n  },\n  length: {\n    get: function() { return this.endIdx - this.startIdx; },\n    enumerable: true\n  }\n});\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Interval;\n\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar util = require('./util');\nvar Interval = require('./Interval');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction MatchResult(\n    matcher,\n    input,\n    startExpr,\n    cst,\n    cstOffset,\n    rightmostFailurePosition,\n    optRecordedFailures) {\n\n  this.matcher = matcher;\n  this.input = input;\n  this.startExpr = startExpr;\n  this._cst = cst;\n  this._cstOffset = cstOffset;\n  this._rightmostFailurePosition = rightmostFailurePosition;\n  this._rightmostFailures = optRecordedFailures;\n\n  if (this.failed()) {\n    common.defineLazyProperty(this, 'message', function() {\n      var detail = 'Expected ' + this.getExpectedText();\n      return util.getLineAndColumnMessage(this.input, this.getRightmostFailurePosition()) + detail;\n    });\n    common.defineLazyProperty(this, 'shortMessage', function() {\n      var detail = 'expected ' + this.getExpectedText();\n      var errorInfo = util.getLineAndColumn(this.input, this.getRightmostFailurePosition());\n      return 'Line ' + errorInfo.lineNum + ', col ' + errorInfo.colNum + ': ' + detail;\n    });\n  }\n}\n\nMatchResult.prototype.succeeded = function() {\n  return !!this._cst;\n};\n\nMatchResult.prototype.failed = function() {\n  return !this.succeeded();\n};\n\nMatchResult.prototype.getRightmostFailurePosition = function() {\n  return this._rightmostFailurePosition;\n};\n\nMatchResult.prototype.getRightmostFailures = function() {\n  if (!this._rightmostFailures) {\n    this.matcher.setInput(this.input);\n    var matchResultWithFailures =\n        this.matcher._match(this.startExpr, false, this.getRightmostFailurePosition());\n    this._rightmostFailures = matchResultWithFailures.getRightmostFailures();\n  }\n  return this._rightmostFailures;\n};\n\nMatchResult.prototype.toString = function() {\n  return this.succeeded() ?\n      '[match succeeded]' :\n      '[match failed at position ' + this.getRightmostFailurePosition() + ']';\n};\n\n// Return a string summarizing the expected contents of the input stream when\n// the match failure occurred.\nMatchResult.prototype.getExpectedText = function() {\n  if (this.succeeded()) {\n    throw new Error('cannot get expected text of a successful MatchResult');\n  }\n\n  var sb = new common.StringBuffer();\n  var failures = this.getRightmostFailures();\n\n  // Filter out the fluffy failures to make the default error messages more useful\n  failures = failures.filter(function(failure) {\n    return !failure.isFluffy();\n  });\n\n  for (var idx = 0; idx < failures.length; idx++) {\n    if (idx > 0) {\n      if (idx === failures.length - 1) {\n        sb.append(failures.length > 2 ? ', or ' : ' or ');\n      } else {\n        sb.append(', ');\n      }\n    }\n    sb.append(failures[idx].toString());\n  }\n  return sb.contents();\n};\n\nMatchResult.prototype.getInterval = function() {\n  var pos = this.getRightmostFailurePosition();\n  return new Interval(this.input, pos, pos);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = MatchResult;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar InputStream = require('./InputStream');\nvar MatchResult = require('./MatchResult');\nvar PosInfo = require('./PosInfo');\nvar Trace = require('./Trace');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nvar applySpaces = new pexprs.Apply('spaces');\n\nfunction MatchState(matcher, startExpr, optPositionToRecordFailures) {\n  this.matcher = matcher;\n  this.startExpr = startExpr;\n\n  this.grammar = matcher.grammar;\n  this.input = matcher.input;\n  this.inputStream = new InputStream(matcher.input);\n  this.memoTable = matcher.memoTable;\n\n  this._bindings = [];\n  this._bindingOffsets = [];\n  this._applicationStack = [];\n  this._posStack = [0];\n  this.inLexifiedContextStack = [false];\n\n  this.rightmostFailurePosition = -1;\n  this._rightmostFailurePositionStack = [];\n  this._recordedFailuresStack = [];\n\n  if (optPositionToRecordFailures !== undefined) {\n    this.positionToRecordFailures = optPositionToRecordFailures;\n    this.recordedFailures = Object.create(null);\n  }\n}\n\nMatchState.prototype = {\n  posToOffset: function(pos) {\n    return pos - this._posStack[this._posStack.length - 1];\n  },\n\n  enterApplication: function(posInfo, app) {\n    this._posStack.push(this.inputStream.pos);\n    this._applicationStack.push(app);\n    this.inLexifiedContextStack.push(false);\n    posInfo.enter(app);\n    this._rightmostFailurePositionStack.push(this.rightmostFailurePosition);\n    this.rightmostFailurePosition = -1;\n  },\n\n  exitApplication: function(posInfo, optNode) {\n    var origPos = this._posStack.pop();\n    this._applicationStack.pop();\n    this.inLexifiedContextStack.pop();\n    posInfo.exit();\n\n    this.rightmostFailurePosition = Math.max(\n        this.rightmostFailurePosition,\n        this._rightmostFailurePositionStack.pop());\n\n    if (optNode) {\n      this.pushBinding(optNode, origPos);\n    }\n  },\n\n  enterLexifiedContext: function() {\n    this.inLexifiedContextStack.push(true);\n  },\n\n  exitLexifiedContext: function() {\n    this.inLexifiedContextStack.pop();\n  },\n\n  currentApplication: function() {\n    return this._applicationStack[this._applicationStack.length - 1];\n  },\n\n  inSyntacticContext: function() {\n    if (typeof this.inputStream.source !== 'string') {\n      return false;\n    }\n    var currentApplication = this.currentApplication();\n    if (currentApplication) {\n      return currentApplication.isSyntactic() && !this.inLexifiedContext();\n    } else {\n      // The top-level context is syntactic if the start application is.\n      return this.startExpr.factors[0].isSyntactic();\n    }\n  },\n\n  inLexifiedContext: function() {\n    return this.inLexifiedContextStack[this.inLexifiedContextStack.length - 1];\n  },\n\n  skipSpaces: function() {\n    this.pushFailuresInfo();\n    this.eval(applySpaces);\n    this.popBinding();\n    this.popFailuresInfo();\n    return this.inputStream.pos;\n  },\n\n  skipSpacesIfInSyntacticContext: function() {\n    return this.inSyntacticContext() ?\n        this.skipSpaces() :\n        this.inputStream.pos;\n  },\n\n  maybeSkipSpacesBefore: function(expr) {\n    if (expr instanceof pexprs.Apply && expr.isSyntactic()) {\n      return this.skipSpaces();\n    } else if (expr.allowsSkippingPrecedingSpace() && expr !== applySpaces) {\n      return this.skipSpacesIfInSyntacticContext();\n    } else {\n      return this.inputStream.pos;\n    }\n  },\n\n  pushBinding: function(node, origPos) {\n    this._bindings.push(node);\n    this._bindingOffsets.push(this.posToOffset(origPos));\n  },\n\n  popBinding: function() {\n    this._bindings.pop();\n    this._bindingOffsets.pop();\n  },\n\n  numBindings: function() {\n    return this._bindings.length;\n  },\n\n  truncateBindings: function(newLength) {\n    // Yes, this is this really faster than setting the `length` property (tested with\n    // bin/es5bench on Node v6.1.0).\n    while (this._bindings.length > newLength) {\n      this.popBinding();\n    }\n  },\n\n  getCurrentPosInfo: function() {\n    return this.getPosInfo(this.inputStream.pos);\n  },\n\n  getPosInfo: function(pos) {\n    var posInfo = this.memoTable[pos];\n    if (!posInfo) {\n      posInfo = this.memoTable[pos] = new PosInfo();\n    }\n    return posInfo;\n  },\n\n  processFailure: function(pos, expr) {\n    this.rightmostFailurePosition = Math.max(this.rightmostFailurePosition, pos);\n\n    if (this.recordedFailures && pos === this.positionToRecordFailures) {\n      var app = this.currentApplication();\n      if (app) {\n        // Substitute parameters with the actual pexprs that were passed to\n        // the current rule.\n        expr = expr.substituteParams(app.args);\n      } else {\n        // This branch is only reached for the \"end-check\" that is\n        // performed after the top-level application. In that case,\n        // expr === pexprs.end so there is no need to substitute\n        // parameters.\n      }\n\n      this.recordFailure(expr.toFailure(this.grammar), false);\n    }\n  },\n\n  recordFailure: function(failure, shouldCloneIfNew) {\n    var key = failure.toKey();\n    if (!this.recordedFailures[key]) {\n      this.recordedFailures[key] = shouldCloneIfNew ? failure.clone() : failure;\n    } else if (this.recordedFailures[key].isFluffy() && !failure.isFluffy()) {\n      this.recordedFailures[key].clearFluffy();\n    }\n  },\n\n  recordFailures: function(failures, shouldCloneIfNew) {\n    var self = this;\n    Object.keys(failures).forEach(function(key) {\n      self.recordFailure(failures[key], shouldCloneIfNew);\n    });\n  },\n\n  cloneRecordedFailures: function() {\n    if (!this.recordedFailures) {\n      return undefined;\n    }\n\n    var ans = Object.create(null);\n    var self = this;\n    Object.keys(this.recordedFailures).forEach(function(key) {\n      ans[key] = self.recordedFailures[key].clone();\n    });\n    return ans;\n  },\n\n  getRightmostFailurePosition: function() {\n    return this.rightmostFailurePosition;\n  },\n\n  _getRightmostFailureOffset: function() {\n    return this.rightmostFailurePosition >= 0 ?\n        this.posToOffset(this.rightmostFailurePosition) :\n        -1;\n  },\n\n  // Returns the memoized trace entry for `expr` at `pos`, if one exists, `null` otherwise.\n  getMemoizedTraceEntry: function(pos, expr) {\n    var posInfo = this.memoTable[pos];\n    if (posInfo && expr.ruleName) {\n      var memoRec = posInfo.memo[expr.toMemoKey()];\n      if (memoRec && memoRec.traceEntry) {\n        var entry = memoRec.traceEntry.cloneWithExpr(expr);\n        entry.isMemoized = true;\n        return entry;\n      }\n    }\n    return null;\n  },\n\n  // Returns a new trace entry, with the currently active trace array as its children.\n  getTraceEntry: function(pos, expr, succeeded, bindings) {\n    if (expr instanceof pexprs.Apply) {\n      var app = this.currentApplication();\n      var actuals = app ? app.args : [];\n      expr = expr.substituteParams(actuals);\n    }\n    return this.getMemoizedTraceEntry(pos, expr) ||\n           new Trace(this.input, pos, this.inputStream.pos, expr, succeeded, bindings, this.trace);\n  },\n\n  isTracing: function() {\n    return !!this.trace;\n  },\n\n  hasNecessaryInfo: function(memoRec) {\n    if (this.trace && !memoRec.traceEntry) {\n      return false;\n    }\n\n    if (this.recordedFailures &&\n        this.inputStream.pos + memoRec.rightmostFailureOffset === this.positionToRecordFailures) {\n      return !!memoRec.failuresAtRightmostPosition;\n    }\n\n    return true;\n  },\n\n\n  useMemoizedResult: function(origPos, memoRec) {\n    if (this.trace) {\n      this.trace.push(memoRec.traceEntry);\n    }\n\n    var memoRecRightmostFailurePosition = this.inputStream.pos + memoRec.rightmostFailureOffset;\n    this.rightmostFailurePosition =\n        Math.max(this.rightmostFailurePosition, memoRecRightmostFailurePosition);\n    if (this.recordedFailures &&\n        this.positionToRecordFailures === memoRecRightmostFailurePosition &&\n        memoRec.failuresAtRightmostPosition) {\n      this.recordFailures(memoRec.failuresAtRightmostPosition, true);\n    }\n\n    this.inputStream.examinedLength =\n        Math.max(this.inputStream.examinedLength, memoRec.examinedLength + origPos);\n\n    if (memoRec.value) {\n      this.inputStream.pos += memoRec.matchLength;\n      this.pushBinding(memoRec.value, origPos);\n      return true;\n    }\n    return false;\n  },\n\n  // Evaluate `expr` and return `true` if it succeeded, `false` otherwise. On success, `bindings`\n  // will have `expr.getArity()` more elements than before, and the input stream's position may\n  // have increased. On failure, `bindings` and position will be unchanged.\n  eval: function(expr) {\n    var inputStream = this.inputStream;\n    var origNumBindings = this._bindings.length;\n\n    var origRecordedFailures;\n    if (this.recordedFailures) {\n      origRecordedFailures = this.recordedFailures;\n      this.recordedFailures = Object.create(null);\n    }\n\n    var origPos = inputStream.pos;\n    var memoPos = this.maybeSkipSpacesBefore(expr);\n\n    var origTrace;\n    if (this.trace) {\n      origTrace = this.trace;\n      this.trace = [];\n    }\n\n    // Do the actual evaluation.\n    var ans = expr.eval(this);\n\n    if (this.trace) {\n      var bindings = this._bindings.slice(origNumBindings);\n      var traceEntry = this.getTraceEntry(memoPos, expr, ans, bindings);\n      traceEntry.isImplicitSpaces = expr === applySpaces;\n      traceEntry.isRootNode = expr === this.startExpr;\n      origTrace.push(traceEntry);\n      this.trace = origTrace;\n    }\n\n    if (ans) {\n      if (this.recordedFailures && inputStream.pos === this.positionToRecordFailures) {\n        var self = this;\n        Object.keys(this.recordedFailures).forEach(function(key) {\n          self.recordedFailures[key].makeFluffy();\n        });\n      }\n    } else {\n      // Reset the position and the bindings.\n      inputStream.pos = origPos;\n      this.truncateBindings(origNumBindings);\n    }\n\n    if (this.recordedFailures) {\n      this.recordFailures(origRecordedFailures, false);\n    }\n\n    return ans;\n  },\n\n  getMatchResult: function() {\n    this.eval(this.startExpr);\n    var rightmostFailures;\n    if (this.recordedFailures) {\n      var self = this;\n      rightmostFailures = Object.keys(this.recordedFailures).map(function(key) {\n        return self.recordedFailures[key];\n      });\n    }\n    return new MatchResult(\n        this.matcher,\n        this.input,\n        this.startExpr,\n        this._bindings[0],\n        this._bindingOffsets[0],\n        this.rightmostFailurePosition,\n        rightmostFailures);\n  },\n\n  getTrace: function() {\n    this.trace = [];\n    var matchResult = this.getMatchResult();\n\n    // The trace node for the start rule is always the last entry. If it is a syntactic rule,\n    // the first entry is for an application of 'spaces'.\n    // TODO(pdubroy): Clean this up by introducing a special `Match<startAppl>` rule, which will\n    // ensure that there is always a single root trace node.\n    var rootTrace = this.trace[this.trace.length - 1];\n    rootTrace.result = matchResult;\n    return rootTrace;\n  },\n\n  pushFailuresInfo: function() {\n    this._rightmostFailurePositionStack.push(this.rightmostFailurePosition);\n    this._recordedFailuresStack.push(this.recordedFailures);\n  },\n\n  popFailuresInfo: function() {\n    this.rightmostFailurePosition = this._rightmostFailurePositionStack.pop();\n    this.recordedFailures = this._recordedFailuresStack.pop();\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = MatchState;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar MatchState = require('./MatchState');\n\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Matcher(grammar) {\n  this.grammar = grammar;\n  this.memoTable = [];\n  this.input = '';\n}\n\nMatcher.prototype.getInput = function() {\n  return this.input;\n};\n\nMatcher.prototype.setInput = function(str) {\n  if (this.input !== str) {\n    this.replaceInputRange(0, this.input.length, str);\n  }\n  return this;\n};\n\nMatcher.prototype.replaceInputRange = function(startIdx, endIdx, str) {\n  var currentInput = this.input;\n  if (startIdx < 0 || startIdx > currentInput.length ||\n      endIdx < 0 || endIdx > currentInput.length ||\n      startIdx > endIdx) {\n    throw new Error('Invalid indices: ' + startIdx + ' and ' + endIdx);\n  }\n\n  // update input\n  this.input = currentInput.slice(0, startIdx) + str + currentInput.slice(endIdx);\n\n  // update memo table (similar to the above)\n  var restOfMemoTable = this.memoTable.slice(endIdx);\n  this.memoTable.length = startIdx;\n  for (var idx = 0; idx < str.length; idx++) {\n    this.memoTable.push(undefined);\n  }\n  restOfMemoTable.forEach(\n      function(posInfo) { this.memoTable.push(posInfo); },\n      this);\n\n  // Invalidate memoRecs\n  for (var pos = 0; pos < startIdx; pos++) {\n    var posInfo = this.memoTable[pos];\n    if (posInfo) {\n      posInfo.clearObsoleteEntries(pos, startIdx);\n    }\n  }\n\n  return this;\n};\n\nMatcher.prototype.match = function(optStartApplicationStr) {\n  return this._match(this._getStartExpr(optStartApplicationStr), false);\n};\n\nMatcher.prototype.trace = function(optStartApplicationStr) {\n  return this._match(this._getStartExpr(optStartApplicationStr), true);\n};\n\nMatcher.prototype._match = function(startExpr, tracing, optPositionToRecordFailures) {\n  var state = new MatchState(this, startExpr, optPositionToRecordFailures);\n  return tracing ? state.getTrace() : state.getMatchResult();\n};\n\n/*\n  Returns the starting expression for this Matcher's associated grammar. If `optStartApplicationStr`\n  is specified, it is a string expressing a rule application in the grammar. If not specified, the\n  grammar's default start rule will be used.\n*/\nMatcher.prototype._getStartExpr = function(optStartApplicationStr) {\n  var applicationStr = optStartApplicationStr || this.grammar.defaultStartRule;\n  if (!applicationStr) {\n    throw new Error('Missing start rule argument -- the grammar has no default start rule.');\n  }\n\n  var startApp = this.grammar.parseApplication(applicationStr);\n  return new pexprs.Seq([startApp, pexprs.end]);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Matcher;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Namespace() {\n}\nNamespace.prototype = Object.create(null);\n\nNamespace.asNamespace = function(objOrNamespace) {\n  if (objOrNamespace instanceof Namespace) {\n    return objOrNamespace;\n  }\n  return Namespace.createNamespace(objOrNamespace);\n};\n\n// Create a new namespace. If `optProps` is specified, all of its properties\n// will be copied to the new namespace.\nNamespace.createNamespace = function(optProps) {\n  return Namespace.extend(Namespace.prototype, optProps);\n};\n\n// Create a new namespace which extends another namespace. If `optProps` is\n// specified, all of its properties will be copied to the new namespace.\nNamespace.extend = function(namespace, optProps) {\n  if (namespace !== Namespace.prototype && !(namespace instanceof Namespace)) {\n    throw new TypeError('not a Namespace object: ' + namespace);\n  }\n  var ns = Object.create(namespace, {\n    constructor: {\n      value: Namespace,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  return extend(ns, optProps);\n};\n\n// TODO: Should this be a regular method?\nNamespace.toString = function(ns) {\n  return Object.prototype.toString.call(ns);\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Namespace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction PosInfo() {\n  this.applicationMemoKeyStack = [];  // active applications at this position\n  this.memo = {};\n  this.maxExaminedLength = 0;\n  this.maxRightmostFailureOffset = -1;\n  this.currentLeftRecursion = undefined;\n}\n\nPosInfo.prototype = {\n  isActive: function(application) {\n    return this.applicationMemoKeyStack.indexOf(application.toMemoKey()) >= 0;\n  },\n\n  enter: function(application) {\n    this.applicationMemoKeyStack.push(application.toMemoKey());\n  },\n\n  exit: function() {\n    this.applicationMemoKeyStack.pop();\n  },\n\n  startLeftRecursion: function(headApplication, memoRec) {\n    memoRec.isLeftRecursion = true;\n    memoRec.headApplication = headApplication;\n    memoRec.nextLeftRecursion = this.currentLeftRecursion;\n    this.currentLeftRecursion = memoRec;\n\n    var applicationMemoKeyStack = this.applicationMemoKeyStack;\n    var indexOfFirstInvolvedRule = applicationMemoKeyStack.indexOf(headApplication.toMemoKey()) + 1;\n    var involvedApplicationMemoKeys = applicationMemoKeyStack.slice(indexOfFirstInvolvedRule);\n\n    memoRec.isInvolved = function(applicationMemoKey) {\n      return involvedApplicationMemoKeys.indexOf(applicationMemoKey) >= 0;\n    };\n\n    memoRec.updateInvolvedApplicationMemoKeys = function() {\n      for (var idx = indexOfFirstInvolvedRule; idx < applicationMemoKeyStack.length; idx++) {\n        var applicationMemoKey = applicationMemoKeyStack[idx];\n        if (!this.isInvolved(applicationMemoKey)) {\n          involvedApplicationMemoKeys.push(applicationMemoKey);\n        }\n      }\n    };\n  },\n\n  endLeftRecursion: function() {\n    this.currentLeftRecursion = this.currentLeftRecursion.nextLeftRecursion;\n  },\n\n  // Note: this method doesn't get called for the \"head\" of a left recursion -- for LR heads,\n  // the memoized result (which starts out being a failure) is always used.\n  shouldUseMemoizedResult: function(memoRec) {\n    if (!memoRec.isLeftRecursion) {\n      return true;\n    }\n    var applicationMemoKeyStack = this.applicationMemoKeyStack;\n    for (var idx = 0; idx < applicationMemoKeyStack.length; idx++) {\n      var applicationMemoKey = applicationMemoKeyStack[idx];\n      if (memoRec.isInvolved(applicationMemoKey)) {\n        return false;\n      }\n    }\n    return true;\n  },\n\n  memoize: function(memoKey, memoRec) {\n    this.memo[memoKey] = memoRec;\n    this.maxExaminedLength = Math.max(this.maxExaminedLength, memoRec.examinedLength);\n    this.maxRightmostFailureOffset =\n        Math.max(this.maxRightmostFailureOffset, memoRec.rightmostFailureOffset);\n    return memoRec;\n  },\n\n  clearObsoleteEntries: function(pos, invalidatedIdx) {\n    if (pos + this.maxExaminedLength <= invalidatedIdx) {\n      // Optimization: none of the rule applications that were memoized here examined the\n      // interval of the input that changed, so nothing has to be invalidated.\n      return;\n    }\n\n    var memo = this.memo;\n    this.maxExaminedLength = 0;\n    this.maxRightmostFailureOffset = -1;\n    var self = this;\n    Object.keys(memo).forEach(function(k) {\n      var memoRec = memo[k];\n      if (pos + memoRec.examinedLength > invalidatedIdx) {\n        delete memo[k];\n      } else {\n        self.maxExaminedLength = Math.max(self.maxExaminedLength, memoRec.examinedLength);\n        self.maxRightmostFailureOffset =\n            Math.max(self.maxRightmostFailureOffset, memoRec.rightmostFailureOffset);\n      }\n    });\n  }\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = PosInfo;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Symbol = require('es6-symbol');  // eslint-disable-line no-undef\nvar inherits = require('inherits');\n\nvar InputStream = require('./InputStream');\nvar IterationNode = require('./nodes').IterationNode;\nvar MatchResult = require('./MatchResult');\nvar common = require('./common');\nvar errors = require('./errors');\nvar util = require('./util');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nvar globalActionStack = [];\nvar prototypeGrammar;\nvar prototypeGrammarSemantics;\n\n// JSON is not a valid subset of JavaScript because there are two possible line terminators,\n// U+2028 (line separator) and U+2029 (paragraph separator) that are allowed in JSON strings\n// but not in JavaScript strings.\n// jsonToJS() properly encodes those two characters in JSON so that it can seamlessly be\n// inserted into JavaScript code (plus the encoded version is still valid JSON)\nfunction jsonToJS(str) {\n  var output = str.replace(/[\\u2028\\u2029]/g, function(char, pos, str) {\n    var hex = char.codePointAt(0).toString(16);\n    return '\\\\u' + '0000'.slice(hex.length) + hex;\n  });\n  return output;\n}\n\n// ----------------- Wrappers -----------------\n\n// Wrappers decorate CST nodes with all of the functionality (i.e., operations and attributes)\n// provided by a Semantics (see below). `Wrapper` is the abstract superclass of all wrappers. A\n// `Wrapper` must have `_node` and `_semantics` instance variables, which refer to the CST node and\n// Semantics (resp.) for which it was created, and a `_childWrappers` instance variable which is\n// used to cache the wrapper instances that are created for its child nodes. Setting these instance\n// variables is the responsibility of the constructor of each Semantics-specific subclass of\n// `Wrapper`.\nfunction Wrapper() {}\n\nWrapper.prototype.toString = function() {\n  return '[semantics wrapper for ' + this._node.grammar.name + ']';\n};\n\n// This is used by ohm editor to display a node wrapper appropriately.\nWrapper.prototype.toJSON = function() {\n  return this.toString();\n};\n\nWrapper.prototype._forgetMemoizedResultFor = function(attributeName) {\n  // Remove the memoized attribute from the cstNode and all its children.\n  delete this._node[this._semantics.attributeKeys[attributeName]];\n  this.children.forEach(function(child) {\n    child._forgetMemoizedResultFor(attributeName);\n  });\n};\n\n// Returns the wrapper of the specified child node. Child wrappers are created lazily and cached in\n// the parent wrapper's `_childWrappers` instance variable.\nWrapper.prototype.child = function(idx) {\n  if (!(0 <= idx && idx < this._node.numChildren())) {\n    // TODO: Consider throwing an exception here.\n    return undefined;\n  }\n  var childWrapper = this._childWrappers[idx];\n  if (!childWrapper) {\n    var childNode = this._node.childAt(idx);\n    var offset = this._node.childOffsets[idx];\n\n    var source = this._baseInterval.subInterval(offset, childNode.matchLength);\n    var base = childNode.isNonterminal() ? source : this._baseInterval;\n    childWrapper = this._childWrappers[idx] = this._semantics.wrap(childNode, source, base);\n  }\n  return childWrapper;\n};\n\n// Returns an array containing the wrappers of all of the children of the node associated with this\n// wrapper.\nWrapper.prototype._children = function() {\n  // Force the creation of all child wrappers\n  for (var idx = 0; idx < this._node.numChildren(); idx++) {\n    this.child(idx);\n  }\n  return this._childWrappers;\n};\n\n// Returns `true` if the CST node associated with this wrapper corresponds to an iteration\n// expression, i.e., a Kleene-*, Kleene-+, or an optional. Returns `false` otherwise.\nWrapper.prototype.isIteration = function() {\n  return this._node.isIteration();\n};\n\n// Returns `true` if the CST node associated with this wrapper is a terminal node, `false`\n// otherwise.\nWrapper.prototype.isTerminal = function() {\n  return this._node.isTerminal();\n};\n\n// Returns `true` if the CST node associated with this wrapper is a nonterminal node, `false`\n// otherwise.\nWrapper.prototype.isNonterminal = function() {\n  return this._node.isNonterminal();\n};\n\n// Returns `true` if the CST node associated with this wrapper is a nonterminal node\n// corresponding to a syntactic rule, `false` otherwise.\nWrapper.prototype.isSyntactic = function() {\n  return this.isNonterminal() && this._node.isSyntactic();\n};\n\n// Returns `true` if the CST node associated with this wrapper is a nonterminal node\n// corresponding to a lexical rule, `false` otherwise.\nWrapper.prototype.isLexical = function() {\n  return this.isNonterminal() && this._node.isLexical();\n};\n\n// Returns `true` if the CST node associated with this wrapper is an iterator node\n// having either one or no child (? operator), `false` otherwise.\n// Otherwise, throws an exception.\nWrapper.prototype.isOptional = function() {\n  return this._node.isOptional();\n};\n\n// Create a new _iter wrapper in the same semantics as this wrapper.\nWrapper.prototype.iteration = function(optChildWrappers) {\n  var childWrappers = optChildWrappers || [];\n\n  var childNodes = childWrappers.map(function(c) { return c._node; });\n  var iter = new IterationNode(this._node.grammar, childNodes, [], -1, false);\n\n  var wrapper = this._semantics.wrap(iter, null, null);\n  wrapper._childWrappers = childWrappers;\n  return wrapper;\n};\n\nObject.defineProperties(Wrapper.prototype, {\n  // Returns an array containing the children of this CST node.\n  children: {get: function() { return this._children(); }},\n\n  // Returns the name of grammar rule that created this CST node.\n  ctorName: {get: function() { return this._node.ctorName; }},\n\n  // TODO: Remove this eventually (deprecated in v0.12).\n  interval: {get: function() {\n    throw new Error('The `interval` property is deprecated -- use `source` instead');\n  }},\n\n  // Returns the number of children of this CST node.\n  numChildren: {get: function() { return this._node.numChildren(); }},\n\n  // Returns the primitive value of this CST node, if it's a terminal node. Otherwise,\n  // throws an exception.\n  primitiveValue: {\n    get: function() {\n      if (this.isTerminal()) {\n        return this._node.primitiveValue;\n      }\n      throw new TypeError(\n          \"tried to access the 'primitiveValue' attribute of a non-terminal CST node\");\n    }\n  },\n\n  // Returns the contents of the input stream consumed by this CST node.\n  sourceString: {get: function() { return this.source.contents; }}\n});\n\n// ----------------- Semantics -----------------\n\n// A Semantics is a container for a family of Operations and Attributes for a given grammar.\n// Semantics enable modularity (different clients of a grammar can create their set of operations\n// and attributes in isolation) and extensibility even when operations and attributes are mutually-\n// recursive. This constructor should not be called directly except from\n// `Semantics.createSemantics`. The normal ways to create a Semantics, given a grammar 'g', are\n// `g.createSemantics()` and `g.extendSemantics(parentSemantics)`.\nfunction Semantics(grammar, superSemantics) {\n  var self = this;\n  this.grammar = grammar;\n  this.checkedActionDicts = false;\n\n  // Constructor for wrapper instances, which are passed as the arguments to the semantic actions\n  // of an operation or attribute. Operations and attributes require double dispatch: the semantic\n  // action is chosen based on both the node's type and the semantics. Wrappers ensure that\n  // the `execute` method is called with the correct (most specific) semantics object as an\n  // argument.\n  this.Wrapper = function(node, sourceInterval, baseInterval) {\n    self.checkActionDictsIfHaventAlready();\n    this._semantics = self;\n    this._node = node;\n    this.source = sourceInterval;\n\n    // The interval that the childOffsets of `node` are relative to. It should be the source\n    // of the closest Nonterminal node.\n    this._baseInterval = baseInterval;\n\n    if (node.isNonterminal()) {\n      common.assert(sourceInterval === baseInterval);\n    }\n\n    this._childWrappers = [];\n  };\n\n  this.super = superSemantics;\n  if (superSemantics) {\n    if (!(grammar.equals(this.super.grammar) || grammar._inheritsFrom(this.super.grammar))) {\n      throw new Error(\n          \"Cannot extend a semantics for grammar '\" + this.super.grammar.name +\n          \"' for use with grammar '\" + grammar.name + \"' (not a sub-grammar)\");\n    }\n    inherits(this.Wrapper, this.super.Wrapper);\n    this.operations = Object.create(this.super.operations);\n    this.attributes = Object.create(this.super.attributes);\n    this.attributeKeys = Object.create(null);\n\n    // Assign unique symbols for each of the attributes inherited from the super-semantics so that\n    // they are memoized independently.\n    for (var attributeName in this.attributes) {\n      this.attributeKeys[attributeName] = Symbol();\n    }\n  } else {\n    inherits(this.Wrapper, Wrapper);\n    this.operations = Object.create(null);\n    this.attributes = Object.create(null);\n    this.attributeKeys = Object.create(null);\n  }\n}\n\nSemantics.prototype.toString = function() {\n  return '[semantics for ' + this.grammar.name + ']';\n};\n\nSemantics.prototype.checkActionDictsIfHaventAlready = function() {\n  if (!this.checkedActionDicts) {\n    this.checkActionDicts();\n    this.checkedActionDicts = true;\n  }\n};\n\n// Checks that the action dictionaries for all operations and attributes in this semantics,\n// including the ones that were inherited from the super-semantics, agree with the grammar.\n// Throws an exception if one or more of them doesn't.\nSemantics.prototype.checkActionDicts = function() {\n  var name;\n  for (name in this.operations) {\n    this.operations[name].checkActionDict(this.grammar);\n  }\n  for (name in this.attributes) {\n    this.attributes[name].checkActionDict(this.grammar);\n  }\n};\n\nSemantics.prototype.toRecipe = function(semanticsOnly) {\n  function hasSuperSemantics(s) {\n    return s.super !== Semantics.BuiltInSemantics._getSemantics();\n  }\n\n  var str = '(function(g) {\\n';\n  if (hasSuperSemantics(this)) {\n    str += '  var semantics = ' + this.super.toRecipe(true) + '(g';\n\n    var superSemanticsGrammar = this.super.grammar;\n    var relatedGrammar = this.grammar;\n    while (relatedGrammar !== superSemanticsGrammar) {\n      str += '.superGrammar';\n      relatedGrammar = relatedGrammar.superGrammar;\n    }\n\n    str += ');\\n';\n    str += '  return g.extendSemantics(semantics)';\n  } else {\n    str += '  return g.createSemantics()';\n  }\n  ['Operation', 'Attribute'].forEach(function(type) {\n    var semanticOperations = this[type.toLowerCase() + 's'];\n    Object.keys(semanticOperations).forEach(function(name) {\n      var signature = name;\n      if (semanticOperations[name].formals.length > 0) {\n        signature += '(' + semanticOperations[name].formals.join(', ') + ')';\n      }\n\n      var method;\n      if (hasSuperSemantics(this) && this.super[type.toLowerCase() + 's'][name]) {\n        method = 'extend' + type;\n      } else {\n        method = 'add' + type;\n      }\n      str += '\\n    .' + method + '(' + JSON.stringify(signature) + ', {';\n\n      var actions = semanticOperations[name].actionDict;\n      var srcArray = [];\n      Object.keys(actions).forEach(function(actionName) {\n        if (semanticOperations[name].builtInDefault !== actions[actionName]) {\n          srcArray.push('\\n      ' + JSON.stringify(actionName) + ': ' +\n            actions[actionName].toString());\n        }\n      });\n      str += srcArray.join(',');\n\n      str += '\\n    })';\n    }, this);\n  }, this);\n  str += ';\\n  })';\n\n  if (!semanticsOnly) {\n    str =\n      '(function() {\\n' +\n      '  var grammar = this.fromRecipe(' + jsonToJS(this.grammar.toRecipe()) + ');\\n' +\n      '  var semantics = ' + str + '(grammar);\\n' +\n      '  return semantics;\\n' +\n      '});\\n';\n  }\n\n  return str;\n};\n\nfunction parseSignature(signature, type) {\n  if (!prototypeGrammar) {\n    // The Operations and Attributes grammar won't be available while Ohm is loading,\n    // but we can get away the following simplification b/c none of the operations\n    // that are used while loading take arguments.\n    common.assert(signature.indexOf('(') === -1);\n    return {\n      name: signature,\n      formals: []\n    };\n  }\n\n  var r = prototypeGrammar.match(\n      signature,\n      type === 'operation' ? 'OperationSignature' : 'AttributeSignature');\n  if (r.failed()) {\n    throw new Error(r.message);\n  }\n\n  return prototypeGrammarSemantics(r).parse();\n}\n\nfunction newDefaultAction(type, name, doIt) {\n  return function(children) {\n    var self = this;\n    var thisThing = this._semantics.operations[name] || this._semantics.attributes[name];\n    var args = thisThing.formals.map(function(formal) {\n      return self.args[formal];\n    });\n\n    if (this.isIteration()) {\n      // This CST node corresponds to an iteration expression in the grammar (*, +, or ?). The\n      // default behavior is to map this operation or attribute over all of its child nodes.\n      return children.map(function(child) { return doIt.apply(child, args); });\n    }\n\n    // This CST node corresponds to a non-terminal in the grammar (e.g., AddExpr). The fact that\n    // we got here means that this action dictionary doesn't have an action for this particular\n    // non-terminal or a generic `_nonterminal` action.\n    if (children.length === 1) {\n      // As a convenience, if this node only has one child, we just return the result of\n      // applying this operation / attribute to the child node.\n      return doIt.apply(children[0], args);\n    } else {\n      // Otherwise, we throw an exception to let the programmer know that we don't know what\n      // to do with this node.\n      throw errors.missingSemanticAction(this.ctorName, name, type, globalActionStack);\n    }\n  };\n}\n\nSemantics.prototype.addOperationOrAttribute = function(type, signature, actionDict) {\n  var typePlural = type + 's';\n\n  var parsedNameAndFormalArgs = parseSignature(signature, type);\n  var name = parsedNameAndFormalArgs.name;\n  var formals = parsedNameAndFormalArgs.formals;\n\n  // TODO: check that there are no duplicate formal arguments\n\n  this.assertNewName(name, type);\n\n  // Create the action dictionary for this operation / attribute that contains a `_default` action\n  // which defines the default behavior of iteration, terminal, and non-terminal nodes...\n  var builtInDefault = newDefaultAction(type, name, doIt);\n  var realActionDict = {_default: builtInDefault};\n  // ... and add in the actions supplied by the programmer, which may override some or all of the\n  // default ones.\n  Object.keys(actionDict).forEach(function(name) {\n    realActionDict[name] = actionDict[name];\n  });\n\n  var entry = type === 'operation' ?\n      new Operation(name, formals, realActionDict, builtInDefault) :\n      new Attribute(name, realActionDict, builtInDefault);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  entry.checkActionDict(this.grammar);\n\n  this[typePlural][name] = entry;\n\n  function doIt() {\n    // Dispatch to most specific version of this operation / attribute -- it may have been\n    // overridden by a sub-semantics.\n    var thisThing = this._semantics[typePlural][name];\n\n    // Check that the caller passed the correct number of arguments.\n    if (arguments.length !== thisThing.formals.length) {\n      throw new Error(\n          'Invalid number of arguments passed to ' + name + ' ' + type + ' (expected ' +\n          thisThing.formals.length + ', got ' + arguments.length + ')');\n    }\n\n    // Create an \"arguments object\" from the arguments that were passed to this\n    // operation / attribute.\n    var args = Object.create(null);\n    for (var idx = 0; idx < arguments.length; idx++) {\n      var formal = thisThing.formals[idx];\n      args[formal] = arguments[idx];\n    }\n\n    var oldArgs = this.args;\n    this.args = args;\n    var ans = thisThing.execute(this._semantics, this);\n    this.args = oldArgs;\n    return ans;\n  }\n\n  if (type === 'operation') {\n    this.Wrapper.prototype[name] = doIt;\n    this.Wrapper.prototype[name].toString = function() {\n      return '[' + name + ' operation]';\n    };\n  } else {\n    Object.defineProperty(this.Wrapper.prototype, name, {\n      get: doIt,\n      configurable: true  // So the property can be deleted.\n    });\n    this.attributeKeys[name] = Symbol();\n  }\n};\n\nSemantics.prototype.extendOperationOrAttribute = function(type, name, actionDict) {\n  var typePlural = type + 's';\n\n  // Make sure that `name` really is just a name, i.e., that it doesn't also contain formals.\n  parseSignature(name, 'attribute');\n\n  if (!(this.super && name in this.super[typePlural])) {\n    throw new Error('Cannot extend ' + type + \" '\" + name +\n        \"': did not inherit an \" + type + ' with that name');\n  }\n  if (Object.prototype.hasOwnProperty.call(this[typePlural], name)) {\n    throw new Error('Cannot extend ' + type + \" '\" + name + \"' again\");\n  }\n\n  // Create a new operation / attribute whose actionDict delegates to the super operation /\n  // attribute's actionDict, and which has all the keys from `inheritedActionDict`.\n  var inheritedFormals = this[typePlural][name].formals;\n  var inheritedActionDict = this[typePlural][name].actionDict;\n  var newActionDict = Object.create(inheritedActionDict);\n  Object.keys(actionDict).forEach(function(name) {\n    newActionDict[name] = actionDict[name];\n  });\n\n  this[typePlural][name] = type === 'operation' ?\n      new Operation(name, inheritedFormals, newActionDict) :\n      new Attribute(name, newActionDict);\n\n  // The following check is not strictly necessary (it will happen later anyway) but it's better to\n  // catch errors early.\n  this[typePlural][name].checkActionDict(this.grammar);\n};\n\nSemantics.prototype.assertNewName = function(name, type) {\n  if (Wrapper.prototype.hasOwnProperty(name)) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': that's a reserved name\");\n  }\n  if (name in this.operations) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an operation with that name already exists\");\n  }\n  if (name in this.attributes) {\n    throw new Error(\n        'Cannot add ' + type + \" '\" + name + \"': an attribute with that name already exists\");\n  }\n};\n\n// Returns a wrapper for the given CST `node` in this semantics.\n// If `node` is already a wrapper, returns `node` itself.  // TODO: why is this needed?\nSemantics.prototype.wrap = function(node, source, optBaseInterval) {\n  var baseInterval = optBaseInterval || source;\n  return node instanceof this.Wrapper ? node : new this.Wrapper(node, source, baseInterval);\n};\n\n// Creates a new Semantics instance for `grammar`, inheriting operations and attributes from\n// `optSuperSemantics`, if it is specified. Returns a function that acts as a proxy for the new\n// Semantics instance. When that function is invoked with a CST node as an argument, it returns\n// a wrapper for that node which gives access to the operations and attributes provided by this\n// semantics.\nSemantics.createSemantics = function(grammar, optSuperSemantics) {\n  var s = new Semantics(\n      grammar,\n      optSuperSemantics !== undefined ?\n          optSuperSemantics :\n          Semantics.BuiltInSemantics._getSemantics());\n\n  // To enable clients to invoke a semantics like a function, return a function that acts as a proxy\n  // for `s`, which is the real `Semantics` instance.\n  var proxy = function ASemantics(matchResult) {\n    if (!(matchResult instanceof MatchResult)) {\n      throw new TypeError(\n          'Semantics expected a MatchResult, but got ' + common.unexpectedObjToString(matchResult));\n    }\n    if (matchResult.failed()) {\n      throw new TypeError('cannot apply Semantics to ' + matchResult.toString());\n    }\n\n    var cst = matchResult._cst;\n    if (cst.grammar !== grammar) {\n      throw new Error(\n          \"Cannot use a MatchResult from grammar '\" + cst.grammar.name +\n          \"' with a semantics for '\" + grammar.name + \"'\");\n    }\n    var inputStream = new InputStream(matchResult.input);\n    return s.wrap(cst, inputStream.interval(matchResult._cstOffset, matchResult.input.length));\n  };\n\n  // Forward public methods from the proxy to the semantics instance.\n  proxy.addOperation = function(signature, actionDict) {\n    s.addOperationOrAttribute('operation', signature, actionDict);\n    return proxy;\n  };\n  proxy.extendOperation = function(name, actionDict) {\n    s.extendOperationOrAttribute('operation', name, actionDict);\n    return proxy;\n  };\n  proxy.addAttribute = function(name, actionDict) {\n    s.addOperationOrAttribute('attribute', name, actionDict);\n    return proxy;\n  };\n  proxy.extendAttribute = function(name, actionDict) {\n    s.extendOperationOrAttribute('attribute', name, actionDict);\n    return proxy;\n  };\n  proxy._getActionDict = function(operationOrAttributeName) {\n    var action = s.operations[operationOrAttributeName] || s.attributes[operationOrAttributeName];\n    if (!action) {\n      throw new Error('\"' + operationOrAttributeName + '\" is not a valid operation or attribute ' +\n        'name in this semantics for \"' + grammar.name + '\"');\n    }\n    return action.actionDict;\n  };\n  proxy._remove = function(operationOrAttributeName) {\n    var semantic;\n    if (operationOrAttributeName in s.operations) {\n      semantic = s.operations[operationOrAttributeName];\n      delete s.operations[operationOrAttributeName];\n    } else if (operationOrAttributeName in s.attributes) {\n      semantic = s.attributes[operationOrAttributeName];\n      delete s.attributes[operationOrAttributeName];\n    }\n    delete s.Wrapper.prototype[operationOrAttributeName];\n    return semantic;\n  };\n  proxy.getOperationNames = function() {\n    return Object.keys(s.operations);\n  };\n  proxy.getAttributeNames = function() {\n    return Object.keys(s.attributes);\n  };\n  proxy.getGrammar = function() {\n    return s.grammar;\n  };\n  proxy.toRecipe = function(semanticsOnly) {\n    return s.toRecipe(semanticsOnly);\n  };\n\n  // Make the proxy's toString() work.\n  proxy.toString = s.toString.bind(s);\n\n  // Returns the semantics for the proxy.\n  proxy._getSemantics = function() {\n    return s;\n  };\n\n  return proxy;\n};\n\n// ----------------- Operation -----------------\n\n// An Operation represents a function to be applied to a concrete syntax tree (CST) -- it's very\n// similar to a Visitor (http://en.wikipedia.org/wiki/Visitor_pattern). An operation is executed by\n// recursively walking the CST, and at each node, invoking the matching semantic action from\n// `actionDict`. See `Operation.prototype.execute` for details of how a CST node's matching semantic\n// action is found.\nfunction Operation(name, formals, actionDict, builtInDefault) {\n  this.name = name;\n  this.formals = formals;\n  this.actionDict = actionDict;\n  this.builtInDefault = builtInDefault;\n}\n\nOperation.prototype.typeName = 'operation';\n\nOperation.prototype.checkActionDict = function(grammar) {\n  grammar._checkTopDownActionDict(this.typeName, this.name, this.actionDict);\n};\n\n// Execute this operation on the CST node associated with `nodeWrapper` in the context of the given\n// Semantics instance.\nOperation.prototype.execute = function(semantics, nodeWrapper) {\n  try {\n    // Look for a semantic action whose name matches the node's constructor name, which is either\n    // the name of a rule in the grammar, or '_terminal' (for a terminal node), or '_iter' (for an\n    // iteration node). In the latter case, the action function receives a single argument, which\n    // is an array containing all of the children of the CST node.\n    var ctorName = nodeWrapper._node.ctorName;\n    var actionFn = this.actionDict[ctorName];\n    var ans;\n    if (actionFn) {\n      globalActionStack.push([this, ctorName]);\n      ans = this.doAction(semantics, nodeWrapper, actionFn, nodeWrapper.isIteration());\n      return ans;\n    }\n\n    // The action dictionary does not contain a semantic action for this specific type of node.\n    // If this is a nonterminal node and the programmer has provided a `_nonterminal` semantic\n    // action, we invoke it:\n    if (nodeWrapper.isNonterminal()) {\n      actionFn = this.actionDict._nonterminal;\n      if (actionFn) {\n        globalActionStack.push([this, '_nonterminal', ctorName]);\n        ans = this.doAction(semantics, nodeWrapper, actionFn, true);\n        return ans;\n      }\n    }\n\n    // Otherwise, we invoke the '_default' semantic action.\n    globalActionStack.push([this, 'default action', ctorName]);\n    ans = this.doAction(semantics, nodeWrapper, this.actionDict._default, true);\n    return ans;\n  } finally {\n    globalActionStack.pop();\n  }\n};\n\n// Invoke `actionFn` on the CST node that corresponds to `nodeWrapper`, in the context of\n// `semantics`. If `optPassChildrenAsArray` is truthy, `actionFn` will be called with a single\n// argument, which is an array of wrappers. Otherwise, the number of arguments to `actionFn` will\n// be equal to the number of children in the CST node.\nOperation.prototype.doAction = function(semantics, nodeWrapper, actionFn, optPassChildrenAsArray) {\n  return optPassChildrenAsArray ?\n      actionFn.call(nodeWrapper, nodeWrapper._children()) :\n      actionFn.apply(nodeWrapper, nodeWrapper._children());\n};\n\n// ----------------- Attribute -----------------\n\n// Attributes are Operations whose results are memoized. This means that, for any given semantics,\n// the semantic action for a CST node will be invoked no more than once.\nfunction Attribute(name, actionDict, builtInDefault) {\n  this.name = name;\n  this.formals = [];\n  this.actionDict = actionDict;\n  this.builtInDefault = builtInDefault;\n}\ninherits(Attribute, Operation);\n\nAttribute.prototype.typeName = 'attribute';\n\nAttribute.prototype.execute = function(semantics, nodeWrapper) {\n  var node = nodeWrapper._node;\n  var key = semantics.attributeKeys[this.name];\n  if (!node.hasOwnProperty(key)) {\n    // The following is a super-send -- isn't JS beautiful? :/\n    node[key] = Operation.prototype.execute.call(this, semantics, nodeWrapper);\n  }\n  return node[key];\n};\n\n// ----------------- Deferred initialization -----------------\n\nutil.awaitBuiltInRules(function(builtInRules) {\n  var operationsAndAttributesGrammar = require('../dist/operations-and-attributes');\n  initBuiltInSemantics(builtInRules);\n  initPrototypeParser(operationsAndAttributesGrammar);  // requires BuiltInSemantics\n});\n\nfunction initBuiltInSemantics(builtInRules) {\n  var actions = {\n    empty: function() {\n      return this.iteration();\n    },\n    nonEmpty: function(first, _, rest) {\n      return this.iteration([first].concat(rest.children));\n    }\n  };\n\n  Semantics.BuiltInSemantics = Semantics\n      .createSemantics(builtInRules, null)\n      .addOperation('asIteration', {\n        emptyListOf: actions.empty,\n        nonemptyListOf: actions.nonEmpty,\n        EmptyListOf: actions.empty,\n        NonemptyListOf: actions.nonEmpty\n      });\n}\n\nfunction initPrototypeParser(grammar) {\n  prototypeGrammarSemantics = grammar.createSemantics().addOperation('parse', {\n    AttributeSignature: function(name) {\n      return {\n        name: name.parse(),\n        formals: []\n      };\n    },\n    OperationSignature: function(name, optFormals) {\n      return {\n        name: name.parse(),\n        formals: optFormals.parse()[0] || []\n      };\n    },\n    Formals: function(oparen, fs, cparen) {\n      return fs.asIteration().parse();\n    },\n    name: function(first, rest) {\n      return this.sourceString;\n    }\n  });\n  prototypeGrammar = grammar;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Semantics;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Interval = require('./Interval');\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Unicode characters that are used in the `toString` output.\nvar BALLOT_X = '\\u2717';\nvar CHECK_MARK = '\\u2713';\nvar DOT_OPERATOR = '\\u22C5';\nvar RIGHTWARDS_DOUBLE_ARROW = '\\u21D2';\nvar SYMBOL_FOR_HORIZONTAL_TABULATION = '\\u2409';\nvar SYMBOL_FOR_LINE_FEED = '\\u240A';\nvar SYMBOL_FOR_CARRIAGE_RETURN = '\\u240D';\n\nvar Flags = {\n  succeeded: 1 << 0,\n  isRootNode: 1 << 1,\n  isImplicitSpaces: 1 << 2,\n  isMemoized: 1 << 3,\n  isHeadOfLeftRecursion: 1 << 4,\n  terminatesLR: 1 << 5\n};\n\nfunction spaces(n) {\n  return common.repeat(' ', n).join('');\n}\n\n// Return a string representation of a portion of `input` at offset `pos`.\n// The result will contain exactly `len` characters.\nfunction getInputExcerpt(input, pos, len) {\n  var excerpt = asEscapedString(input.slice(pos, pos + len));\n\n  // Pad the output if necessary.\n  if (excerpt.length < len) {\n    return excerpt + common.repeat(' ', len - excerpt.length).join('');\n  }\n  return excerpt;\n}\n\nfunction asEscapedString(obj) {\n  if (typeof obj === 'string') {\n    // Replace non-printable characters with visible symbols.\n    return obj\n        .replace(/ /g, DOT_OPERATOR)\n        .replace(/\\t/g, SYMBOL_FOR_HORIZONTAL_TABULATION)\n        .replace(/\\n/g, SYMBOL_FOR_LINE_FEED)\n        .replace(/\\r/g, SYMBOL_FOR_CARRIAGE_RETURN);\n  }\n  return String(obj);\n}\n\n// ----------------- Trace -----------------\n\nfunction Trace(input, pos1, pos2, expr, succeeded, bindings, optChildren) {\n  this.input = input;\n  this.pos = this.pos1 = pos1;\n  this.pos2 = pos2;\n  this.source = new Interval(input, pos1, pos2);\n  this.expr = expr;\n  this.bindings = bindings;\n  this.children = optChildren || [];\n  this.terminatingLREntry = null;\n\n  this._flags = succeeded ? Flags.succeeded : 0;\n}\n\n// A value that can be returned from visitor functions to indicate that a\n// node should not be recursed into.\nTrace.prototype.SKIP = {};\n\nObject.defineProperty(Trace.prototype, 'displayString', {\n  get: function() { return this.expr.toDisplayString(); }\n});\n\n// For convenience, create a getter and setter for the boolean flags in `Flags`.\nObject.keys(Flags).forEach(function(name) {\n  var mask = Flags[name];\n  Object.defineProperty(Trace.prototype, name, {\n    get: function() {\n      return (this._flags & mask) !== 0;\n    },\n    set: function(val) {\n      if (val) {\n        this._flags |= mask;\n      } else {\n        this._flags &= ~mask;\n      }\n    }\n  });\n});\n\nTrace.prototype.clone = function() {\n  return this.cloneWithExpr(this.expr);\n};\n\nTrace.prototype.cloneWithExpr = function(expr) {\n  var ans = new Trace(\n      this.input, this.pos, this.pos2, expr, this.succeeded, this.bindings, this.children);\n\n  ans.isHeadOfLeftRecursion = this.isHeadOfLeftRecursion;\n  ans.isImplicitSpaces = this.isImplicitSpaces;\n  ans.isMemoized = this.isMemoized;\n  ans.isRootNode = this.isRootNode;\n  ans.terminatesLR = this.terminatesLR;\n  ans.terminatingLREntry = this.terminatingLREntry;\n  return ans;\n};\n\n// Record the trace information for the terminating condition of the LR loop.\nTrace.prototype.recordLRTermination = function(ruleBodyTrace, value) {\n  this.terminatingLREntry =\n      new Trace(this.input, this.pos, this.pos2, this.expr, false, [value], [ruleBodyTrace]);\n  this.terminatingLREntry.terminatesLR = true;\n};\n\n// Recursively traverse this trace node and all its descendents, calling a visitor function\n// for each node that is visited. If `vistorObjOrFn` is an object, then its 'enter' property\n// is a function to call before visiting the children of a node, and its 'exit' property is\n// a function to call afterwards. If `visitorObjOrFn` is a function, it represents the 'enter'\n// function.\n//\n// The functions are called with three arguments: the Trace node, its parent Trace, and a number\n// representing the depth of the node in the tree. (The root node has depth 0.) `optThisArg`, if\n// specified, is the value to use for `this` when executing the visitor functions.\nTrace.prototype.walk = function(visitorObjOrFn, optThisArg) {\n  var visitor = visitorObjOrFn;\n  if (typeof visitor === 'function') {\n    visitor = {enter: visitor};\n  }\n\n  function _walk(node, parent, depth) {\n    var recurse = true;\n    if (visitor.enter) {\n      if (visitor.enter.call(optThisArg, node, parent, depth) === Trace.prototype.SKIP) {\n        recurse = false;\n      }\n    }\n    if (recurse) {\n      node.children.forEach(function(child) {\n        _walk(child, node, depth + 1);\n      });\n      if (visitor.exit) {\n        visitor.exit.call(optThisArg, node, parent, depth);\n      }\n    }\n  }\n  if (this.isRootNode) {\n    // Don't visit the root node itself, only its children.\n    this.children.forEach(function(c) { _walk(c, null, 0); });\n  } else {\n    _walk(this, null, 0);\n  }\n};\n\n// Return a string representation of the trace.\n// Sample:\n//     12⋅+⋅2⋅*⋅3 ✓ exp ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3   ✓ addExp (LR) ⇒  \"12\"\n//     12⋅+⋅2⋅*⋅3       ✗ addExp_plus\nTrace.prototype.toString = function() {\n  var sb = new common.StringBuffer();\n  this.walk(function(node, parent, depth) {\n    if (!node) {\n      return this.SKIP;\n    }\n    var ctorName = node.expr.constructor.name;\n    // Don't print anything for Alt nodes.\n    if (ctorName === 'Alt') {\n      return;  // eslint-disable-line consistent-return\n    }\n    sb.append(getInputExcerpt(node.input, node.pos, 10) + spaces(depth * 2 + 1));\n    sb.append((node.succeeded ? CHECK_MARK : BALLOT_X) + ' ' + node.displayString);\n    if (node.isHeadOfLeftRecursion) {\n      sb.append(' (LR)');\n    }\n    if (node.succeeded) {\n      var contents = asEscapedString(node.source.contents);\n      sb.append(' ' + RIGHTWARDS_DOUBLE_ARROW + '  ');\n      sb.append(typeof contents === 'string' ? '\"' + contents + '\"' : contents);\n    }\n    sb.append('\\n');\n  }.bind(this));\n  return sb.contents();\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = Trace;\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar extend = require('util-extend');\n\n// --------------------------------------------------------------------\n// Private Stuff\n// --------------------------------------------------------------------\n\n// Helpers\n\nvar escapeStringFor = {};\nfor (var c = 0; c < 128; c++) {\n  escapeStringFor[c] = String.fromCharCode(c);\n}\nescapeStringFor[\"'\".charCodeAt(0)] = \"\\\\'\";\nescapeStringFor['\"'.charCodeAt(0)] = '\\\\\"';\nescapeStringFor['\\\\'.charCodeAt(0)] = '\\\\\\\\';\nescapeStringFor['\\b'.charCodeAt(0)] = '\\\\b';\nescapeStringFor['\\f'.charCodeAt(0)] = '\\\\f';\nescapeStringFor['\\n'.charCodeAt(0)] = '\\\\n';\nescapeStringFor['\\r'.charCodeAt(0)] = '\\\\r';\nescapeStringFor['\\t'.charCodeAt(0)] = '\\\\t';\nescapeStringFor['\\u000b'.charCodeAt(0)] = '\\\\v';\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.abstract = function(optMethodName) {\n  var methodName = optMethodName || '';\n  return function() {\n    throw new Error(\n      'this method ' + methodName + ' is abstract! ' +\n      '(it has no implementation in class ' + this.constructor.name + ')');\n  };\n};\n\nexports.assert = function(cond, message) {\n  if (!cond) {\n    throw new Error(message);\n  }\n};\n\n// Define a lazily-computed, non-enumerable property named `propName`\n// on the object `obj`. `getterFn` will be called to compute the value the\n// first time the property is accessed.\nexports.defineLazyProperty = function(obj, propName, getterFn) {\n  var memo;\n  Object.defineProperty(obj, propName, {\n    get: function() {\n      if (!memo) {\n        memo = getterFn.call(this);\n      }\n      return memo;\n    }\n  });\n};\n\nexports.clone = function(obj) {\n  if (obj) {\n    return extend({}, obj);\n  }\n  return obj;\n};\n\nexports.extend = extend;\n\nexports.repeatFn = function(fn, n) {\n  var arr = [];\n  while (n-- > 0) {\n    arr.push(fn());\n  }\n  return arr;\n};\n\nexports.repeatStr = function(str, n) {\n  return new Array(n + 1).join(str);\n};\n\nexports.repeat = function(x, n) {\n  return exports.repeatFn(function() { return x; }, n);\n};\n\nexports.getDuplicates = function(array) {\n  var duplicates = [];\n  for (var idx = 0; idx < array.length; idx++) {\n    var x = array[idx];\n    if (array.lastIndexOf(x) !== idx && duplicates.indexOf(x) < 0) {\n      duplicates.push(x);\n    }\n  }\n  return duplicates;\n};\n\nexports.copyWithoutDuplicates = function(array) {\n  var noDuplicates = [];\n  array.forEach(function(entry) {\n    if (noDuplicates.indexOf(entry) < 0) {\n      noDuplicates.push(entry);\n    }\n  });\n  return noDuplicates;\n};\n\nexports.isSyntactic = function(ruleName) {\n  var firstChar = ruleName[0];\n  return firstChar === firstChar.toUpperCase();\n};\n\nexports.isLexical = function(ruleName) {\n  return !exports.isSyntactic(ruleName);\n};\n\nexports.padLeft = function(str, len, optChar) {\n  var ch = optChar || ' ';\n  if (str.length < len) {\n    return exports.repeatStr(ch, len - str.length) + str;\n  }\n  return str;\n};\n\n// StringBuffer\n\nexports.StringBuffer = function() {\n  this.strings = [];\n};\n\nexports.StringBuffer.prototype.append = function(str) {\n  this.strings.push(str);\n};\n\nexports.StringBuffer.prototype.contents = function() {\n  return this.strings.join('');\n};\n\n// Character escaping and unescaping\n\nexports.escapeChar = function(c, optDelim) {\n  var charCode = c.charCodeAt(0);\n  if ((c === '\"' || c === \"'\") && optDelim && c !== optDelim) {\n    return c;\n  } else if (charCode < 128) {\n    return escapeStringFor[charCode];\n  } else if (128 <= charCode && charCode < 256) {\n    return '\\\\x' + exports.padLeft(charCode.toString(16), 2, '0');\n  } else {\n    return '\\\\u' + exports.padLeft(charCode.toString(16), 4, '0');\n  }\n};\n\nexports.unescapeChar = function(s) {\n  if (s.charAt(0) === '\\\\') {\n    switch (s.charAt(1)) {\n      case 'b': return '\\b';\n      case 'f': return '\\f';\n      case 'n': return '\\n';\n      case 'r': return '\\r';\n      case 't': return '\\t';\n      case 'v': return '\\v';\n      case 'x': return String.fromCharCode(parseInt(s.substring(2, 4), 16));\n      case 'u': return String.fromCharCode(parseInt(s.substring(2, 6), 16));\n      default: return s.charAt(1);\n    }\n  } else {\n    return s;\n  }\n};\n\n// Helper for producing a description of an unknown object in a safe way.\n// Especially useful for error messages where an unexpected type of object was encountered.\nexports.unexpectedObjToString = function(obj) {\n  if (obj == null) {\n    return String(obj);\n  }\n  var baseToString = Object.prototype.toString.call(obj);\n  try {\n    var typeName;\n    if (obj.constructor && obj.constructor.name) {\n      typeName = obj.constructor.name;\n    } else if (baseToString.indexOf('[object ') === 0) {\n      typeName = baseToString.slice(8, -1);  // Extract e.g. \"Array\" from \"[object Array]\".\n    } else {\n      typeName = typeof obj;\n    }\n    return typeName + ': ' + JSON.stringify(String(obj));\n  } catch (e) {\n    return baseToString;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar pexprs = require('./pexprs');\n\nvar Namespace = require('./Namespace');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction createError(message, optInterval) {\n  var e;\n  if (optInterval) {\n    e = new Error(optInterval.getLineAndColumnMessage() + message);\n    e.shortMessage = message;\n    e.interval = optInterval;\n  } else {\n    e = new Error(message);\n  }\n  return e;\n}\n\n// ----------------- errors about intervals -----------------\n\nfunction intervalSourcesDontMatch() {\n  return createError(\"Interval sources don't match\");\n}\n\n// ----------------- errors about grammars -----------------\n\n// Grammar syntax error\n\nfunction grammarSyntaxError(matchFailure) {\n  var e = new Error();\n  Object.defineProperty(e, 'message', {get: function() { return matchFailure.message; }});\n  Object.defineProperty(e, 'shortMessage', {get: function() {\n    return 'Expected ' + matchFailure.getExpectedText();\n  }});\n  e.interval = matchFailure.getInterval();\n  return e;\n}\n\n// Undeclared grammar\n\nfunction undeclaredGrammar(grammarName, namespace, interval) {\n  var message = namespace ?\n      'Grammar ' + grammarName + ' is not declared in namespace ' + Namespace.toString(namespace) :\n      'Undeclared grammar ' + grammarName;\n  return createError(message, interval);\n}\n\n// Duplicate grammar declaration\n\nfunction duplicateGrammarDeclaration(grammar, namespace) {\n  return createError('Grammar ' + grammar.name + ' is already declared in this namespace');\n}\n\n// ----------------- rules -----------------\n\n// Undeclared rule\n\nfunction undeclaredRule(ruleName, grammarName, optInterval) {\n  return createError(\n      'Rule ' + ruleName + ' is not declared in grammar ' + grammarName,\n      optInterval);\n}\n\n// Cannot override undeclared rule\n\nfunction cannotOverrideUndeclaredRule(ruleName, grammarName, optSource) {\n  return createError(\n      'Cannot override rule ' + ruleName + ' because it is not declared in ' + grammarName,\n      optSource);\n}\n\n// Cannot extend undeclared rule\n\nfunction cannotExtendUndeclaredRule(ruleName, grammarName, optSource) {\n  return createError(\n      'Cannot extend rule ' + ruleName + ' because it is not declared in ' + grammarName,\n      optSource);\n}\n\n// Duplicate rule declaration\n\nfunction duplicateRuleDeclaration(ruleName, grammarName, declGrammarName, optSource) {\n  var message = \"Duplicate declaration for rule '\" + ruleName +\n      \"' in grammar '\" + grammarName + \"'\";\n  if (grammarName !== declGrammarName) {\n    message += \" (originally declared in '\" + declGrammarName + \"')\";\n  }\n  return createError(message, optSource);\n}\n\n// Wrong number of parameters\n\nfunction wrongNumberOfParameters(ruleName, expected, actual, source) {\n  return createError(\n      'Wrong number of parameters for rule ' + ruleName +\n          ' (expected ' + expected + ', got ' + actual + ')',\n      source);\n}\n\n// Wrong number of arguments\n\nfunction wrongNumberOfArguments(ruleName, expected, actual, expr) {\n  return createError(\n      'Wrong number of arguments for rule ' + ruleName +\n          ' (expected ' + expected + ', got ' + actual + ')',\n      expr.source);\n}\n\n// Duplicate parameter names\n\nfunction duplicateParameterNames(ruleName, duplicates, source) {\n  return createError(\n      'Duplicate parameter names in rule ' + ruleName + ': ' + duplicates.join(', '),\n      source);\n}\n\n// Invalid parameter expression\n\nfunction invalidParameter(ruleName, expr) {\n  return createError(\n      'Invalid parameter to rule ' + ruleName + ': ' + expr + ' has arity ' + expr.getArity() +\n         ', but parameter expressions must have arity 1',\n      expr.source);\n}\n\n// Application of syntactic rule from lexical rule\n\nfunction applicationOfSyntacticRuleFromLexicalContext(ruleName, applyExpr) {\n  return createError(\n      'Cannot apply syntactic rule ' + ruleName + ' from here (inside a lexical context)',\n      applyExpr.source);\n}\n\n// Incorrect argument type\n\nfunction incorrectArgumentType(expectedType, expr) {\n  return createError('Incorrect argument type: expected ' + expectedType, expr.source);\n}\n\n// ----------------- Kleene operators -----------------\n\nfunction kleeneExprHasNullableOperand(kleeneExpr, applicationStack) {\n  var actuals = applicationStack.length > 0 ?\n    applicationStack[applicationStack.length - 1].args :\n    [];\n  var expr = kleeneExpr.expr.substituteParams(actuals);\n  var message =\n    'Nullable expression ' + expr + \" is not allowed inside '\" +\n    kleeneExpr.operator + \"' (possible infinite loop)\";\n  if (applicationStack.length > 0) {\n    var stackTrace = applicationStack\n      .map(function(app) { return new pexprs.Apply(app.ruleName, app.args); })\n      .join('\\n');\n    message += '\\nApplication stack (most recent application last):\\n' + stackTrace;\n  }\n  return createError(message, kleeneExpr.expr.source);\n}\n\n// ----------------- arity -----------------\n\nfunction inconsistentArity(ruleName, expected, actual, expr) {\n  return createError(\n      'Rule ' + ruleName + ' involves an alternation which has inconsistent arity ' +\n          '(expected ' + expected + ', got ' + actual + ')',\n      expr.source);\n}\n\n// ----------------- properties -----------------\n\nfunction duplicatePropertyNames(duplicates) {\n  return createError('Object pattern has duplicate property names: ' + duplicates.join(', '));\n}\n\n// ----------------- constructors -----------------\n\nfunction invalidConstructorCall(grammar, ctorName, children) {\n  return createError(\n      'Attempt to invoke constructor ' + ctorName + ' with invalid or unexpected arguments');\n}\n\n// ----------------- convenience -----------------\n\nfunction multipleErrors(errors) {\n  var messages = errors.map(function(e) { return e.message; });\n  return createError(\n      ['Errors:'].concat(messages).join('\\n- '),\n      errors[0].interval);\n}\n\n// ----------------- semantic -----------------\n\nfunction missingSemanticAction(ctorName, name, type, stack) {\n  var stackTrace = stack.slice(0, -1).map(function(info) {\n    var ans = '  ' + info[0].name + ' > ' + info[1];\n    return info.length === 3\n        ? ans + \" for '\" + info[2] + \"'\"\n        : ans;\n  }).join('\\n');\n  stackTrace += '\\n  ' + name + ' > ' + ctorName;\n\n  var where = type + \" '\" + name + \"'\";\n  var message = \"Missing semantic action for '\" + ctorName + \"' in \" + where + '\\n' +\n                'Action stack (most recent call last):\\n' + stackTrace;\n\n  var e = createError(message);\n  e.name = 'missingSemanticAction';\n  return e;\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {\n  applicationOfSyntacticRuleFromLexicalContext: applicationOfSyntacticRuleFromLexicalContext,\n  cannotExtendUndeclaredRule: cannotExtendUndeclaredRule,\n  cannotOverrideUndeclaredRule: cannotOverrideUndeclaredRule,\n  duplicateGrammarDeclaration: duplicateGrammarDeclaration,\n  duplicateParameterNames: duplicateParameterNames,\n  duplicatePropertyNames: duplicatePropertyNames,\n  duplicateRuleDeclaration: duplicateRuleDeclaration,\n  inconsistentArity: inconsistentArity,\n  incorrectArgumentType: incorrectArgumentType,\n  intervalSourcesDontMatch: intervalSourcesDontMatch,\n  invalidConstructorCall: invalidConstructorCall,\n  invalidParameter: invalidParameter,\n  grammarSyntaxError: grammarSyntaxError,\n  kleeneExprHasNullableOperand: kleeneExprHasNullableOperand,\n  missingSemanticAction: missingSemanticAction,\n  undeclaredGrammar: undeclaredGrammar,\n  undeclaredRule: undeclaredRule,\n  wrongNumberOfArguments: wrongNumberOfArguments,\n  wrongNumberOfParameters: wrongNumberOfParameters,\n\n  throwErrors: function(errors) {\n    if (errors.length === 1) {\n      throw errors[0];\n    }\n    if (errors.length > 1) {\n      throw multipleErrors(errors);\n    }\n  }\n};\n","/* global document, XMLHttpRequest */\n\n'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Builder = require('./Builder');\nvar Grammar = require('./Grammar');\nvar Namespace = require('./Namespace');\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\nvar util = require('./util');\nvar version = require('./version');\n\nvar isBuffer = require('is-buffer');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// The metagrammar, i.e. the grammar for Ohm grammars. Initialized at the\n// bottom of this file because loading the grammar requires Ohm itself.\nvar ohmGrammar;\n\n// An object which makes it possible to stub out the document API for testing.\nvar documentInterface = {\n  querySelector: function(sel) { return document.querySelector(sel); },\n  querySelectorAll: function(sel) { return document.querySelectorAll(sel); }\n};\n\n// Check if `obj` is a DOM element.\nfunction isElement(obj) {\n  return !!(obj && obj.nodeType === 1);\n}\n\nfunction isUndefined(obj) {\n  return obj === void 0;  // eslint-disable-line no-void\n}\n\nvar MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;\n\nfunction isArrayLike(obj) {\n  if (obj == null) {\n    return false;\n  }\n  var length = obj.length;\n  return typeof length === 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;\n}\n\n// TODO: just use the jQuery thing\nfunction load(url) {\n  var req = new XMLHttpRequest();\n  req.open('GET', url, false);\n  try {\n    req.send();\n    if (req.status === 0 || req.status === 200) {\n      return req.responseText;\n    }\n  } catch (e) {}\n  throw new Error('unable to load url ' + url);\n}\n\n// Returns a Grammar instance (i.e., an object with a `match` method) for\n// `tree`, which is the concrete syntax tree of a user-written grammar.\n// The grammar will be assigned into `namespace` under the name of the grammar\n// as specified in the source.\nfunction buildGrammar(match, namespace, optOhmGrammarForTesting) {\n  var builder = new Builder();\n  var decl;\n  var currentRuleName;\n  var currentRuleFormals;\n  var overriding = false;\n  var metaGrammar = optOhmGrammarForTesting || ohmGrammar;\n\n  // A visitor that produces a Grammar instance from the CST.\n  var helpers = metaGrammar.createSemantics().addOperation('visit', {\n    Grammar: function(n, s, open, rs, close) {\n      var grammarName = n.visit();\n      decl = builder.newGrammar(grammarName, namespace);\n      s.visit();\n      rs.visit();\n      var g = decl.build();\n      g.source = this.source.trimmed();\n      if (grammarName in namespace) {\n        throw errors.duplicateGrammarDeclaration(g, namespace);\n      }\n      namespace[grammarName] = g;\n      return g;\n    },\n\n    SuperGrammar: function(_, n) {\n      var superGrammarName = n.visit();\n      if (superGrammarName === 'null') {\n        decl.withSuperGrammar(null);\n      } else {\n        if (!namespace || !(superGrammarName in namespace)) {\n          throw errors.undeclaredGrammar(superGrammarName, namespace, n.source);\n        }\n        decl.withSuperGrammar(namespace[superGrammarName]);\n      }\n    },\n\n    Rule_define: function(n, fs, d, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      // If there is no default start rule yet, set it now. This must be done before visiting\n      // the body, because it might contain an inline rule definition.\n      if (!decl.defaultStartRule && decl.ensureSuperGrammar() !== Grammar.ProtoBuiltInRules) {\n        decl.withDefaultStartRule(currentRuleName);\n      }\n      var body = b.visit();\n      var description = d.visit()[0];\n      var source = this.source.trimmed();\n      return decl.define(currentRuleName, currentRuleFormals, body, description, source);\n    },\n    Rule_override: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      overriding = true;\n      var body = b.visit();\n      var source = this.source.trimmed();\n      var ans = decl.override(currentRuleName, currentRuleFormals, body, null, source);\n      overriding = false;\n      return ans;\n    },\n    Rule_extend: function(n, fs, _, b) {\n      currentRuleName = n.visit();\n      currentRuleFormals = fs.visit()[0] || [];\n      var body = b.visit();\n      var source = this.source.trimmed();\n      var ans = decl.extend(currentRuleName, currentRuleFormals, body, null, source);\n      return ans;\n    },\n    RuleBody: function(_, terms) {\n      var args = terms.visit();\n      return builder.alt.apply(builder, args).withSource(this.source);\n    },\n\n    Formals: function(opointy, fs, cpointy) {\n      return fs.visit();\n    },\n\n    Params: function(opointy, ps, cpointy) {\n      return ps.visit();\n    },\n\n    Alt: function(seqs) {\n      var args = seqs.visit();\n      return builder.alt.apply(builder, args).withSource(this.source);\n    },\n\n    TopLevelTerm_inline: function(b, n) {\n      var inlineRuleName = currentRuleName + '_' + n.visit();\n      var body = b.visit();\n      var source = this.source.trimmed();\n      var isNewRuleDeclaration =\n          !(decl.superGrammar && decl.superGrammar.rules[inlineRuleName]);\n      if (overriding && !isNewRuleDeclaration) {\n        decl.override(inlineRuleName, currentRuleFormals, body, null, source);\n      } else {\n        decl.define(inlineRuleName, currentRuleFormals, body, null, source);\n      }\n      var params = currentRuleFormals.map(function(formal) { return builder.app(formal); });\n      return builder.app(inlineRuleName, params).withSource(body.source);\n    },\n\n    Seq: function(expr) {\n      return builder.seq.apply(builder, expr.visit()).withSource(this.source);\n    },\n\n    Iter_star: function(x, _) {\n      return builder.star(x.visit()).withSource(this.source);\n    },\n    Iter_plus: function(x, _) {\n      return builder.plus(x.visit()).withSource(this.source);\n    },\n    Iter_opt: function(x, _) {\n      return builder.opt(x.visit()).withSource(this.source);\n    },\n\n    Pred_not: function(_, x) {\n      return builder.not(x.visit()).withSource(this.source);\n    },\n    Pred_lookahead: function(_, x) {\n      return builder.lookahead(x.visit()).withSource(this.source);\n    },\n\n    Lex_lex: function(_, x) {\n      return builder.lex(x.visit()).withSource(this.source);\n    },\n\n    Base_application: function(rule, ps) {\n      return builder.app(rule.visit(), ps.visit()[0] || []).withSource(this.source);\n    },\n    Base_range: function(from, _, to) {\n      return builder.range(from.visit(), to.visit()).withSource(this.source);\n    },\n    Base_terminal: function(expr) {\n      return builder.terminal(expr.visit()).withSource(this.source);\n    },\n    Base_paren: function(open, x, close) {\n      return x.visit();\n    },\n\n    ruleDescr: function(open, t, close) {\n      return t.visit();\n    },\n    ruleDescrText: function(_) {\n      return this.sourceString.trim();\n    },\n\n    caseName: function(_, space1, n, space2, end) {\n      return n.visit();\n    },\n\n    name: function(first, rest) {\n      return this.sourceString;\n    },\n    nameFirst: function(expr) {},\n    nameRest: function(expr) {},\n\n    terminal: function(open, cs, close) {\n      return cs.visit().join('');\n    },\n\n    oneCharTerminal: function(open, c, close) {\n      return c.visit();\n    },\n\n    terminalChar: function(_) {\n      return common.unescapeChar(this.sourceString);\n    },\n\n    escapeChar: function(_) {\n      return this.sourceString;\n    },\n\n    NonemptyListOf: function(x, _, xs) {\n      return [x.visit()].concat(xs.visit());\n    },\n    EmptyListOf: function() {\n      return [];\n    },\n\n    _terminal: function() {\n      return this.primitiveValue;\n    }\n  });\n  return helpers(match).visit();\n}\n\nfunction compileAndLoad(source, namespace) {\n  var m = ohmGrammar.match(source, 'Grammars');\n  if (m.failed()) {\n    throw errors.grammarSyntaxError(m);\n  }\n  return buildGrammar(m, namespace);\n}\n\n// Return the contents of a script element, fetching it via XHR if necessary.\nfunction getScriptElementContents(el) {\n  if (!isElement(el)) {\n    throw new TypeError('Expected a DOM Node, got ' + common.unexpectedObjToString(el));\n  }\n  if (el.type !== 'text/ohm-js') {\n    throw new Error('Expected a script tag with type=\"text/ohm-js\", got ' + el);\n  }\n  return el.getAttribute('src') ? load(el.getAttribute('src')) : el.innerHTML;\n}\n\nfunction grammar(source, optNamespace) {\n  var ns = grammars(source, optNamespace);\n\n  // Ensure that the source contained no more than one grammar definition.\n  var grammarNames = Object.keys(ns);\n  if (grammarNames.length === 0) {\n    throw new Error('Missing grammar definition');\n  } else if (grammarNames.length > 1) {\n    var secondGrammar = ns[grammarNames[1]];\n    var interval = secondGrammar.source;\n    throw new Error(\n        util.getLineAndColumnMessage(interval.sourceString, interval.startIdx) +\n        'Found more than one grammar definition -- use ohm.grammars() instead.');\n  }\n  return ns[grammarNames[0]];  // Return the one and only grammar.\n}\n\nfunction grammars(source, optNamespace) {\n  var ns = Namespace.extend(Namespace.asNamespace(optNamespace));\n  if (typeof source !== 'string') {\n    // For convenience, detect Node.js Buffer objects and automatically call toString().\n    if (isBuffer(source)) {\n      source = source.toString();\n    } else {\n      throw new TypeError(\n          'Expected string as first argument, got ' + common.unexpectedObjToString(source));\n    }\n  }\n  compileAndLoad(source, ns);\n  return ns;\n}\n\nfunction grammarFromScriptElement(optNode) {\n  var node = optNode;\n  if (isUndefined(node)) {\n    var nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n    if (nodeList.length !== 1) {\n      throw new Error(\n          'Expected exactly one script tag with type=\"text/ohm-js\", found ' + nodeList.length);\n    }\n    node = nodeList[0];\n  }\n  return grammar(getScriptElementContents(node));\n}\n\nfunction grammarsFromScriptElements(optNodeOrNodeList) {\n  // Simple case: the argument is a DOM node.\n  if (isElement(optNodeOrNodeList)) {\n    return grammars(optNodeOrNodeList);\n  }\n  // Otherwise, it must be either undefined or a NodeList.\n  var nodeList = optNodeOrNodeList;\n  if (isUndefined(nodeList)) {\n    // Find all script elements with type=\"text/ohm-js\".\n    nodeList = documentInterface.querySelectorAll('script[type=\"text/ohm-js\"]');\n  } else if (typeof nodeList === 'string' || (!isElement(nodeList) && !isArrayLike(nodeList))) {\n    throw new TypeError('Expected a Node, NodeList, or Array, but got ' + nodeList);\n  }\n  var ns = Namespace.createNamespace();\n  for (var i = 0; i < nodeList.length; ++i) {\n    // Copy the new grammars into `ns` to keep the namespace flat.\n    common.extend(ns, grammars(getScriptElementContents(nodeList[i]), ns));\n  }\n  return ns;\n}\n\nfunction makeRecipe(recipe) {\n  if (typeof recipe === 'function') {\n    return recipe.call(new Builder());\n  } else {\n    if (typeof recipe === 'string') {\n      // stringified JSON recipe\n      recipe = JSON.parse(recipe);\n    }\n    return (new Builder()).fromRecipe(recipe);\n  }\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\n// Stuff that users should know about\nmodule.exports = {\n  createNamespace: Namespace.createNamespace,\n  grammar: grammar,\n  grammars: grammars,\n  grammarFromScriptElement: grammarFromScriptElement,\n  grammarsFromScriptElements: grammarsFromScriptElements,\n  makeRecipe: makeRecipe,\n  ohmGrammar: null,  // Initialized below, after Grammar.BuiltInRules.\n  pexprs: pexprs,\n  util: util,\n  extras: require('../extras'),\n  version: version\n};\n\n// Stuff for testing, etc.\nmodule.exports._buildGrammar = buildGrammar;\nmodule.exports._setDocumentInterfaceForTesting = function(doc) { documentInterface = doc; };\n\n// Late initialization for stuff that is bootstrapped.\n\nGrammar.BuiltInRules = require('../dist/built-in-rules');\nutil.announceBuiltInRules(Grammar.BuiltInRules);\n\nmodule.exports.ohmGrammar = ohmGrammar = require('../dist/ohm-grammar');\nGrammar.initApplicationParser(ohmGrammar, buildGrammar);\n","'use strict';\n\nvar inherits = require('inherits');\n\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction Node(grammar, ctorName, matchLength) {\n  this.grammar = grammar;\n  this.ctorName = ctorName;\n  this.matchLength = matchLength;\n}\n\nNode.prototype.numChildren = function() {\n  return this.children ? this.children.length : 0;\n};\n\nNode.prototype.childAt = function(idx) {\n  if (this.children) {\n    return this.children[idx];\n  }\n};\n\nNode.prototype.indexOfChild = function(arg) {\n  return this.children.indexOf(arg);\n};\n\nNode.prototype.hasChildren = function() {\n  return this.numChildren() > 1;\n};\n\nNode.prototype.hasNoChildren = function() {\n  return !this.hasChildren();\n};\n\nNode.prototype.onlyChild = function() {\n  if (this.numChildren() !== 1) {\n    throw new Error(\n        'cannot get only child of a node of type ' + this.ctorName +\n        ' (it has ' + this.numChildren() + ' children)');\n  } else {\n    return this.firstChild();\n  }\n};\n\nNode.prototype.firstChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get first child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(0);\n  }\n};\n\nNode.prototype.lastChild = function() {\n  if (this.hasNoChildren()) {\n    throw new Error(\n        'cannot get last child of a ' + this.ctorName + ' node, which has no children');\n  } else {\n    return this.childAt(this.numChildren() - 1);\n  }\n};\n\nNode.prototype.childBefore = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childBefore() called w/ an argument that is not a child');\n  } else if (childIdx === 0) {\n    throw new Error('cannot get child before first child');\n  } else {\n    return this.childAt(childIdx - 1);\n  }\n};\n\nNode.prototype.childAfter = function(child) {\n  var childIdx = this.indexOfChild(child);\n  if (childIdx < 0) {\n    throw new Error('Node.childAfter() called w/ an argument that is not a child');\n  } else if (childIdx === this.numChildren() - 1) {\n    throw new Error('cannot get child after last child');\n  } else {\n    return this.childAt(childIdx + 1);\n  }\n};\n\nNode.prototype.isTerminal = function() {\n  return false;\n};\n\nNode.prototype.isNonterminal = function() {\n  return false;\n};\n\nNode.prototype.isIteration = function() {\n  return false;\n};\n\nNode.prototype.isOptional = function() {\n  return false;\n};\n\nNode.prototype.toJSON = function() {\n  var r = {};\n  r[this.ctorName] = this.children;\n  return r;\n};\n\n// Terminals\n\nfunction TerminalNode(grammar, value) {\n  var matchLength = value ? value.length : 0;\n  Node.call(this, grammar, '_terminal', matchLength);\n  this.primitiveValue = value;\n}\ninherits(TerminalNode, Node);\n\nTerminalNode.prototype.isTerminal = function() {\n  return true;\n};\n\nTerminalNode.prototype.toJSON = function() {\n  var r = {};\n  r[this.ctorName] = this.primitiveValue;\n  return r;\n};\n\n// Nonterminals\n\nfunction NonterminalNode(grammar, ruleName, children, childOffsets, matchLength) {\n  Node.call(this, grammar, ruleName, matchLength);\n  this.children = children;\n  this.childOffsets = childOffsets;\n}\ninherits(NonterminalNode, Node);\n\nNonterminalNode.prototype.isNonterminal = function() {\n  return true;\n};\n\nNonterminalNode.prototype.isLexical = function() {\n  return common.isLexical(this.ctorName);\n};\n\nNonterminalNode.prototype.isSyntactic = function() {\n  return common.isSyntactic(this.ctorName);\n};\n\n// Iterations\n\nfunction IterationNode(grammar, children, childOffsets, matchLength, isOptional) {\n  Node.call(this, grammar, '_iter', matchLength);\n  this.children = children;\n  this.childOffsets = childOffsets;\n  this.optional = isOptional;\n}\ninherits(IterationNode, Node);\n\nIterationNode.prototype.isIteration = function() {\n  return true;\n};\n\nIterationNode.prototype.isOptional = function() {\n  return this.optional;\n};\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nmodule.exports = {\n  Node: Node,\n  TerminalNode: TerminalNode,\n  NonterminalNode: NonterminalNode,\n  IterationNode: IterationNode\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  Return true if we should skip spaces preceding this expression in a syntactic context.\n*/\npexprs.PExpr.prototype.allowsSkippingPrecedingSpace = common.abstract(\n  'allowsSkippingPrecedingSpace'\n);\n\n/*\n  Generally, these are all first-order expressions and (with the exception of Apply)\n  directly read from the input stream.\n*/\npexprs.any.allowsSkippingPrecedingSpace =\npexprs.end.allowsSkippingPrecedingSpace =\npexprs.Apply.prototype.allowsSkippingPrecedingSpace =\npexprs.Terminal.prototype.allowsSkippingPrecedingSpace =\npexprs.Range.prototype.allowsSkippingPrecedingSpace =\npexprs.UnicodeChar.prototype.allowsSkippingPrecedingSpace = function() {\n  return true;\n};\n\n/*\n  Higher-order expressions that don't directly consume input.\n*/\npexprs.Alt.prototype.allowsSkippingPrecedingSpace =\npexprs.Iter.prototype.allowsSkippingPrecedingSpace =\npexprs.Lex.prototype.allowsSkippingPrecedingSpace =\npexprs.Lookahead.prototype.allowsSkippingPrecedingSpace =\npexprs.Not.prototype.allowsSkippingPrecedingSpace =\npexprs.Param.prototype.allowsSkippingPrecedingSpace =\npexprs.Seq.prototype.allowsSkippingPrecedingSpace = function() {\n  return false;\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\nvar util = require('./util');\n\nvar BuiltInRules;\n\nutil.awaitBuiltInRules(function(g) { BuiltInRules = g; });\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\nvar lexifyCount;\n\npexprs.PExpr.prototype.assertAllApplicationsAreValid = function(ruleName, grammar) {\n  lexifyCount = 0;\n  this._assertAllApplicationsAreValid(ruleName, grammar);\n};\n\npexprs.PExpr.prototype._assertAllApplicationsAreValid = common.abstract(\n  '_assertAllApplicationsAreValid'\n);\n\npexprs.any._assertAllApplicationsAreValid =\npexprs.end._assertAllApplicationsAreValid =\npexprs.Terminal.prototype._assertAllApplicationsAreValid =\npexprs.Range.prototype._assertAllApplicationsAreValid =\npexprs.Param.prototype._assertAllApplicationsAreValid =\npexprs.UnicodeChar.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  // no-op\n};\n\npexprs.Lex.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  lexifyCount++;\n  this.expr._assertAllApplicationsAreValid(ruleName, grammar);\n  lexifyCount--;\n};\n\npexprs.Alt.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx]._assertAllApplicationsAreValid(ruleName, grammar);\n  }\n};\n\npexprs.Seq.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx]._assertAllApplicationsAreValid(ruleName, grammar);\n  }\n};\n\npexprs.Iter.prototype._assertAllApplicationsAreValid =\npexprs.Not.prototype._assertAllApplicationsAreValid =\npexprs.Lookahead.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  this.expr._assertAllApplicationsAreValid(ruleName, grammar);\n};\n\npexprs.Apply.prototype._assertAllApplicationsAreValid = function(ruleName, grammar) {\n  var ruleInfo = grammar.rules[this.ruleName];\n\n  // Make sure that the rule exists...\n  if (!ruleInfo) {\n    throw errors.undeclaredRule(this.ruleName, grammar.name, this.source);\n  }\n\n  // ...and that this application is allowed\n  if (common.isSyntactic(this.ruleName) && (!common.isSyntactic(ruleName) || lexifyCount > 0)) {\n    throw errors.applicationOfSyntacticRuleFromLexicalContext(this.ruleName, this);\n  }\n\n  // ...and that this application has the correct number of arguments\n  var actual = this.args.length;\n  var expected = ruleInfo.formals.length;\n  if (actual !== expected) {\n    throw errors.wrongNumberOfArguments(this.ruleName, expected, actual, this.source);\n  }\n\n  // ...and that all of the argument expressions only have valid applications and have arity 1.\n  var self = this;\n  this.args.forEach(function(arg) {\n    arg._assertAllApplicationsAreValid(ruleName, grammar);\n    if (arg.getArity() !== 1) {\n      throw errors.invalidParameter(self.ruleName, arg);\n    }\n  });\n\n  // Extra checks for \"special\" applications\n\n  // If it's an application of 'caseInsensitive', ensure that the argument is a Terminal.\n  if (BuiltInRules && ruleInfo === BuiltInRules.rules.caseInsensitive) {\n    if (!(this.args[0] instanceof pexprs.Terminal)) {\n      throw errors.incorrectArgumentType('a Terminal (e.g. \\\"abc\\\")', this.args[0]);\n    }\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertChoicesHaveUniformArity = common.abstract(\n  'assertChoicesHaveUniformArity'\n);\n\npexprs.any.assertChoicesHaveUniformArity =\npexprs.end.assertChoicesHaveUniformArity =\npexprs.Terminal.prototype.assertChoicesHaveUniformArity =\npexprs.Range.prototype.assertChoicesHaveUniformArity =\npexprs.Param.prototype.assertChoicesHaveUniformArity =\npexprs.Lex.prototype.assertChoicesHaveUniformArity =\npexprs.UnicodeChar.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  if (this.terms.length === 0) {\n    return;\n  }\n  var arity = this.terms[0].getArity();\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    var term = this.terms[idx];\n    term.assertChoicesHaveUniformArity();\n    var otherArity = term.getArity();\n    if (arity !== otherArity) {\n      throw errors.inconsistentArity(ruleName, arity, otherArity, term);\n    }\n  }\n};\n\npexprs.Extend.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // Extend is a special case of Alt that's guaranteed to have exactly two\n  // cases: [extensions, origBody].\n  var actualArity = this.terms[0].getArity();\n  var expectedArity = this.terms[1].getArity();\n  if (actualArity !== expectedArity) {\n    throw errors.inconsistentArity(ruleName, expectedArity, actualArity, this.terms[0]);\n  }\n};\n\npexprs.Seq.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertChoicesHaveUniformArity(ruleName);\n  }\n};\n\npexprs.Iter.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Not.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // no-op (not required b/c the nested expr doesn't show up in the CST)\n};\n\npexprs.Lookahead.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  this.expr.assertChoicesHaveUniformArity(ruleName);\n};\n\npexprs.Apply.prototype.assertChoicesHaveUniformArity = function(ruleName) {\n  // The arities of the parameter expressions is required to be 1 by\n  // `assertAllApplicationsAreValid()`.\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar errors = require('./errors');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.assertIteratedExprsAreNotNullable = common.abstract(\n  'assertIteratedExprsAreNotNullable'\n);\n\npexprs.any.assertIteratedExprsAreNotNullable =\npexprs.end.assertIteratedExprsAreNotNullable =\npexprs.Terminal.prototype.assertIteratedExprsAreNotNullable =\npexprs.Range.prototype.assertIteratedExprsAreNotNullable =\npexprs.Param.prototype.assertIteratedExprsAreNotNullable =\npexprs.UnicodeChar.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  // no-op\n};\n\npexprs.Alt.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    this.terms[idx].assertIteratedExprsAreNotNullable(grammar);\n  }\n};\n\npexprs.Seq.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    this.factors[idx].assertIteratedExprsAreNotNullable(grammar);\n  }\n};\n\npexprs.Iter.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  // Note: this is the implementation of this method for `Star` and `Plus` expressions.\n  // It is overridden for `Opt` below.\n  this.expr.assertIteratedExprsAreNotNullable(grammar);\n  if (this.expr.isNullable(grammar)) {\n    throw errors.kleeneExprHasNullableOperand(this, []);\n  }\n};\n\npexprs.Opt.prototype.assertIteratedExprsAreNotNullable =\npexprs.Not.prototype.assertIteratedExprsAreNotNullable =\npexprs.Lookahead.prototype.assertIteratedExprsAreNotNullable =\npexprs.Lex.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  this.expr.assertIteratedExprsAreNotNullable(grammar);\n};\n\npexprs.Apply.prototype.assertIteratedExprsAreNotNullable = function(grammar) {\n  this.args.forEach(function(arg) {\n    arg.assertIteratedExprsAreNotNullable(grammar);\n  });\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.check = common.abstract('check');\n\npexprs.any.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.end.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === undefined;\n};\n\npexprs.Terminal.prototype.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         vals[0].primitiveValue === this.obj;\n};\n\npexprs.Range.prototype.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         typeof vals[0].primitiveValue === typeof this.from;\n};\n\npexprs.Param.prototype.check = function(grammar, vals) {\n  return vals.length >= 1;\n};\n\npexprs.Alt.prototype.check = function(grammar, vals) {\n  for (var i = 0; i < this.terms.length; i++) {\n    var term = this.terms[i];\n    if (term.check(grammar, vals)) {\n      return true;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype.check = function(grammar, vals) {\n  var pos = 0;\n  for (var i = 0; i < this.factors.length; i++) {\n    var factor = this.factors[i];\n    if (factor.check(grammar, vals.slice(pos))) {\n      pos += factor.getArity();\n    } else {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype.check = function(grammar, vals) {\n  var arity = this.getArity();\n  var columns = vals.slice(0, arity);\n  if (columns.length !== arity) {\n    return false;\n  }\n  var rowCount = columns[0].length;\n  var i;\n  for (i = 1; i < arity; i++) {\n    if (columns[i].length !== rowCount) {\n      return false;\n    }\n  }\n\n  for (i = 0; i < rowCount; i++) {\n    var row = [];\n    for (var j = 0; j < arity; j++) {\n      row.push(columns[j][i]);\n    }\n    if (!this.expr.check(grammar, row)) {\n      return false;\n    }\n  }\n\n  return true;\n};\n\npexprs.Not.prototype.check = function(grammar, vals) {\n  return true;\n};\n\npexprs.Lookahead.prototype.check =\npexprs.Lex.prototype.check = function(grammar, vals) {\n  return this.expr.check(grammar, vals);\n};\n\npexprs.Apply.prototype.check = function(grammar, vals) {\n  if (!(vals[0] instanceof nodes.Node &&\n        vals[0].grammar === grammar &&\n        vals[0].ctorName === this.ruleName)) {\n    return false;\n  }\n\n  // TODO: think about *not* doing the following checks, i.e., trusting that the rule\n  // was correctly constructed.\n  var ruleNode = vals[0];\n  var body = grammar.rules[this.ruleName].body;\n  return body.check(grammar, ruleNode.children) && ruleNode.numChildren() === body.getArity();\n};\n\npexprs.UnicodeChar.prototype.check = function(grammar, vals) {\n  return vals[0] instanceof nodes.Node &&\n         vals[0].isTerminal() &&\n         typeof vals[0].primitiveValue === 'string';\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Trace = require('./Trace');\nvar common = require('./common');\nvar errors = require('./errors');\nvar nodes = require('./nodes');\nvar pexprs = require('./pexprs');\n\nvar TerminalNode = nodes.TerminalNode;\nvar NonterminalNode = nodes.NonterminalNode;\nvar IterationNode = nodes.IterationNode;\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  Evaluate the expression and return `true` if it succeeds, `false` otherwise. This method should\n  only be called directly by `State.prototype.eval(expr)`, which also updates the data structures\n  that are used for tracing. (Making those updates in a method of `State` enables the trace-specific\n  data structures to be \"secrets\" of that class, which is good for modularity.)\n\n  The contract of this method is as follows:\n  * When the return value is `true`,\n    - the state object will have `expr.getArity()` more bindings than it did before the call.\n  * When the return value is `false`,\n    - the state object may have more bindings than it did before the call, and\n    - its input stream's position may be anywhere.\n\n  Note that `State.prototype.eval(expr)`, unlike this method, guarantees that neither the state\n  object's bindings nor its input stream's position will change if the expression fails to match.\n*/\npexprs.PExpr.prototype.eval = common.abstract('eval');  // function(state) { ... }\n\npexprs.any.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  var ch = inputStream.next();\n  if (ch) {\n    state.pushBinding(new TerminalNode(state.grammar, ch), origPos);\n    return true;\n  } else {\n    state.processFailure(origPos, this);\n    return false;\n  }\n};\n\npexprs.end.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  if (inputStream.atEnd()) {\n    state.pushBinding(new TerminalNode(state.grammar, undefined), origPos);\n    return true;\n  } else {\n    state.processFailure(origPos, this);\n    return false;\n  }\n};\n\npexprs.Terminal.prototype.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  if (!inputStream.matchString(this.obj)) {\n    state.processFailure(origPos, this);\n    return false;\n  } else {\n    state.pushBinding(new TerminalNode(state.grammar, this.obj), origPos);\n    return true;\n  }\n};\n\npexprs.Range.prototype.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  var ch = inputStream.next();\n  if (ch && this.from <= ch && ch <= this.to) {\n    state.pushBinding(new TerminalNode(state.grammar, ch), origPos);\n    return true;\n  } else {\n    state.processFailure(origPos, this);\n    return false;\n  }\n};\n\npexprs.Param.prototype.eval = function(state) {\n  return state.eval(state.currentApplication().args[this.index]);\n};\n\npexprs.Lex.prototype.eval = function(state) {\n  state.enterLexifiedContext();\n  var ans = state.eval(this.expr);\n  state.exitLexifiedContext();\n  return ans;\n};\n\npexprs.Alt.prototype.eval = function(state) {\n  for (var idx = 0; idx < this.terms.length; idx++) {\n    if (state.eval(this.terms[idx])) {\n      return true;\n    }\n  }\n  return false;\n};\n\npexprs.Seq.prototype.eval = function(state) {\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    var factor = this.factors[idx];\n    if (!state.eval(factor)) {\n      return false;\n    }\n  }\n  return true;\n};\n\npexprs.Iter.prototype.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  var arity = this.getArity();\n  var cols = [];\n  var colOffsets = [];\n  while (cols.length < arity) {\n    cols.push([]);\n    colOffsets.push([]);\n  }\n\n  var numMatches = 0;\n  var prevPos = origPos;\n  var idx;\n  while (numMatches < this.maxNumMatches && state.eval(this.expr)) {\n    if (inputStream.pos === prevPos) {\n      throw errors.kleeneExprHasNullableOperand(this, state._applicationStack);\n    }\n    prevPos = inputStream.pos;\n    numMatches++;\n    var row = state._bindings.splice(state._bindings.length - arity, arity);\n    var rowOffsets = state._bindingOffsets.splice(state._bindingOffsets.length - arity, arity);\n    for (idx = 0; idx < row.length; idx++) {\n      cols[idx].push(row[idx]);\n      colOffsets[idx].push(rowOffsets[idx]);\n    }\n  }\n  if (numMatches < this.minNumMatches) {\n    return false;\n  }\n  var offset = state.posToOffset(origPos);\n  var matchLength = 0;\n  if (numMatches > 0) {\n    var lastCol = cols[arity - 1];\n    var lastColOffsets = colOffsets[arity - 1];\n\n    var endOffset =\n        lastColOffsets[lastColOffsets.length - 1] + lastCol[lastCol.length - 1].matchLength;\n    offset = colOffsets[0][0];\n    matchLength = endOffset - offset;\n  }\n  var isOptional = this instanceof pexprs.Opt;\n  for (idx = 0; idx < cols.length; idx++) {\n    state._bindings.push(\n        new IterationNode(state.grammar, cols[idx], colOffsets[idx], matchLength, isOptional));\n    state._bindingOffsets.push(offset);\n  }\n  return true;\n};\n\npexprs.Not.prototype.eval = function(state) {\n  /*\n    TODO:\n    - Right now we're just throwing away all of the failures that happen inside a `not`, and\n      recording `this` as a failed expression.\n    - Double negation should be equivalent to lookahead, but that's not the case right now wrt\n      failures. E.g., ~~'foo' produces a failure for ~~'foo', but maybe it should produce\n      a failure for 'foo' instead.\n  */\n\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  state.pushFailuresInfo();\n\n  var ans = state.eval(this.expr);\n\n  state.popFailuresInfo();\n  if (ans) {\n    state.processFailure(origPos, this);\n    return false;\n  }\n\n  inputStream.pos = origPos;\n  return true;\n};\n\npexprs.Lookahead.prototype.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  if (state.eval(this.expr)) {\n    inputStream.pos = origPos;\n    return true;\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype.eval = function(state) {\n  var caller = state.currentApplication();\n  var actuals = caller ? caller.args : [];\n  var app = this.substituteParams(actuals);\n\n  var posInfo = state.getCurrentPosInfo();\n  if (posInfo.isActive(app)) {\n    // This rule is already active at this position, i.e., it is left-recursive.\n    return app.handleCycle(state);\n  }\n\n  var memoKey = app.toMemoKey();\n  var memoRec = posInfo.memo[memoKey];\n\n  if (memoRec && posInfo.shouldUseMemoizedResult(memoRec)) {\n    if (state.hasNecessaryInfo(memoRec)) {\n      return state.useMemoizedResult(state.inputStream.pos, memoRec);\n    }\n    delete posInfo.memo[memoKey];\n  }\n  return app.reallyEval(state);\n};\n\npexprs.Apply.prototype.handleCycle = function(state) {\n  var posInfo = state.getCurrentPosInfo();\n  var currentLeftRecursion = posInfo.currentLeftRecursion;\n  var memoKey = this.toMemoKey();\n  var memoRec = posInfo.memo[memoKey];\n\n  if (currentLeftRecursion && currentLeftRecursion.headApplication.toMemoKey() === memoKey) {\n    // We already know about this left recursion, but it's possible there are \"involved\n    // applications\" that we don't already know about, so...\n    memoRec.updateInvolvedApplicationMemoKeys();\n  } else if (!memoRec) {\n    // New left recursion detected! Memoize a failure to try to get a seed parse.\n    memoRec = posInfo.memoize(\n        memoKey,\n        {matchLength: 0, examinedLength: 0, value: false, rightmostFailureOffset: -1});\n    posInfo.startLeftRecursion(this, memoRec);\n  }\n  return state.useMemoizedResult(state.inputStream.pos, memoRec);\n};\n\npexprs.Apply.prototype.reallyEval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  var origPosInfo = state.getCurrentPosInfo();\n  var ruleInfo = state.grammar.rules[this.ruleName];\n  var body = ruleInfo.body;\n  var description = ruleInfo.description;\n\n  state.enterApplication(origPosInfo, this);\n\n  if (description) {\n    state.pushFailuresInfo();\n  }\n\n  // Reset the input stream's examinedLength property so that we can track\n  // the examined length of this particular application.\n  var origInputStreamExaminedLength = inputStream.examinedLength;\n  inputStream.examinedLength = 0;\n\n  var value = this.evalOnce(body, state);\n  var currentLR = origPosInfo.currentLeftRecursion;\n  var memoKey = this.toMemoKey();\n  var isHeadOfLeftRecursion = currentLR && currentLR.headApplication.toMemoKey() === memoKey;\n  var memoRec;\n\n  if (isHeadOfLeftRecursion) {\n    value = this.growSeedResult(body, state, origPos, currentLR, value);\n    origPosInfo.endLeftRecursion();\n    memoRec = currentLR;\n    memoRec.examinedLength = inputStream.examinedLength - origPos;\n    memoRec.rightmostFailureOffset = state._getRightmostFailureOffset();\n    origPosInfo.memoize(memoKey, memoRec);  // updates origPosInfo's maxExaminedLength\n  } else if (!currentLR || !currentLR.isInvolved(memoKey)) {\n    // This application is not involved in left recursion, so it's ok to memoize it.\n    memoRec = origPosInfo.memoize(memoKey, {\n      matchLength: inputStream.pos - origPos,\n      examinedLength: inputStream.examinedLength - origPos,\n      value: value,\n      failuresAtRightmostPosition: state.cloneRecordedFailures(),\n      rightmostFailureOffset: state._getRightmostFailureOffset()\n    });\n  }\n  var succeeded = !!value;\n\n  if (description) {\n    state.popFailuresInfo();\n    if (!succeeded) {\n      state.processFailure(origPos, this);\n    }\n    if (memoRec) {\n      memoRec.failuresAtRightmostPosition = state.cloneRecordedFailures();\n    }\n  }\n\n  // Record trace information in the memo table, so that it is available if the memoized result\n  // is used later.\n  if (state.isTracing() && memoRec) {\n    var entry = state.getTraceEntry(origPos, this, succeeded, succeeded ? [value] : []);\n    if (isHeadOfLeftRecursion) {\n      common.assert(entry.terminatingLREntry != null || !succeeded);\n      entry.isHeadOfLeftRecursion = true;\n    }\n    memoRec.traceEntry = entry;\n  }\n\n  // Fix the input stream's examinedLength -- it should be the maximum examined length\n  // across all applications, not just this one.\n  inputStream.examinedLength = Math.max(inputStream.examinedLength, origInputStreamExaminedLength);\n\n  state.exitApplication(origPosInfo, value);\n\n  return succeeded;\n};\n\npexprs.Apply.prototype.evalOnce = function(expr, state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n\n  if (state.eval(expr)) {\n    var arity = expr.getArity();\n    var bindings = state._bindings.splice(state._bindings.length - arity, arity);\n    var offsets = state._bindingOffsets.splice(state._bindingOffsets.length - arity, arity);\n    return new NonterminalNode(\n        state.grammar, this.ruleName, bindings, offsets, inputStream.pos - origPos);\n  } else {\n    return false;\n  }\n};\n\npexprs.Apply.prototype.growSeedResult = function(body, state, origPos, lrMemoRec, newValue) {\n  if (!newValue) {\n    return false;\n  }\n\n  var inputStream = state.inputStream;\n\n  while (true) {\n    lrMemoRec.matchLength = inputStream.pos - origPos;\n    lrMemoRec.value = newValue;\n    lrMemoRec.failuresAtRightmostPosition = state.cloneRecordedFailures();\n\n    if (state.isTracing()) {\n      // Before evaluating the body again, add a trace node for this application to the memo entry.\n      // Its only child is a copy of the trace node from `newValue`, which will always be the last\n      // element in `state.trace`.\n      var seedTrace = state.trace[state.trace.length - 1];\n      lrMemoRec.traceEntry = new Trace(\n          state.input, origPos, inputStream.pos, this, true, [newValue], [seedTrace.clone()]);\n    }\n    inputStream.pos = origPos;\n    newValue = this.evalOnce(body, state);\n    if (inputStream.pos - origPos <= lrMemoRec.matchLength) {\n      break;\n    }\n    if (state.isTracing()) {\n      state.trace.splice(-2, 1);  // Drop the trace for the old seed.\n    }\n  }\n  if (state.isTracing()) {\n    // The last entry is for an unused result -- pop it and save it in the \"real\" entry.\n    lrMemoRec.traceEntry.recordLRTermination(state.trace.pop(), newValue);\n  }\n  inputStream.pos = origPos + lrMemoRec.matchLength;\n  return lrMemoRec.value;\n};\n\npexprs.UnicodeChar.prototype.eval = function(state) {\n  var inputStream = state.inputStream;\n  var origPos = inputStream.pos;\n  var ch = inputStream.next();\n  if (ch && this.pattern.test(ch)) {\n    state.pushBinding(new TerminalNode(state.grammar, ch), origPos);\n    return true;\n  } else {\n    state.processFailure(origPos, this);\n    return false;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Helpers\n// --------------------------------------------------------------------\n\nfunction flatten(listOfLists) {\n  return Array.prototype.concat.apply([], listOfLists);\n}\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.generateExample = common.abstract('generateExample');\n\nfunction categorizeExamples(examples) {\n  // A list of rules that the system needs examples of, in order to generate an example\n  //   for the current rule\n  var examplesNeeded = examples.filter(function(example) {\n    return example.hasOwnProperty('examplesNeeded');\n  })\n  .map(function(example) { return example.examplesNeeded; });\n\n  examplesNeeded = flatten(examplesNeeded);\n\n  var uniqueExamplesNeeded = {};\n  for (var i = 0; i < examplesNeeded.length; i++) {\n    var currentExampleNeeded = examplesNeeded[i];\n    uniqueExamplesNeeded[currentExampleNeeded] = true;\n  }\n  examplesNeeded = Object.keys(uniqueExamplesNeeded);\n\n  // A list of successfully generated examples\n  var successfulExamples = examples.filter(function(example) {\n    return example.hasOwnProperty('value');\n  })\n  .map(function(item) { return item.value; });\n\n  // This flag returns true if the system cannot generate the rule it is currently\n  //   attempting to generate, regardless of whether or not it has the examples it needs.\n  //   Currently, this is only used in overriding generators to prevent the system from\n  //   generating examples for certain rules (e.g. 'ident').\n  var needHelp = examples.some(function(item) { return item.needHelp; });\n\n  return {\n    examplesNeeded: examplesNeeded,\n    successfulExamples: successfulExamples,\n    needHelp: needHelp\n  };\n}\n\npexprs.any.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  return {value: String.fromCharCode(Math.floor(Math.random() * 255))};\n};\n\n// Assumes that terminal's object is always a string\npexprs.Terminal.prototype.generateExample = function(grammar, examples, inSyntacticContext) {\n  return {value: this.obj};\n};\n\npexprs.Range.prototype.generateExample = function(grammar, examples, inSyntacticContext) {\n  var rangeSize = this.to.charCodeAt(0) - this.from.charCodeAt(0);\n  return {value: String.fromCharCode(\n    this.from.charCodeAt(0) + Math.floor(rangeSize * Math.random())\n  )};\n};\n\npexprs.Param.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  return actuals[this.index].generateExample(grammar, examples, inSyntacticContext, actuals);\n};\n\npexprs.Alt.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  // items -> termExamples\n  var termExamples = this.terms.map(function(term) {\n    return term.generateExample(grammar, examples, inSyntacticContext, actuals);\n  });\n\n  var categorizedExamples = categorizeExamples(termExamples);\n\n  var examplesNeeded = categorizedExamples.examplesNeeded;\n  var successfulExamples = categorizedExamples.successfulExamples;\n  var needHelp = categorizedExamples.needHelp;\n\n  var ans = {};\n\n  // Alt can contain both an example and a request for examples\n  if (successfulExamples.length > 0) {\n    var i = Math.floor(Math.random() * successfulExamples.length);\n    ans.value = successfulExamples[i];\n  }\n  if (examplesNeeded.length > 0) {\n    ans.examplesNeeded = examplesNeeded;\n  }\n  ans.needHelp = needHelp;\n\n  return ans;\n};\n\npexprs.Seq.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  var factorExamples = this.factors.map(function(factor) {\n    return factor.generateExample(grammar, examples, inSyntacticContext, actuals);\n  });\n  var categorizedExamples = categorizeExamples(factorExamples);\n\n  var examplesNeeded = categorizedExamples.examplesNeeded;\n  var successfulExamples = categorizedExamples.successfulExamples;\n  var needHelp = categorizedExamples.needHelp;\n\n  var ans = {};\n\n  // In a Seq, all pieces must succeed in order to have a successful example.\n  if (examplesNeeded.length > 0 || needHelp) {\n    ans.examplesNeeded = examplesNeeded;\n    ans.needHelp = needHelp;\n  } else {\n    ans.value = successfulExamples.join(inSyntacticContext ? ' ' : '');\n  }\n\n  return ans;\n};\n\npexprs.Iter.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  var rangeTimes = Math.min(this.maxNumMatches - this.minNumMatches, 3);\n  var numTimes = Math.floor(Math.random() * (rangeTimes + 1) + this.minNumMatches);\n  var items = [];\n\n  for (var i = 0; i < numTimes; i++) {\n    items.push(this.expr.generateExample(grammar, examples, inSyntacticContext, actuals));\n  }\n\n  var categorizedExamples = categorizeExamples(items);\n\n  var examplesNeeded = categorizedExamples.examplesNeeded;\n  var successfulExamples = categorizedExamples.successfulExamples;\n\n  var ans = {};\n\n  // It's always either one or the other.\n  // TODO: instead of ' ', call 'spaces.generateExample()'\n  ans.value = successfulExamples.join(inSyntacticContext ? ' ' : '');\n  if (examplesNeeded.length > 0) {\n    ans.examplesNeeded = examplesNeeded;\n  }\n\n  return ans;\n};\n\n// Right now, 'Not' and 'Lookahead' generate nothing and assume that whatever follows will\n//   work according to the encoded constraints.\npexprs.Not.prototype.generateExample = function(grammar, examples, inSyntacticContext) {\n  return {value: ''};\n};\n\npexprs.Lookahead.prototype.generateExample = function(grammar, examples, inSyntacticContext) {\n  return {value: ''};\n};\n\npexprs.Lex.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  return this.expr.generateExample(grammar, examples, false, actuals);\n};\n\npexprs.Apply.prototype.generateExample = function(grammar, examples, inSyntacticContext, actuals) {\n  var ans = {};\n\n  var ruleName = this.substituteParams(actuals).toString();\n\n  if (!examples.hasOwnProperty(ruleName)) {\n    ans.examplesNeeded = [ruleName];\n  } else {\n    var relevantExamples = examples[ruleName];\n    var i = Math.floor(Math.random() * relevantExamples.length);\n    ans.value = relevantExamples[i];\n  }\n\n  return ans;\n};\n\npexprs.UnicodeChar.prototype.generateExample = function(\n    grammar, examples, inSyntacticContext, actuals) {\n  var char;\n  switch (this.category) {\n    case 'Lu': char = 'Á'; break;\n    case 'Ll': char = 'ŏ'; break;\n    case 'Lt': char = 'ǅ'; break;\n    case 'Lm': char = 'ˮ'; break;\n    case 'Lo': char = 'ƻ'; break;\n\n    case 'Nl': char = 'ↂ'; break;\n    case 'Nd': char = '½'; break;\n\n    case 'Mn': char = '\\u0487'; break;\n    case 'Mc': char = 'ि'; break;\n\n    case 'Pc': char = '⁀'; break;\n\n    case 'Zs': char = '\\u2001'; break;\n\n    case 'L': char = 'Á'; break;\n    case 'Ltmo': char = 'ǅ'; break;\n  }\n  return {value: char}; // 💩\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.getArity = common.abstract('getArity');\n\npexprs.any.getArity =\npexprs.end.getArity =\npexprs.Terminal.prototype.getArity =\npexprs.Range.prototype.getArity =\npexprs.Param.prototype.getArity =\npexprs.Apply.prototype.getArity =\npexprs.UnicodeChar.prototype.getArity = function() {\n  return 1;\n};\n\npexprs.Alt.prototype.getArity = function() {\n  // This is ok b/c all terms must have the same arity -- this property is\n  // checked by the Grammar constructor.\n  return this.terms.length === 0 ? 0 : this.terms[0].getArity();\n};\n\npexprs.Seq.prototype.getArity = function() {\n  var arity = 0;\n  for (var idx = 0; idx < this.factors.length; idx++) {\n    arity += this.factors[idx].getArity();\n  }\n  return arity;\n};\n\npexprs.Iter.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n\npexprs.Not.prototype.getArity = function() {\n  return 0;\n};\n\npexprs.Lookahead.prototype.getArity =\npexprs.Lex.prototype.getArity = function() {\n  return this.expr.getArity();\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  Called at grammar creation time to rewrite a rule body, replacing each reference to a formal\n  parameter with a `Param` node. Returns a PExpr -- either a new one, or the original one if\n  it was modified in place.\n*/\npexprs.PExpr.prototype.introduceParams = common.abstract('introduceParams');\n\npexprs.any.introduceParams =\npexprs.end.introduceParams =\npexprs.Terminal.prototype.introduceParams =\npexprs.Range.prototype.introduceParams =\npexprs.Param.prototype.introduceParams =\npexprs.UnicodeChar.prototype.introduceParams = function(formals) {\n  return this;\n};\n\npexprs.Alt.prototype.introduceParams = function(formals) {\n  this.terms.forEach(function(term, idx, terms) {\n    terms[idx] = term.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Seq.prototype.introduceParams = function(formals) {\n  this.factors.forEach(function(factor, idx, factors) {\n    factors[idx] = factor.introduceParams(formals);\n  });\n  return this;\n};\n\npexprs.Iter.prototype.introduceParams =\npexprs.Not.prototype.introduceParams =\npexprs.Lookahead.prototype.introduceParams =\npexprs.Lex.prototype.introduceParams = function(formals) {\n  this.expr = this.expr.introduceParams(formals);\n  return this;\n};\n\npexprs.Apply.prototype.introduceParams = function(formals) {\n  var index = formals.indexOf(this.ruleName);\n  if (index >= 0) {\n    if (this.args.length > 0) {\n      // TODO: Should this be supported? See issue #64.\n      throw new Error('Parameterized rules cannot be passed as arguments to another rule.');\n    }\n    return new pexprs.Param(index).withSource(this.source);\n  } else {\n    this.args.forEach(function(arg, idx, args) {\n      args[idx] = arg.introduceParams(formals);\n    });\n    return this;\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns `true` if this parsing expression may accept without consuming any input.\npexprs.PExpr.prototype.isNullable = function(grammar) {\n  return this._isNullable(grammar, Object.create(null));\n};\n\npexprs.PExpr.prototype._isNullable = common.abstract('_isNullable');\n\npexprs.any._isNullable =\npexprs.Range.prototype._isNullable =\npexprs.Param.prototype._isNullable =\npexprs.Plus.prototype._isNullable =\npexprs.UnicodeChar.prototype._isNullable = function(grammar, memo) {\n  return false;\n};\n\npexprs.end._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.Terminal.prototype._isNullable = function(grammar, memo) {\n  if (typeof this.obj === 'string') {\n    // This is an over-simplification: it's only correct if the input is a string. If it's an array\n    // or an object, then the empty string parsing expression is not nullable.\n    return this.obj === '';\n  } else {\n    return false;\n  }\n};\n\npexprs.Alt.prototype._isNullable = function(grammar, memo) {\n  return this.terms.length === 0 ||\n      this.terms.some(function(term) { return term._isNullable(grammar, memo); });\n};\n\npexprs.Seq.prototype._isNullable = function(grammar, memo) {\n  return this.factors.every(function(factor) { return factor._isNullable(grammar, memo); });\n};\n\npexprs.Star.prototype._isNullable =\npexprs.Opt.prototype._isNullable =\npexprs.Not.prototype._isNullable =\npexprs.Lookahead.prototype._isNullable = function(grammar, memo) {\n  return true;\n};\n\npexprs.Lex.prototype._isNullable = function(grammar, memo) {\n  return this.expr._isNullable(grammar, memo);\n};\n\npexprs.Apply.prototype._isNullable = function(grammar, memo) {\n  var key = this.toMemoKey();\n  if (!Object.prototype.hasOwnProperty.call(memo, key)) {\n    var body = grammar.rules[this.ruleName].body;\n    var inlined = body.substituteParams(this.args);\n    memo[key] = false;  // Prevent infinite recursion for recursive rules.\n    memo[key] = inlined._isNullable(grammar, memo);\n  }\n  return memo[key];\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction getMetaInfo(expr, grammarInterval) {\n  var metaInfo = {};\n  if (expr.source && grammarInterval) {\n    var adjusted = expr.source.relativeTo(grammarInterval);\n    metaInfo.sourceInterval = [adjusted.startIdx, adjusted.endIdx];\n  }\n  return metaInfo;\n}\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.outputRecipe = common.abstract('outputRecipe');\n\npexprs.any.outputRecipe = function(formals, grammarInterval) {\n  return ['any', getMetaInfo(this, grammarInterval)];\n};\n\npexprs.end.outputRecipe = function(formals, grammarInterval) {\n  return ['end', getMetaInfo(this, grammarInterval)];\n};\n\npexprs.Terminal.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'terminal',\n    getMetaInfo(this, grammarInterval),\n    this.obj\n  ];\n};\n\npexprs.Range.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'range',\n    getMetaInfo(this, grammarInterval),\n    this.from,\n    this.to\n  ];\n};\n\npexprs.Param.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'param',\n    getMetaInfo(this, grammarInterval),\n    this.index\n  ];\n};\n\npexprs.Alt.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'alt',\n    getMetaInfo(this, grammarInterval)\n  ].concat(this.terms.map(function(term) {\n    return term.outputRecipe(formals, grammarInterval);\n  }));\n};\n\npexprs.Extend.prototype.outputRecipe = function(formals, grammarInterval) {\n  var extension = this.terms[0]; // [extension, orginal]\n  return extension.outputRecipe(formals, grammarInterval);\n};\n\npexprs.Seq.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'seq',\n    getMetaInfo(this, grammarInterval)\n  ].concat(this.factors.map(function(factor) {\n    return factor.outputRecipe(formals, grammarInterval);\n  }));\n};\n\npexprs.Star.prototype.outputRecipe =\npexprs.Plus.prototype.outputRecipe =\npexprs.Opt.prototype.outputRecipe =\npexprs.Not.prototype.outputRecipe =\npexprs.Lookahead.prototype.outputRecipe =\npexprs.Lex.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    this.constructor.name.toLowerCase(),\n    getMetaInfo(this, grammarInterval),\n    this.expr.outputRecipe(formals, grammarInterval)\n  ];\n};\n\npexprs.Apply.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'app',\n    getMetaInfo(this, grammarInterval),\n    this.ruleName,\n    this.args.map(function(arg) {\n      return arg.outputRecipe(formals, grammarInterval);\n    })\n  ];\n};\n\npexprs.UnicodeChar.prototype.outputRecipe = function(formals, grammarInterval) {\n  return [\n    'unicodeChar',\n    getMetaInfo(this, grammarInterval),\n    this.category\n  ];\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  Returns a PExpr that results from recursively replacing every formal parameter (i.e., instance\n  of `Param`) inside this PExpr with its actual value from `actuals` (an Array).\n\n  The receiver must not be modified; a new PExpr must be returned if any replacement is necessary.\n*/\n// function(actuals) { ... }\npexprs.PExpr.prototype.substituteParams = common.abstract('substituteParams');\n\npexprs.any.substituteParams =\npexprs.end.substituteParams =\npexprs.Terminal.prototype.substituteParams =\npexprs.Range.prototype.substituteParams =\npexprs.UnicodeChar.prototype.substituteParams = function(actuals) {\n  return this;\n};\n\npexprs.Param.prototype.substituteParams = function(actuals) {\n  return actuals[this.index];\n};\n\npexprs.Alt.prototype.substituteParams = function(actuals) {\n  return new pexprs.Alt(\n      this.terms.map(function(term) { return term.substituteParams(actuals); }));\n};\n\npexprs.Seq.prototype.substituteParams = function(actuals) {\n  return new pexprs.Seq(\n      this.factors.map(function(factor) { return factor.substituteParams(actuals); }));\n};\n\npexprs.Iter.prototype.substituteParams =\npexprs.Not.prototype.substituteParams =\npexprs.Lookahead.prototype.substituteParams =\npexprs.Lex.prototype.substituteParams = function(actuals) {\n  return new this.constructor(this.expr.substituteParams(actuals));\n};\n\npexprs.Apply.prototype.substituteParams = function(actuals) {\n  if (this.args.length === 0) {\n    // Avoid making a copy of this application, as an optimization\n    return this;\n  } else {\n    var args = this.args.map(function(arg) { return arg.substituteParams(actuals); });\n    return new pexprs.Apply(this.ruleName, args);\n  }\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\nvar copyWithoutDuplicates = common.copyWithoutDuplicates;\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\nfunction isRestrictedJSIdentifier(str) {\n  return /^[a-zA-Z_$][0-9a-zA-Z_$]*$/.test(str);\n}\n\nfunction resolveDuplicatedNames(argumentNameList) {\n  // `count` is used to record the number of times each argument name occurs in the list,\n  // this is useful for checking duplicated argument name. It maps argument names to ints.\n  var count = Object.create(null);\n  argumentNameList.forEach(function(argName) {\n    count[argName] = (count[argName] || 0) + 1;\n  });\n\n  // Append subscripts ('_1', '_2', ...) to duplicate argument names.\n  Object.keys(count).forEach(function(dupArgName) {\n    if (count[dupArgName] <= 1) {\n      return;\n    }\n\n    // This name shows up more than once, so add subscripts.\n    var subscript = 1;\n    argumentNameList.forEach(function(argName, idx) {\n      if (argName === dupArgName) {\n        argumentNameList[idx] = argName + '_' + subscript++;\n      }\n    });\n  });\n}\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  Returns a list of strings that will be used as the default argument names for its receiver\n  (a pexpr) in a semantic action. This is used exclusively by the Semantics Editor.\n\n  `firstArgIndex` is the 1-based index of the first argument name that will be generated for this\n  pexpr. It enables us to name arguments positionally, e.g., if the second argument is a\n  non-alphanumeric terminal like \"+\", it will be named '$2'.\n\n  `noDupCheck` is true if the caller of `toArgumentNameList` is not a top level caller. It enables\n  us to avoid nested duplication subscripts appending, e.g., '_1_1', '_1_2', by only checking\n  duplicates at the top level.\n\n  Here is a more elaborate example that illustrates how this method works:\n  `(a \"+\" b).toArgumentNameList(1)` evaluates to `['a', '$2', 'b']` with the following recursive\n  calls:\n\n    (a).toArgumentNameList(1) -> ['a'],\n    (\"+\").toArgumentNameList(2) -> ['$2'],\n    (b).toArgumentNameList(3) -> ['b']\n\n  Notes:\n  * This method must only be called on well-formed expressions, e.g., the receiver must\n    not have any Alt sub-expressions with inconsistent arities.\n  * e.getArity() === e.toArgumentNameList(1).length\n*/\n// function(firstArgIndex, noDupCheck) { ... }\npexprs.PExpr.prototype.toArgumentNameList = common.abstract('toArgumentNameList');\n\npexprs.any.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return ['any'];\n};\n\npexprs.end.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return ['end'];\n};\n\npexprs.Terminal.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  if (typeof this.obj === 'string' && /^[_a-zA-Z0-9]+$/.test(this.obj)) {\n    // If this terminal is a valid suffix for a JS identifier, just prepend it with '_'\n    return ['_' + this.obj];\n  } else {\n    // Otherwise, name it positionally.\n    return ['$' + firstArgIndex];\n  }\n};\n\npexprs.Range.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  var argName = this.from + '_to_' + this.to;\n  // If the `argName` is not valid then try to prepend a `_`.\n  if (!isRestrictedJSIdentifier(argName)) {\n    argName = '_' + argName;\n  }\n  // If the `argName` still not valid after prepending a `_`, then name it positionally.\n  if (!isRestrictedJSIdentifier(argName)) {\n    argName = '$' + firstArgIndex;\n  }\n  return [argName];\n};\n\npexprs.Alt.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  // `termArgNameLists` is an array of arrays where each row is the\n  // argument name list that corresponds to a term in this alternation.\n  var termArgNameLists = this.terms.map(function(term) {\n    return term.toArgumentNameList(firstArgIndex, true);\n  });\n\n  var argumentNameList = [];\n  var numArgs = termArgNameLists[0].length;\n  for (var colIdx = 0; colIdx < numArgs; colIdx++) {\n    var col = [];\n    for (var rowIdx = 0; rowIdx < this.terms.length; rowIdx++) {\n      col.push(termArgNameLists[rowIdx][colIdx]);\n    }\n    var uniqueNames = copyWithoutDuplicates(col);\n    argumentNameList.push(uniqueNames.join('_or_'));\n  }\n\n  if (!noDupCheck) {\n    resolveDuplicatedNames(argumentNameList);\n  }\n  return argumentNameList;\n};\n\npexprs.Seq.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  // Generate the argument name list, without worrying about duplicates.\n  var argumentNameList = [];\n  this.factors.forEach(function(factor) {\n    var factorArgumentNameList = factor.toArgumentNameList(firstArgIndex, true);\n    argumentNameList = argumentNameList.concat(factorArgumentNameList);\n\n    // Shift the firstArgIndex to take this factor's argument names into account.\n    firstArgIndex += factorArgumentNameList.length;\n  });\n  if (!noDupCheck) {\n    resolveDuplicatedNames(argumentNameList);\n  }\n  return argumentNameList;\n};\n\npexprs.Iter.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  var argumentNameList = this.expr.toArgumentNameList(firstArgIndex, noDupCheck)\n    .map(function(exprArgumentString) {\n      return exprArgumentString[exprArgumentString.length - 1] === 's' ?\n          exprArgumentString + 'es' :\n          exprArgumentString + 's';\n    });\n  if (!noDupCheck) {\n    resolveDuplicatedNames(argumentNameList);\n  }\n  return argumentNameList;\n};\n\npexprs.Opt.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return this.expr.toArgumentNameList(firstArgIndex, noDupCheck).map(function(argName) {\n    return 'opt' + argName[0].toUpperCase() + argName.slice(1);\n  });\n};\n\npexprs.Not.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return [];\n};\n\npexprs.Lookahead.prototype.toArgumentNameList =\npexprs.Lex.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return this.expr.toArgumentNameList(firstArgIndex, noDupCheck);\n};\n\npexprs.Apply.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return [this.ruleName];\n};\n\npexprs.UnicodeChar.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return ['$' + firstArgIndex];\n};\n\npexprs.Param.prototype.toArgumentNameList = function(firstArgIndex, noDupCheck) {\n  return ['param' + this.index];\n};\n\n// \"Value pexprs\" (Value, Str, Arr, Obj) are going away soon, so we don't worry about them here.\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n// Returns a string representing the PExpr, for use as a UI label, etc.\npexprs.PExpr.prototype.toDisplayString = common.abstract('toDisplayString');\n\npexprs.Alt.prototype.toDisplayString =\npexprs.Seq.prototype.toDisplayString = function() {\n  if (this.source) {\n    return this.source.trimmed().contents;\n  }\n  return '[' + this.constructor.name + ']';\n};\n\npexprs.any.toDisplayString =\npexprs.end.toDisplayString =\npexprs.Iter.prototype.toDisplayString =\npexprs.Not.prototype.toDisplayString =\npexprs.Lookahead.prototype.toDisplayString =\npexprs.Lex.prototype.toDisplayString =\npexprs.Terminal.prototype.toDisplayString =\npexprs.Range.prototype.toDisplayString =\npexprs.Param.prototype.toDisplayString = function() {\n  return this.toString();\n};\n\npexprs.Apply.prototype.toDisplayString = function() {\n  if (this.args.length > 0) {\n    var ps = this.args.map(function(arg) { return arg.toDisplayString(); });\n    return this.ruleName + '<' + ps.join(',') + '>';\n  } else {\n    return this.ruleName;\n  }\n};\n\npexprs.UnicodeChar.prototype.toDisplayString = function() {\n  return 'Unicode [' + this.category + '] character';\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar Failure = require('./Failure');\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\npexprs.PExpr.prototype.toFailure = common.abstract('toFailure');\n\npexprs.any.toFailure = function(grammar) {\n  return new Failure(this, 'any object', 'description');\n};\n\npexprs.end.toFailure = function(grammar) {\n  return new Failure(this, 'end of input', 'description');\n};\n\npexprs.Terminal.prototype.toFailure = function(grammar) {\n  return new Failure(this, this.obj, 'string');\n};\n\npexprs.Range.prototype.toFailure = function(grammar) {\n  // TODO: come up with something better\n  return new Failure(this, JSON.stringify(this.from) + '..' + JSON.stringify(this.to), 'code');\n};\n\npexprs.Not.prototype.toFailure = function(grammar) {\n  var description = this.expr === pexprs.any ?\n      'nothing' :\n      'not ' + this.expr.toFailure(grammar);\n  return new Failure(this, description, 'description');\n};\n\npexprs.Lookahead.prototype.toFailure = function(grammar) {\n  return this.expr.toFailure(grammar);\n};\n\npexprs.Apply.prototype.toFailure = function(grammar) {\n  var description = grammar.rules[this.ruleName].description;\n  if (!description) {\n    var article = (/^[aeiouAEIOU]/.test(this.ruleName) ? 'an' : 'a');\n    description = article + ' ' + this.ruleName;\n  }\n  return new Failure(this, description, 'description');\n};\n\npexprs.UnicodeChar.prototype.toFailure = function(grammar) {\n  return new Failure(this, 'a Unicode [' + this.category + '] character', 'description');\n};\n\npexprs.Alt.prototype.toFailure = function(grammar) {\n  var fs = this.terms.map(function(t) { return t.toFailure(grammar); });\n  var description = '(' + fs.join(' or ') + ')';\n  return new Failure(this, description, 'description');\n};\n\npexprs.Seq.prototype.toFailure = function(grammar) {\n  var fs = this.factors.map(function(f) { return f.toFailure(grammar); });\n  var description = '(' + fs.join(' ') + ')';\n  return new Failure(this, description, 'description');\n};\n\npexprs.Iter.prototype.toFailure = function(grammar) {\n  var description = '(' + this.expr.toFailure(grammar) + this.operator + ')';\n  return new Failure(this, description, 'description');\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\nvar pexprs = require('./pexprs');\n\n// --------------------------------------------------------------------\n// Operations\n// --------------------------------------------------------------------\n\n/*\n  e1.toString() === e2.toString() ==> e1 and e2 are semantically equivalent.\n  Note that this is not an iff (<==>): e.g.,\n  (~\"b\" \"a\").toString() !== (\"a\").toString(), even though\n  ~\"b\" \"a\" and \"a\" are interchangeable in any grammar,\n  both in terms of the languages they accept and their arities.\n*/\npexprs.PExpr.prototype.toString = common.abstract('toString');\n\npexprs.any.toString = function() {\n  return 'any';\n};\n\npexprs.end.toString = function() {\n  return 'end';\n};\n\npexprs.Terminal.prototype.toString = function() {\n  return JSON.stringify(this.obj);\n};\n\npexprs.Range.prototype.toString = function() {\n  return JSON.stringify(this.from) + '..' + JSON.stringify(this.to);\n};\n\npexprs.Param.prototype.toString = function() {\n  return '$' + this.index;\n};\n\npexprs.Lex.prototype.toString = function() {\n  return '#(' + this.expr.toString() + ')';\n};\n\npexprs.Alt.prototype.toString = function() {\n  return this.terms.length === 1 ?\n    this.terms[0].toString() :\n    '(' + this.terms.map(function(term) { return term.toString(); }).join(' | ') + ')';\n};\n\npexprs.Seq.prototype.toString = function() {\n  return this.factors.length === 1 ?\n    this.factors[0].toString() :\n    '(' + this.factors.map(function(factor) { return factor.toString(); }).join(' ') + ')';\n};\n\npexprs.Iter.prototype.toString = function() {\n  return this.expr + this.operator;\n};\n\npexprs.Not.prototype.toString = function() {\n  return '~' + this.expr;\n};\n\npexprs.Lookahead.prototype.toString = function() {\n  return '&' + this.expr;\n};\n\npexprs.Apply.prototype.toString = function() {\n  if (this.args.length > 0) {\n    var ps = this.args.map(function(arg) { return arg.toString(); });\n    return this.ruleName + '<' + ps.join(',') + '>';\n  } else {\n    return this.ruleName;\n  }\n};\n\npexprs.UnicodeChar.prototype.toString = function() {\n  return '\\\\p{' + this.category + '}';\n};\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar UnicodeCategories = require('../third_party/UnicodeCategories');\nvar common = require('./common');\nvar inherits = require('inherits');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// General stuff\n\nfunction PExpr() {\n  throw new Error(\"PExpr cannot be instantiated -- it's abstract\");\n}\n\n// Set the `source` property to the interval containing the source for this expression.\nPExpr.prototype.withSource = function(interval) {\n  if (interval) {\n    this.source = interval.trimmed();\n  }\n  return this;\n};\n\n// Any\n\nvar any = Object.create(PExpr.prototype);\n\n// End\n\nvar end = Object.create(PExpr.prototype);\n\n// Terminals\n\nfunction Terminal(obj) {\n  this.obj = obj;\n}\ninherits(Terminal, PExpr);\n\n// Ranges\n\nfunction Range(from, to) {\n  this.from = from;\n  this.to = to;\n}\ninherits(Range, PExpr);\n\n// Parameters\n\nfunction Param(index) {\n  this.index = index;\n}\ninherits(Param, PExpr);\n\n// Alternation\n\nfunction Alt(terms) {\n  this.terms = terms;\n}\ninherits(Alt, PExpr);\n\n// Extend is an implementation detail of rule extension\n\nfunction Extend(superGrammar, name, body) {\n  this.superGrammar = superGrammar;\n  this.name = name;\n  this.body = body;\n  var origBody = superGrammar.rules[name].body;\n  this.terms = [body, origBody];\n}\ninherits(Extend, Alt);\n\n// Sequences\n\nfunction Seq(factors) {\n  this.factors = factors;\n}\ninherits(Seq, PExpr);\n\n// Iterators and optionals\n\nfunction Iter(expr) {\n  this.expr = expr;\n}\ninherits(Iter, PExpr);\n\nfunction Star(expr) {\n  this.expr = expr;\n}\ninherits(Star, Iter);\n\nfunction Plus(expr) {\n  this.expr = expr;\n}\ninherits(Plus, Iter);\n\nfunction Opt(expr) {\n  this.expr = expr;\n}\ninherits(Opt, Iter);\n\nStar.prototype.operator = '*';\nPlus.prototype.operator = '+';\nOpt.prototype.operator = '?';\n\nStar.prototype.minNumMatches = 0;\nPlus.prototype.minNumMatches = 1;\nOpt.prototype.minNumMatches = 0;\n\nStar.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nPlus.prototype.maxNumMatches = Number.POSITIVE_INFINITY;\nOpt.prototype.maxNumMatches = 1;\n\n// Predicates\n\nfunction Not(expr) {\n  this.expr = expr;\n}\ninherits(Not, PExpr);\n\nfunction Lookahead(expr) {\n  this.expr = expr;\n}\ninherits(Lookahead, PExpr);\n\n// \"Lexification\"\n\nfunction Lex(expr) {\n  this.expr = expr;\n}\ninherits(Lex, PExpr);\n\n// Rule application\n\nfunction Apply(ruleName, optArgs) {\n  this.ruleName = ruleName;\n  this.args = optArgs || [];\n}\ninherits(Apply, PExpr);\n\nApply.prototype.isSyntactic = function() {\n  return common.isSyntactic(this.ruleName);\n};\n\n// This method just caches the result of `this.toString()` in a non-enumerable property.\nApply.prototype.toMemoKey = function() {\n  if (!this._memoKey) {\n    Object.defineProperty(this, '_memoKey', {value: this.toString()});\n  }\n  return this._memoKey;\n};\n\n// Unicode character\n\nfunction UnicodeChar(category) {\n  this.category = category;\n  this.pattern = UnicodeCategories[category];\n}\ninherits(UnicodeChar, PExpr);\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nexports.PExpr = PExpr;\nexports.any = any;\nexports.end = end;\nexports.Terminal = Terminal;\nexports.Range = Range;\nexports.Param = Param;\nexports.Alt = Alt;\nexports.Extend = Extend;\nexports.Seq = Seq;\nexports.Iter = Iter;\nexports.Star = Star;\nexports.Plus = Plus;\nexports.Opt = Opt;\nexports.Not = Not;\nexports.Lookahead = Lookahead;\nexports.Lex = Lex;\nexports.Apply = Apply;\nexports.UnicodeChar = UnicodeChar;\n\n// --------------------------------------------------------------------\n// Extensions\n// --------------------------------------------------------------------\n\nrequire('./pexprs-allowsSkippingPrecedingSpace');\nrequire('./pexprs-assertAllApplicationsAreValid');\nrequire('./pexprs-assertChoicesHaveUniformArity');\nrequire('./pexprs-assertIteratedExprsAreNotNullable');\nrequire('./pexprs-check');\nrequire('./pexprs-eval');\nrequire('./pexprs-getArity');\nrequire('./pexprs-generateExample');\nrequire('./pexprs-outputRecipe');\nrequire('./pexprs-introduceParams');\nrequire('./pexprs-isNullable');\nrequire('./pexprs-substituteParams');\nrequire('./pexprs-toDisplayString');\nrequire('./pexprs-toArgumentNameList');\nrequire('./pexprs-toFailure');\nrequire('./pexprs-toString');\n","'use strict';\n\n// --------------------------------------------------------------------\n// Imports\n// --------------------------------------------------------------------\n\nvar common = require('./common');\n\n// --------------------------------------------------------------------\n// Private stuff\n// --------------------------------------------------------------------\n\n// Given an array of numbers `arr`, return an array of the numbers as strings,\n// right-justified and padded to the same length.\nfunction padNumbersToEqualLength(arr) {\n  var maxLen = 0;\n  var strings = arr.map(function(n) {\n    var str = n.toString();\n    maxLen = Math.max(maxLen, str.length);\n    return str;\n  });\n  return strings.map(function(s) { return common.padLeft(s, maxLen); });\n}\n\n// Produce a new string that would be the result of copying the contents\n// of the string `src` onto `dest` at offset `offest`.\nfunction strcpy(dest, src, offset) {\n  var origDestLen = dest.length;\n  var start = dest.slice(0, offset);\n  var end = dest.slice(offset + src.length);\n  return (start + src + end).substr(0, origDestLen);\n}\n\n// --------------------------------------------------------------------\n// Exports\n// --------------------------------------------------------------------\n\nvar builtInRulesCallbacks = [];\n\n// Since Grammar.BuiltInRules is bootstrapped, most of Ohm can't directly depend it.\n// This function allows modules that do depend on the built-in rules to register a callback\n// that will be called later in the initialization process.\nexports.awaitBuiltInRules = function(cb) {\n  builtInRulesCallbacks.push(cb);\n};\n\nexports.announceBuiltInRules = function(grammar) {\n  builtInRulesCallbacks.forEach(function(cb) {\n    cb(grammar);\n  });\n  builtInRulesCallbacks = null;\n};\n\n// Return an object with the line and column information for the given\n// offset in `str`.\nexports.getLineAndColumn = function(str, offset) {\n  var lineNum = 1;\n  var colNum = 1;\n\n  var currOffset = 0;\n  var lineStartOffset = 0;\n\n  var nextLine = null;\n  var prevLine = null;\n  var prevLineStartOffset = -1;\n\n  while (currOffset < offset) {\n    var c = str.charAt(currOffset++);\n    if (c === '\\n') {\n      lineNum++;\n      colNum = 1;\n      prevLineStartOffset = lineStartOffset;\n      lineStartOffset = currOffset;\n    } else if (c !== '\\r') {\n      colNum++;\n    }\n  }\n\n  // Find the end of the target line.\n  var lineEndOffset = str.indexOf('\\n', lineStartOffset);\n  if (lineEndOffset === -1) {\n    lineEndOffset = str.length;\n  } else {\n    // Get the next line.\n    var nextLineEndOffset = str.indexOf('\\n', lineEndOffset + 1);\n    nextLine = nextLineEndOffset === -1 ? str.slice(lineEndOffset)\n                                        : str.slice(lineEndOffset, nextLineEndOffset);\n    // Strip leading and trailing EOL char(s).\n    nextLine = nextLine.replace(/^\\r?\\n/, '').replace(/\\r$/, '');\n  }\n\n  // Get the previous line.\n  if (prevLineStartOffset >= 0) {\n    prevLine = str.slice(prevLineStartOffset, lineStartOffset)\n                  .replace(/\\r?\\n$/, '');  // Strip trailing EOL char(s).\n  }\n\n  // Get the target line, stripping a trailing carriage return if necessary.\n  var line = str.slice(lineStartOffset, lineEndOffset).replace(/\\r$/, '');\n\n  return {\n    lineNum: lineNum,\n    colNum: colNum,\n    line: line,\n    prevLine: prevLine,\n    nextLine: nextLine\n  };\n};\n\n// Return a nicely-formatted string describing the line and column for the\n// given offset in `str`.\nexports.getLineAndColumnMessage = function(str, offset /* ...ranges */) {\n  var repeatStr = common.repeatStr;\n\n  var lineAndCol = exports.getLineAndColumn(str, offset);\n  var sb = new common.StringBuffer();\n  sb.append('Line ' + lineAndCol.lineNum + ', col ' + lineAndCol.colNum + ':\\n');\n\n  // An array of the previous, current, and next line numbers as strings of equal length.\n  var lineNumbers = padNumbersToEqualLength([\n    lineAndCol.prevLine == null ? 0 : lineAndCol.lineNum - 1,\n    lineAndCol.lineNum,\n    lineAndCol.nextLine == null ? 0 : lineAndCol.lineNum + 1\n  ]);\n\n  // Helper for appending formatting input lines to the buffer.\n  function appendLine(num, content, prefix) {\n    sb.append(prefix + lineNumbers[num] + ' | ' + content + '\\n');\n  }\n\n  // Include the previous line for context if possible.\n  if (lineAndCol.prevLine != null) {\n    appendLine(0, lineAndCol.prevLine, '  ');\n  }\n  // Line that the error occurred on.\n  appendLine(1, lineAndCol.line, '> ');\n\n  // Build up the line that points to the offset and possible indicates one or more ranges.\n  // Start with a blank line, and indicate each range by overlaying a string of `~` chars.\n  var lineLen = lineAndCol.line.length;\n  var indicationLine = repeatStr(' ', lineLen + 1);\n  var ranges = Array.prototype.slice.call(arguments, 2);\n  for (var i = 0; i < ranges.length; ++i) {\n    var startIdx = ranges[i][0];\n    var endIdx = ranges[i][1];\n    common.assert(startIdx >= 0 && startIdx <= endIdx, 'range start must be >= 0 and <= end');\n\n    var lineStartOffset = offset - lineAndCol.colNum + 1;\n    startIdx = Math.max(0, startIdx - lineStartOffset);\n    endIdx = Math.min(endIdx - lineStartOffset, lineLen);\n\n    indicationLine = strcpy(indicationLine, repeatStr('~', endIdx - startIdx), startIdx);\n  }\n  var gutterWidth = 2 + lineNumbers[1].length + 3;\n  sb.append(repeatStr(' ', gutterWidth));\n  indicationLine = strcpy(indicationLine, '^', lineAndCol.colNum - 1);\n  sb.append(indicationLine.replace(/ +$/, '') + '\\n');\n\n  // Include the next line for context if possible.\n  if (lineAndCol.nextLine != null) {\n    appendLine(2, lineAndCol.nextLine, '  ');\n  }\n  return sb.contents();\n};\n","/* global browserifyGlobalOhmVersion */\n\n'use strict';\n\n// When running under Node, read the version from package.json. For the browser,\n// use a special global variable defined in the build process (see bin/build-debug.js).\nmodule.exports = typeof browserifyGlobalOhmVersion === 'string'\n    ? browserifyGlobalOhmVersion\n    : require('../package.json').version;\n","// Based on https://github.com/mathiasbynens/unicode-9.0.0.\n// These are just categories that are used in ES5/ES2015.\n// The full list of Unicode categories is here: http://www.fileformat.info/info/unicode/category/index.htm.\nmodule.exports = {\n  // Letters\n  Lu: /[A-Z\\xC0-\\xD6\\xD8-\\xDE\\u0100\\u0102\\u0104\\u0106\\u0108\\u010A\\u010C\\u010E\\u0110\\u0112\\u0114\\u0116\\u0118\\u011A\\u011C\\u011E\\u0120\\u0122\\u0124\\u0126\\u0128\\u012A\\u012C\\u012E\\u0130\\u0132\\u0134\\u0136\\u0139\\u013B\\u013D\\u013F\\u0141\\u0143\\u0145\\u0147\\u014A\\u014C\\u014E\\u0150\\u0152\\u0154\\u0156\\u0158\\u015A\\u015C\\u015E\\u0160\\u0162\\u0164\\u0166\\u0168\\u016A\\u016C\\u016E\\u0170\\u0172\\u0174\\u0176\\u0178\\u0179\\u017B\\u017D\\u0181\\u0182\\u0184\\u0186\\u0187\\u0189-\\u018B\\u018E-\\u0191\\u0193\\u0194\\u0196-\\u0198\\u019C\\u019D\\u019F\\u01A0\\u01A2\\u01A4\\u01A6\\u01A7\\u01A9\\u01AC\\u01AE\\u01AF\\u01B1-\\u01B3\\u01B5\\u01B7\\u01B8\\u01BC\\u01C4\\u01C7\\u01CA\\u01CD\\u01CF\\u01D1\\u01D3\\u01D5\\u01D7\\u01D9\\u01DB\\u01DE\\u01E0\\u01E2\\u01E4\\u01E6\\u01E8\\u01EA\\u01EC\\u01EE\\u01F1\\u01F4\\u01F6-\\u01F8\\u01FA\\u01FC\\u01FE\\u0200\\u0202\\u0204\\u0206\\u0208\\u020A\\u020C\\u020E\\u0210\\u0212\\u0214\\u0216\\u0218\\u021A\\u021C\\u021E\\u0220\\u0222\\u0224\\u0226\\u0228\\u022A\\u022C\\u022E\\u0230\\u0232\\u023A\\u023B\\u023D\\u023E\\u0241\\u0243-\\u0246\\u0248\\u024A\\u024C\\u024E\\u0370\\u0372\\u0376\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E\\u038F\\u0391-\\u03A1\\u03A3-\\u03AB\\u03CF\\u03D2-\\u03D4\\u03D8\\u03DA\\u03DC\\u03DE\\u03E0\\u03E2\\u03E4\\u03E6\\u03E8\\u03EA\\u03EC\\u03EE\\u03F4\\u03F7\\u03F9\\u03FA\\u03FD-\\u042F\\u0460\\u0462\\u0464\\u0466\\u0468\\u046A\\u046C\\u046E\\u0470\\u0472\\u0474\\u0476\\u0478\\u047A\\u047C\\u047E\\u0480\\u048A\\u048C\\u048E\\u0490\\u0492\\u0494\\u0496\\u0498\\u049A\\u049C\\u049E\\u04A0\\u04A2\\u04A4\\u04A6\\u04A8\\u04AA\\u04AC\\u04AE\\u04B0\\u04B2\\u04B4\\u04B6\\u04B8\\u04BA\\u04BC\\u04BE\\u04C0\\u04C1\\u04C3\\u04C5\\u04C7\\u04C9\\u04CB\\u04CD\\u04D0\\u04D2\\u04D4\\u04D6\\u04D8\\u04DA\\u04DC\\u04DE\\u04E0\\u04E2\\u04E4\\u04E6\\u04E8\\u04EA\\u04EC\\u04EE\\u04F0\\u04F2\\u04F4\\u04F6\\u04F8\\u04FA\\u04FC\\u04FE\\u0500\\u0502\\u0504\\u0506\\u0508\\u050A\\u050C\\u050E\\u0510\\u0512\\u0514\\u0516\\u0518\\u051A\\u051C\\u051E\\u0520\\u0522\\u0524\\u0526\\u0528\\u052A\\u052C\\u052E\\u0531-\\u0556\\u10A0-\\u10C5\\u10C7\\u10CD\\u13A0-\\u13F5\\u1E00\\u1E02\\u1E04\\u1E06\\u1E08\\u1E0A\\u1E0C\\u1E0E\\u1E10\\u1E12\\u1E14\\u1E16\\u1E18\\u1E1A\\u1E1C\\u1E1E\\u1E20\\u1E22\\u1E24\\u1E26\\u1E28\\u1E2A\\u1E2C\\u1E2E\\u1E30\\u1E32\\u1E34\\u1E36\\u1E38\\u1E3A\\u1E3C\\u1E3E\\u1E40\\u1E42\\u1E44\\u1E46\\u1E48\\u1E4A\\u1E4C\\u1E4E\\u1E50\\u1E52\\u1E54\\u1E56\\u1E58\\u1E5A\\u1E5C\\u1E5E\\u1E60\\u1E62\\u1E64\\u1E66\\u1E68\\u1E6A\\u1E6C\\u1E6E\\u1E70\\u1E72\\u1E74\\u1E76\\u1E78\\u1E7A\\u1E7C\\u1E7E\\u1E80\\u1E82\\u1E84\\u1E86\\u1E88\\u1E8A\\u1E8C\\u1E8E\\u1E90\\u1E92\\u1E94\\u1E9E\\u1EA0\\u1EA2\\u1EA4\\u1EA6\\u1EA8\\u1EAA\\u1EAC\\u1EAE\\u1EB0\\u1EB2\\u1EB4\\u1EB6\\u1EB8\\u1EBA\\u1EBC\\u1EBE\\u1EC0\\u1EC2\\u1EC4\\u1EC6\\u1EC8\\u1ECA\\u1ECC\\u1ECE\\u1ED0\\u1ED2\\u1ED4\\u1ED6\\u1ED8\\u1EDA\\u1EDC\\u1EDE\\u1EE0\\u1EE2\\u1EE4\\u1EE6\\u1EE8\\u1EEA\\u1EEC\\u1EEE\\u1EF0\\u1EF2\\u1EF4\\u1EF6\\u1EF8\\u1EFA\\u1EFC\\u1EFE\\u1F08-\\u1F0F\\u1F18-\\u1F1D\\u1F28-\\u1F2F\\u1F38-\\u1F3F\\u1F48-\\u1F4D\\u1F59\\u1F5B\\u1F5D\\u1F5F\\u1F68-\\u1F6F\\u1FB8-\\u1FBB\\u1FC8-\\u1FCB\\u1FD8-\\u1FDB\\u1FE8-\\u1FEC\\u1FF8-\\u1FFB\\u2102\\u2107\\u210B-\\u210D\\u2110-\\u2112\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u2130-\\u2133\\u213E\\u213F\\u2145\\u2183\\u2C00-\\u2C2E\\u2C60\\u2C62-\\u2C64\\u2C67\\u2C69\\u2C6B\\u2C6D-\\u2C70\\u2C72\\u2C75\\u2C7E-\\u2C80\\u2C82\\u2C84\\u2C86\\u2C88\\u2C8A\\u2C8C\\u2C8E\\u2C90\\u2C92\\u2C94\\u2C96\\u2C98\\u2C9A\\u2C9C\\u2C9E\\u2CA0\\u2CA2\\u2CA4\\u2CA6\\u2CA8\\u2CAA\\u2CAC\\u2CAE\\u2CB0\\u2CB2\\u2CB4\\u2CB6\\u2CB8\\u2CBA\\u2CBC\\u2CBE\\u2CC0\\u2CC2\\u2CC4\\u2CC6\\u2CC8\\u2CCA\\u2CCC\\u2CCE\\u2CD0\\u2CD2\\u2CD4\\u2CD6\\u2CD8\\u2CDA\\u2CDC\\u2CDE\\u2CE0\\u2CE2\\u2CEB\\u2CED\\u2CF2\\uA640\\uA642\\uA644\\uA646\\uA648\\uA64A\\uA64C\\uA64E\\uA650\\uA652\\uA654\\uA656\\uA658\\uA65A\\uA65C\\uA65E\\uA660\\uA662\\uA664\\uA666\\uA668\\uA66A\\uA66C\\uA680\\uA682\\uA684\\uA686\\uA688\\uA68A\\uA68C\\uA68E\\uA690\\uA692\\uA694\\uA696\\uA698\\uA69A\\uA722\\uA724\\uA726\\uA728\\uA72A\\uA72C\\uA72E\\uA732\\uA734\\uA736\\uA738\\uA73A\\uA73C\\uA73E\\uA740\\uA742\\uA744\\uA746\\uA748\\uA74A\\uA74C\\uA74E\\uA750\\uA752\\uA754\\uA756\\uA758\\uA75A\\uA75C\\uA75E\\uA760\\uA762\\uA764\\uA766\\uA768\\uA76A\\uA76C\\uA76E\\uA779\\uA77B\\uA77D\\uA77E\\uA780\\uA782\\uA784\\uA786\\uA78B\\uA78D\\uA790\\uA792\\uA796\\uA798\\uA79A\\uA79C\\uA79E\\uA7A0\\uA7A2\\uA7A4\\uA7A6\\uA7A8\\uA7AA-\\uA7AE\\uA7B0-\\uA7B4\\uA7B6\\uFF21-\\uFF3A]|\\uD801[\\uDC00-\\uDC27\\uDCB0-\\uDCD3]|\\uD803[\\uDC80-\\uDCB2]|\\uD806[\\uDCA0-\\uDCBF]|\\uD835[\\uDC00-\\uDC19\\uDC34-\\uDC4D\\uDC68-\\uDC81\\uDC9C\\uDC9E\\uDC9F\\uDCA2\\uDCA5\\uDCA6\\uDCA9-\\uDCAC\\uDCAE-\\uDCB5\\uDCD0-\\uDCE9\\uDD04\\uDD05\\uDD07-\\uDD0A\\uDD0D-\\uDD14\\uDD16-\\uDD1C\\uDD38\\uDD39\\uDD3B-\\uDD3E\\uDD40-\\uDD44\\uDD46\\uDD4A-\\uDD50\\uDD6C-\\uDD85\\uDDA0-\\uDDB9\\uDDD4-\\uDDED\\uDE08-\\uDE21\\uDE3C-\\uDE55\\uDE70-\\uDE89\\uDEA8-\\uDEC0\\uDEE2-\\uDEFA\\uDF1C-\\uDF34\\uDF56-\\uDF6E\\uDF90-\\uDFA8\\uDFCA]|\\uD83A[\\uDD00-\\uDD21]/,\n  Ll: /[a-z\\xB5\\xDF-\\xF6\\xF8-\\xFF\\u0101\\u0103\\u0105\\u0107\\u0109\\u010B\\u010D\\u010F\\u0111\\u0113\\u0115\\u0117\\u0119\\u011B\\u011D\\u011F\\u0121\\u0123\\u0125\\u0127\\u0129\\u012B\\u012D\\u012F\\u0131\\u0133\\u0135\\u0137\\u0138\\u013A\\u013C\\u013E\\u0140\\u0142\\u0144\\u0146\\u0148\\u0149\\u014B\\u014D\\u014F\\u0151\\u0153\\u0155\\u0157\\u0159\\u015B\\u015D\\u015F\\u0161\\u0163\\u0165\\u0167\\u0169\\u016B\\u016D\\u016F\\u0171\\u0173\\u0175\\u0177\\u017A\\u017C\\u017E-\\u0180\\u0183\\u0185\\u0188\\u018C\\u018D\\u0192\\u0195\\u0199-\\u019B\\u019E\\u01A1\\u01A3\\u01A5\\u01A8\\u01AA\\u01AB\\u01AD\\u01B0\\u01B4\\u01B6\\u01B9\\u01BA\\u01BD-\\u01BF\\u01C6\\u01C9\\u01CC\\u01CE\\u01D0\\u01D2\\u01D4\\u01D6\\u01D8\\u01DA\\u01DC\\u01DD\\u01DF\\u01E1\\u01E3\\u01E5\\u01E7\\u01E9\\u01EB\\u01ED\\u01EF\\u01F0\\u01F3\\u01F5\\u01F9\\u01FB\\u01FD\\u01FF\\u0201\\u0203\\u0205\\u0207\\u0209\\u020B\\u020D\\u020F\\u0211\\u0213\\u0215\\u0217\\u0219\\u021B\\u021D\\u021F\\u0221\\u0223\\u0225\\u0227\\u0229\\u022B\\u022D\\u022F\\u0231\\u0233-\\u0239\\u023C\\u023F\\u0240\\u0242\\u0247\\u0249\\u024B\\u024D\\u024F-\\u0293\\u0295-\\u02AF\\u0371\\u0373\\u0377\\u037B-\\u037D\\u0390\\u03AC-\\u03CE\\u03D0\\u03D1\\u03D5-\\u03D7\\u03D9\\u03DB\\u03DD\\u03DF\\u03E1\\u03E3\\u03E5\\u03E7\\u03E9\\u03EB\\u03ED\\u03EF-\\u03F3\\u03F5\\u03F8\\u03FB\\u03FC\\u0430-\\u045F\\u0461\\u0463\\u0465\\u0467\\u0469\\u046B\\u046D\\u046F\\u0471\\u0473\\u0475\\u0477\\u0479\\u047B\\u047D\\u047F\\u0481\\u048B\\u048D\\u048F\\u0491\\u0493\\u0495\\u0497\\u0499\\u049B\\u049D\\u049F\\u04A1\\u04A3\\u04A5\\u04A7\\u04A9\\u04AB\\u04AD\\u04AF\\u04B1\\u04B3\\u04B5\\u04B7\\u04B9\\u04BB\\u04BD\\u04BF\\u04C2\\u04C4\\u04C6\\u04C8\\u04CA\\u04CC\\u04CE\\u04CF\\u04D1\\u04D3\\u04D5\\u04D7\\u04D9\\u04DB\\u04DD\\u04DF\\u04E1\\u04E3\\u04E5\\u04E7\\u04E9\\u04EB\\u04ED\\u04EF\\u04F1\\u04F3\\u04F5\\u04F7\\u04F9\\u04FB\\u04FD\\u04FF\\u0501\\u0503\\u0505\\u0507\\u0509\\u050B\\u050D\\u050F\\u0511\\u0513\\u0515\\u0517\\u0519\\u051B\\u051D\\u051F\\u0521\\u0523\\u0525\\u0527\\u0529\\u052B\\u052D\\u052F\\u0561-\\u0587\\u13F8-\\u13FD\\u1C80-\\u1C88\\u1D00-\\u1D2B\\u1D6B-\\u1D77\\u1D79-\\u1D9A\\u1E01\\u1E03\\u1E05\\u1E07\\u1E09\\u1E0B\\u1E0D\\u1E0F\\u1E11\\u1E13\\u1E15\\u1E17\\u1E19\\u1E1B\\u1E1D\\u1E1F\\u1E21\\u1E23\\u1E25\\u1E27\\u1E29\\u1E2B\\u1E2D\\u1E2F\\u1E31\\u1E33\\u1E35\\u1E37\\u1E39\\u1E3B\\u1E3D\\u1E3F\\u1E41\\u1E43\\u1E45\\u1E47\\u1E49\\u1E4B\\u1E4D\\u1E4F\\u1E51\\u1E53\\u1E55\\u1E57\\u1E59\\u1E5B\\u1E5D\\u1E5F\\u1E61\\u1E63\\u1E65\\u1E67\\u1E69\\u1E6B\\u1E6D\\u1E6F\\u1E71\\u1E73\\u1E75\\u1E77\\u1E79\\u1E7B\\u1E7D\\u1E7F\\u1E81\\u1E83\\u1E85\\u1E87\\u1E89\\u1E8B\\u1E8D\\u1E8F\\u1E91\\u1E93\\u1E95-\\u1E9D\\u1E9F\\u1EA1\\u1EA3\\u1EA5\\u1EA7\\u1EA9\\u1EAB\\u1EAD\\u1EAF\\u1EB1\\u1EB3\\u1EB5\\u1EB7\\u1EB9\\u1EBB\\u1EBD\\u1EBF\\u1EC1\\u1EC3\\u1EC5\\u1EC7\\u1EC9\\u1ECB\\u1ECD\\u1ECF\\u1ED1\\u1ED3\\u1ED5\\u1ED7\\u1ED9\\u1EDB\\u1EDD\\u1EDF\\u1EE1\\u1EE3\\u1EE5\\u1EE7\\u1EE9\\u1EEB\\u1EED\\u1EEF\\u1EF1\\u1EF3\\u1EF5\\u1EF7\\u1EF9\\u1EFB\\u1EFD\\u1EFF-\\u1F07\\u1F10-\\u1F15\\u1F20-\\u1F27\\u1F30-\\u1F37\\u1F40-\\u1F45\\u1F50-\\u1F57\\u1F60-\\u1F67\\u1F70-\\u1F7D\\u1F80-\\u1F87\\u1F90-\\u1F97\\u1FA0-\\u1FA7\\u1FB0-\\u1FB4\\u1FB6\\u1FB7\\u1FBE\\u1FC2-\\u1FC4\\u1FC6\\u1FC7\\u1FD0-\\u1FD3\\u1FD6\\u1FD7\\u1FE0-\\u1FE7\\u1FF2-\\u1FF4\\u1FF6\\u1FF7\\u210A\\u210E\\u210F\\u2113\\u212F\\u2134\\u2139\\u213C\\u213D\\u2146-\\u2149\\u214E\\u2184\\u2C30-\\u2C5E\\u2C61\\u2C65\\u2C66\\u2C68\\u2C6A\\u2C6C\\u2C71\\u2C73\\u2C74\\u2C76-\\u2C7B\\u2C81\\u2C83\\u2C85\\u2C87\\u2C89\\u2C8B\\u2C8D\\u2C8F\\u2C91\\u2C93\\u2C95\\u2C97\\u2C99\\u2C9B\\u2C9D\\u2C9F\\u2CA1\\u2CA3\\u2CA5\\u2CA7\\u2CA9\\u2CAB\\u2CAD\\u2CAF\\u2CB1\\u2CB3\\u2CB5\\u2CB7\\u2CB9\\u2CBB\\u2CBD\\u2CBF\\u2CC1\\u2CC3\\u2CC5\\u2CC7\\u2CC9\\u2CCB\\u2CCD\\u2CCF\\u2CD1\\u2CD3\\u2CD5\\u2CD7\\u2CD9\\u2CDB\\u2CDD\\u2CDF\\u2CE1\\u2CE3\\u2CE4\\u2CEC\\u2CEE\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\uA641\\uA643\\uA645\\uA647\\uA649\\uA64B\\uA64D\\uA64F\\uA651\\uA653\\uA655\\uA657\\uA659\\uA65B\\uA65D\\uA65F\\uA661\\uA663\\uA665\\uA667\\uA669\\uA66B\\uA66D\\uA681\\uA683\\uA685\\uA687\\uA689\\uA68B\\uA68D\\uA68F\\uA691\\uA693\\uA695\\uA697\\uA699\\uA69B\\uA723\\uA725\\uA727\\uA729\\uA72B\\uA72D\\uA72F-\\uA731\\uA733\\uA735\\uA737\\uA739\\uA73B\\uA73D\\uA73F\\uA741\\uA743\\uA745\\uA747\\uA749\\uA74B\\uA74D\\uA74F\\uA751\\uA753\\uA755\\uA757\\uA759\\uA75B\\uA75D\\uA75F\\uA761\\uA763\\uA765\\uA767\\uA769\\uA76B\\uA76D\\uA76F\\uA771-\\uA778\\uA77A\\uA77C\\uA77F\\uA781\\uA783\\uA785\\uA787\\uA78C\\uA78E\\uA791\\uA793-\\uA795\\uA797\\uA799\\uA79B\\uA79D\\uA79F\\uA7A1\\uA7A3\\uA7A5\\uA7A7\\uA7A9\\uA7B5\\uA7B7\\uA7FA\\uAB30-\\uAB5A\\uAB60-\\uAB65\\uAB70-\\uABBF\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFF41-\\uFF5A]|\\uD801[\\uDC28-\\uDC4F\\uDCD8-\\uDCFB]|\\uD803[\\uDCC0-\\uDCF2]|\\uD806[\\uDCC0-\\uDCDF]|\\uD835[\\uDC1A-\\uDC33\\uDC4E-\\uDC54\\uDC56-\\uDC67\\uDC82-\\uDC9B\\uDCB6-\\uDCB9\\uDCBB\\uDCBD-\\uDCC3\\uDCC5-\\uDCCF\\uDCEA-\\uDD03\\uDD1E-\\uDD37\\uDD52-\\uDD6B\\uDD86-\\uDD9F\\uDDBA-\\uDDD3\\uDDEE-\\uDE07\\uDE22-\\uDE3B\\uDE56-\\uDE6F\\uDE8A-\\uDEA5\\uDEC2-\\uDEDA\\uDEDC-\\uDEE1\\uDEFC-\\uDF14\\uDF16-\\uDF1B\\uDF36-\\uDF4E\\uDF50-\\uDF55\\uDF70-\\uDF88\\uDF8A-\\uDF8F\\uDFAA-\\uDFC2\\uDFC4-\\uDFC9\\uDFCB]|\\uD83A[\\uDD22-\\uDD43]/,\n  Lt: /[\\u01C5\\u01C8\\u01CB\\u01F2\\u1F88-\\u1F8F\\u1F98-\\u1F9F\\u1FA8-\\u1FAF\\u1FBC\\u1FCC\\u1FFC]/,\n  Lm: /[\\u02B0-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0374\\u037A\\u0559\\u0640\\u06E5\\u06E6\\u07F4\\u07F5\\u07FA\\u081A\\u0824\\u0828\\u0971\\u0E46\\u0EC6\\u10FC\\u17D7\\u1843\\u1AA7\\u1C78-\\u1C7D\\u1D2C-\\u1D6A\\u1D78\\u1D9B-\\u1DBF\\u2071\\u207F\\u2090-\\u209C\\u2C7C\\u2C7D\\u2D6F\\u2E2F\\u3005\\u3031-\\u3035\\u303B\\u309D\\u309E\\u30FC-\\u30FE\\uA015\\uA4F8-\\uA4FD\\uA60C\\uA67F\\uA69C\\uA69D\\uA717-\\uA71F\\uA770\\uA788\\uA7F8\\uA7F9\\uA9CF\\uA9E6\\uAA70\\uAADD\\uAAF3\\uAAF4\\uAB5C-\\uAB5F\\uFF70\\uFF9E\\uFF9F]|\\uD81A[\\uDF40-\\uDF43]|\\uD81B[\\uDF93-\\uDF9F\\uDFE0]/,\n  Lo: /[\\xAA\\xBA\\u01BB\\u01C0-\\u01C3\\u0294\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u063F\\u0641-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u0800-\\u0815\\u0840-\\u0858\\u08A0-\\u08B4\\u08B6-\\u08BD\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0972-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0AF9\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58-\\u0C5A\\u0C60\\u0C61\\u0C80\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D54-\\u0D56\\u0D5F-\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E45\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10D0-\\u10FA\\u10FD-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16F1-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17DC\\u1820-\\u1842\\u1844-\\u1877\\u1880-\\u1884\\u1887-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C77\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u2135-\\u2138\\u2D30-\\u2D67\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u3006\\u303C\\u3041-\\u3096\\u309F\\u30A1-\\u30FA\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FD5\\uA000-\\uA014\\uA016-\\uA48C\\uA4D0-\\uA4F7\\uA500-\\uA60B\\uA610-\\uA61F\\uA62A\\uA62B\\uA66E\\uA6A0-\\uA6E5\\uA78F\\uA7F7\\uA7FB-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA8FD\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9E0-\\uA9E4\\uA9E7-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA6F\\uAA71-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB\\uAADC\\uAAE0-\\uAAEA\\uAAF2\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF66-\\uFF6F\\uFF71-\\uFF9D\\uFFA0-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]|\\uD800[\\uDC00-\\uDC0B\\uDC0D-\\uDC26\\uDC28-\\uDC3A\\uDC3C\\uDC3D\\uDC3F-\\uDC4D\\uDC50-\\uDC5D\\uDC80-\\uDCFA\\uDE80-\\uDE9C\\uDEA0-\\uDED0\\uDF00-\\uDF1F\\uDF30-\\uDF40\\uDF42-\\uDF49\\uDF50-\\uDF75\\uDF80-\\uDF9D\\uDFA0-\\uDFC3\\uDFC8-\\uDFCF]|\\uD801[\\uDC50-\\uDC9D\\uDD00-\\uDD27\\uDD30-\\uDD63\\uDE00-\\uDF36\\uDF40-\\uDF55\\uDF60-\\uDF67]|\\uD802[\\uDC00-\\uDC05\\uDC08\\uDC0A-\\uDC35\\uDC37\\uDC38\\uDC3C\\uDC3F-\\uDC55\\uDC60-\\uDC76\\uDC80-\\uDC9E\\uDCE0-\\uDCF2\\uDCF4\\uDCF5\\uDD00-\\uDD15\\uDD20-\\uDD39\\uDD80-\\uDDB7\\uDDBE\\uDDBF\\uDE00\\uDE10-\\uDE13\\uDE15-\\uDE17\\uDE19-\\uDE33\\uDE60-\\uDE7C\\uDE80-\\uDE9C\\uDEC0-\\uDEC7\\uDEC9-\\uDEE4\\uDF00-\\uDF35\\uDF40-\\uDF55\\uDF60-\\uDF72\\uDF80-\\uDF91]|\\uD803[\\uDC00-\\uDC48]|\\uD804[\\uDC03-\\uDC37\\uDC83-\\uDCAF\\uDCD0-\\uDCE8\\uDD03-\\uDD26\\uDD50-\\uDD72\\uDD76\\uDD83-\\uDDB2\\uDDC1-\\uDDC4\\uDDDA\\uDDDC\\uDE00-\\uDE11\\uDE13-\\uDE2B\\uDE80-\\uDE86\\uDE88\\uDE8A-\\uDE8D\\uDE8F-\\uDE9D\\uDE9F-\\uDEA8\\uDEB0-\\uDEDE\\uDF05-\\uDF0C\\uDF0F\\uDF10\\uDF13-\\uDF28\\uDF2A-\\uDF30\\uDF32\\uDF33\\uDF35-\\uDF39\\uDF3D\\uDF50\\uDF5D-\\uDF61]|\\uD805[\\uDC00-\\uDC34\\uDC47-\\uDC4A\\uDC80-\\uDCAF\\uDCC4\\uDCC5\\uDCC7\\uDD80-\\uDDAE\\uDDD8-\\uDDDB\\uDE00-\\uDE2F\\uDE44\\uDE80-\\uDEAA\\uDF00-\\uDF19]|\\uD806[\\uDCFF\\uDEC0-\\uDEF8]|\\uD807[\\uDC00-\\uDC08\\uDC0A-\\uDC2E\\uDC40\\uDC72-\\uDC8F]|\\uD808[\\uDC00-\\uDF99]|\\uD809[\\uDC80-\\uDD43]|[\\uD80C\\uD81C-\\uD820\\uD840-\\uD868\\uD86A-\\uD86C\\uD86F-\\uD872][\\uDC00-\\uDFFF]|\\uD80D[\\uDC00-\\uDC2E]|\\uD811[\\uDC00-\\uDE46]|\\uD81A[\\uDC00-\\uDE38\\uDE40-\\uDE5E\\uDED0-\\uDEED\\uDF00-\\uDF2F\\uDF63-\\uDF77\\uDF7D-\\uDF8F]|\\uD81B[\\uDF00-\\uDF44\\uDF50]|\\uD821[\\uDC00-\\uDFEC]|\\uD822[\\uDC00-\\uDEF2]|\\uD82C[\\uDC00\\uDC01]|\\uD82F[\\uDC00-\\uDC6A\\uDC70-\\uDC7C\\uDC80-\\uDC88\\uDC90-\\uDC99]|\\uD83A[\\uDC00-\\uDCC4]|\\uD83B[\\uDE00-\\uDE03\\uDE05-\\uDE1F\\uDE21\\uDE22\\uDE24\\uDE27\\uDE29-\\uDE32\\uDE34-\\uDE37\\uDE39\\uDE3B\\uDE42\\uDE47\\uDE49\\uDE4B\\uDE4D-\\uDE4F\\uDE51\\uDE52\\uDE54\\uDE57\\uDE59\\uDE5B\\uDE5D\\uDE5F\\uDE61\\uDE62\\uDE64\\uDE67-\\uDE6A\\uDE6C-\\uDE72\\uDE74-\\uDE77\\uDE79-\\uDE7C\\uDE7E\\uDE80-\\uDE89\\uDE8B-\\uDE9B\\uDEA1-\\uDEA3\\uDEA5-\\uDEA9\\uDEAB-\\uDEBB]|\\uD869[\\uDC00-\\uDED6\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF34\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D\\uDC20-\\uDFFF]|\\uD873[\\uDC00-\\uDEA1]|\\uD87E[\\uDC00-\\uDE1D]/,\n\n  // Numbers\n  Nl: /[\\u16EE-\\u16F0\\u2160-\\u2182\\u2185-\\u2188\\u3007\\u3021-\\u3029\\u3038-\\u303A\\uA6E6-\\uA6EF]|\\uD800[\\uDD40-\\uDD74\\uDF41\\uDF4A\\uDFD1-\\uDFD5]|\\uD809[\\uDC00-\\uDC6E]/,\n  Nd: /[0-9\\u0660-\\u0669\\u06F0-\\u06F9\\u07C0-\\u07C9\\u0966-\\u096F\\u09E6-\\u09EF\\u0A66-\\u0A6F\\u0AE6-\\u0AEF\\u0B66-\\u0B6F\\u0BE6-\\u0BEF\\u0C66-\\u0C6F\\u0CE6-\\u0CEF\\u0D66-\\u0D6F\\u0DE6-\\u0DEF\\u0E50-\\u0E59\\u0ED0-\\u0ED9\\u0F20-\\u0F29\\u1040-\\u1049\\u1090-\\u1099\\u17E0-\\u17E9\\u1810-\\u1819\\u1946-\\u194F\\u19D0-\\u19D9\\u1A80-\\u1A89\\u1A90-\\u1A99\\u1B50-\\u1B59\\u1BB0-\\u1BB9\\u1C40-\\u1C49\\u1C50-\\u1C59\\uA620-\\uA629\\uA8D0-\\uA8D9\\uA900-\\uA909\\uA9D0-\\uA9D9\\uA9F0-\\uA9F9\\uAA50-\\uAA59\\uABF0-\\uABF9\\uFF10-\\uFF19]|\\uD801[\\uDCA0-\\uDCA9]|\\uD804[\\uDC66-\\uDC6F\\uDCF0-\\uDCF9\\uDD36-\\uDD3F\\uDDD0-\\uDDD9\\uDEF0-\\uDEF9]|[\\uD805\\uD807][\\uDC50-\\uDC59\\uDCD0-\\uDCD9\\uDE50-\\uDE59\\uDEC0-\\uDEC9\\uDF30-\\uDF39]|\\uD806[\\uDCE0-\\uDCE9]|\\uD81A[\\uDE60-\\uDE69\\uDF50-\\uDF59]|\\uD835[\\uDFCE-\\uDFFF]|\\uD83A[\\uDD50-\\uDD59]/,\n\n  // Marks\n  Mn: /[\\u0300-\\u036F\\u0483-\\u0487\\u0591-\\u05BD\\u05BF\\u05C1\\u05C2\\u05C4\\u05C5\\u05C7\\u0610-\\u061A\\u064B-\\u065F\\u0670\\u06D6-\\u06DC\\u06DF-\\u06E4\\u06E7\\u06E8\\u06EA-\\u06ED\\u0711\\u0730-\\u074A\\u07A6-\\u07B0\\u07EB-\\u07F3\\u0816-\\u0819\\u081B-\\u0823\\u0825-\\u0827\\u0829-\\u082D\\u0859-\\u085B\\u08D4-\\u08E1\\u08E3-\\u0902\\u093A\\u093C\\u0941-\\u0948\\u094D\\u0951-\\u0957\\u0962\\u0963\\u0981\\u09BC\\u09C1-\\u09C4\\u09CD\\u09E2\\u09E3\\u0A01\\u0A02\\u0A3C\\u0A41\\u0A42\\u0A47\\u0A48\\u0A4B-\\u0A4D\\u0A51\\u0A70\\u0A71\\u0A75\\u0A81\\u0A82\\u0ABC\\u0AC1-\\u0AC5\\u0AC7\\u0AC8\\u0ACD\\u0AE2\\u0AE3\\u0B01\\u0B3C\\u0B3F\\u0B41-\\u0B44\\u0B4D\\u0B56\\u0B62\\u0B63\\u0B82\\u0BC0\\u0BCD\\u0C00\\u0C3E-\\u0C40\\u0C46-\\u0C48\\u0C4A-\\u0C4D\\u0C55\\u0C56\\u0C62\\u0C63\\u0C81\\u0CBC\\u0CBF\\u0CC6\\u0CCC\\u0CCD\\u0CE2\\u0CE3\\u0D01\\u0D41-\\u0D44\\u0D4D\\u0D62\\u0D63\\u0DCA\\u0DD2-\\u0DD4\\u0DD6\\u0E31\\u0E34-\\u0E3A\\u0E47-\\u0E4E\\u0EB1\\u0EB4-\\u0EB9\\u0EBB\\u0EBC\\u0EC8-\\u0ECD\\u0F18\\u0F19\\u0F35\\u0F37\\u0F39\\u0F71-\\u0F7E\\u0F80-\\u0F84\\u0F86\\u0F87\\u0F8D-\\u0F97\\u0F99-\\u0FBC\\u0FC6\\u102D-\\u1030\\u1032-\\u1037\\u1039\\u103A\\u103D\\u103E\\u1058\\u1059\\u105E-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108D\\u109D\\u135D-\\u135F\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17B4\\u17B5\\u17B7-\\u17BD\\u17C6\\u17C9-\\u17D3\\u17DD\\u180B-\\u180D\\u1885\\u1886\\u18A9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193B\\u1A17\\u1A18\\u1A1B\\u1A56\\u1A58-\\u1A5E\\u1A60\\u1A62\\u1A65-\\u1A6C\\u1A73-\\u1A7C\\u1A7F\\u1AB0-\\u1ABD\\u1B00-\\u1B03\\u1B34\\u1B36-\\u1B3A\\u1B3C\\u1B42\\u1B6B-\\u1B73\\u1B80\\u1B81\\u1BA2-\\u1BA5\\u1BA8\\u1BA9\\u1BAB-\\u1BAD\\u1BE6\\u1BE8\\u1BE9\\u1BED\\u1BEF-\\u1BF1\\u1C2C-\\u1C33\\u1C36\\u1C37\\u1CD0-\\u1CD2\\u1CD4-\\u1CE0\\u1CE2-\\u1CE8\\u1CED\\u1CF4\\u1CF8\\u1CF9\\u1DC0-\\u1DF5\\u1DFB-\\u1DFF\\u20D0-\\u20DC\\u20E1\\u20E5-\\u20F0\\u2CEF-\\u2CF1\\u2D7F\\u2DE0-\\u2DFF\\u302A-\\u302D\\u3099\\u309A\\uA66F\\uA674-\\uA67D\\uA69E\\uA69F\\uA6F0\\uA6F1\\uA802\\uA806\\uA80B\\uA825\\uA826\\uA8C4\\uA8C5\\uA8E0-\\uA8F1\\uA926-\\uA92D\\uA947-\\uA951\\uA980-\\uA982\\uA9B3\\uA9B6-\\uA9B9\\uA9BC\\uA9E5\\uAA29-\\uAA2E\\uAA31\\uAA32\\uAA35\\uAA36\\uAA43\\uAA4C\\uAA7C\\uAAB0\\uAAB2-\\uAAB4\\uAAB7\\uAAB8\\uAABE\\uAABF\\uAAC1\\uAAEC\\uAAED\\uAAF6\\uABE5\\uABE8\\uABED\\uFB1E\\uFE00-\\uFE0F\\uFE20-\\uFE2F]|\\uD800[\\uDDFD\\uDEE0\\uDF76-\\uDF7A]|\\uD802[\\uDE01-\\uDE03\\uDE05\\uDE06\\uDE0C-\\uDE0F\\uDE38-\\uDE3A\\uDE3F\\uDEE5\\uDEE6]|\\uD804[\\uDC01\\uDC38-\\uDC46\\uDC7F-\\uDC81\\uDCB3-\\uDCB6\\uDCB9\\uDCBA\\uDD00-\\uDD02\\uDD27-\\uDD2B\\uDD2D-\\uDD34\\uDD73\\uDD80\\uDD81\\uDDB6-\\uDDBE\\uDDCA-\\uDDCC\\uDE2F-\\uDE31\\uDE34\\uDE36\\uDE37\\uDE3E\\uDEDF\\uDEE3-\\uDEEA\\uDF00\\uDF01\\uDF3C\\uDF40\\uDF66-\\uDF6C\\uDF70-\\uDF74]|\\uD805[\\uDC38-\\uDC3F\\uDC42-\\uDC44\\uDC46\\uDCB3-\\uDCB8\\uDCBA\\uDCBF\\uDCC0\\uDCC2\\uDCC3\\uDDB2-\\uDDB5\\uDDBC\\uDDBD\\uDDBF\\uDDC0\\uDDDC\\uDDDD\\uDE33-\\uDE3A\\uDE3D\\uDE3F\\uDE40\\uDEAB\\uDEAD\\uDEB0-\\uDEB5\\uDEB7\\uDF1D-\\uDF1F\\uDF22-\\uDF25\\uDF27-\\uDF2B]|\\uD807[\\uDC30-\\uDC36\\uDC38-\\uDC3D\\uDC3F\\uDC92-\\uDCA7\\uDCAA-\\uDCB0\\uDCB2\\uDCB3\\uDCB5\\uDCB6]|\\uD81A[\\uDEF0-\\uDEF4\\uDF30-\\uDF36]|\\uD81B[\\uDF8F-\\uDF92]|\\uD82F[\\uDC9D\\uDC9E]|\\uD834[\\uDD67-\\uDD69\\uDD7B-\\uDD82\\uDD85-\\uDD8B\\uDDAA-\\uDDAD\\uDE42-\\uDE44]|\\uD836[\\uDE00-\\uDE36\\uDE3B-\\uDE6C\\uDE75\\uDE84\\uDE9B-\\uDE9F\\uDEA1-\\uDEAF]|\\uD838[\\uDC00-\\uDC06\\uDC08-\\uDC18\\uDC1B-\\uDC21\\uDC23\\uDC24\\uDC26-\\uDC2A]|\\uD83A[\\uDCD0-\\uDCD6\\uDD44-\\uDD4A]|\\uDB40[\\uDD00-\\uDDEF]/,\n  Mc: /[\\u0903-\\u0903]|[\\u093E-\\u0940]|[\\u0949-\\u094C]|[\\u0982-\\u0983]|[\\u09BE-\\u09C0]|[\\u09C7-\\u09C8]|[\\u09CB-\\u09CC]|[\\u09D7-\\u09D7]|[\\u0A3E-\\u0A40]|[\\u0A83-\\u0A83]|[\\u0ABE-\\u0AC0]|[\\u0AC9-\\u0AC9]|[\\u0ACB-\\u0ACC]|[\\u0B02-\\u0B03]|[\\u0B3E-\\u0B3E]|[\\u0B40-\\u0B40]|[\\u0B47-\\u0B48]|[\\u0B4B-\\u0B4C]|[\\u0B57-\\u0B57]|[\\u0B83-\\u0B83]|[\\u0BBE-\\u0BBF]|[\\u0BC1-\\u0BC2]|[\\u0BC6-\\u0BC8]|[\\u0BCA-\\u0BCC]|[\\u0BD7-\\u0BD7]|[\\u0C01-\\u0C03]|[\\u0C41-\\u0C44]|[\\u0C82-\\u0C83]|[\\u0CBE-\\u0CBE]|[\\u0CC0-\\u0CC4]|[\\u0CC7-\\u0CC8]|[\\u0CCA-\\u0CCB]|[\\u0CD5-\\u0CD6]|[\\u0D02-\\u0D03]|[\\u0D3E-\\u0D40]|[\\u0D46-\\u0D48]|[\\u0D4A-\\u0D4C]|[\\u0D57-\\u0D57]|[\\u0F3E-\\u0F3F]|[\\u0F7F-\\u0F7F]/,\n\n  // Punctuation, Connector\n  Pc: /[_\\u203F\\u2040\\u2054\\uFE33\\uFE34\\uFE4D-\\uFE4F\\uFF3F]/,\n\n  // Separator, Space\n  Zs: /[ \\xA0\\u1680\\u2000-\\u200A\\u202F\\u205F\\u3000]/,\n\n  // These two are not real Unicode categories, but our useful for Ohm.\n  // L is a combination of all the letter categories.\n  // Ltmo is a combination of Lt, Lm, and Lo.\n  L: /[A-Za-z\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0370-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u07F4\\u07F5\\u07FA\\u0800-\\u0815\\u081A\\u0824\\u0828\\u0840-\\u0858\\u08A0-\\u08B4\\u08B6-\\u08BD\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0971-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0AF9\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58-\\u0C5A\\u0C60\\u0C61\\u0C80\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D54-\\u0D56\\u0D5F-\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E46\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u13A0-\\u13F5\\u13F8-\\u13FD\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16F1-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17D7\\u17DC\\u1820-\\u1877\\u1880-\\u1884\\u1887-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1AA7\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C7D\\u1C80-\\u1C88\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u1D00-\\u1DBF\\u1E00-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u2071\\u207F\\u2090-\\u209C\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2183\\u2184\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CEE\\u2CF2\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2E2F\\u3005\\u3006\\u3031-\\u3035\\u303B\\u303C\\u3041-\\u3096\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FD5\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA61F\\uA62A\\uA62B\\uA640-\\uA66E\\uA67F-\\uA69D\\uA6A0-\\uA6E5\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA7AE\\uA7B0-\\uA7B7\\uA7F7-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA8FD\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9CF\\uA9E0-\\uA9E4\\uA9E6-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEA\\uAAF2-\\uAAF4\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB65\\uAB70-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF21-\\uFF3A\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]|\\uD800[\\uDC00-\\uDC0B\\uDC0D-\\uDC26\\uDC28-\\uDC3A\\uDC3C\\uDC3D\\uDC3F-\\uDC4D\\uDC50-\\uDC5D\\uDC80-\\uDCFA\\uDE80-\\uDE9C\\uDEA0-\\uDED0\\uDF00-\\uDF1F\\uDF30-\\uDF40\\uDF42-\\uDF49\\uDF50-\\uDF75\\uDF80-\\uDF9D\\uDFA0-\\uDFC3\\uDFC8-\\uDFCF]|\\uD801[\\uDC00-\\uDC9D\\uDCB0-\\uDCD3\\uDCD8-\\uDCFB\\uDD00-\\uDD27\\uDD30-\\uDD63\\uDE00-\\uDF36\\uDF40-\\uDF55\\uDF60-\\uDF67]|\\uD802[\\uDC00-\\uDC05\\uDC08\\uDC0A-\\uDC35\\uDC37\\uDC38\\uDC3C\\uDC3F-\\uDC55\\uDC60-\\uDC76\\uDC80-\\uDC9E\\uDCE0-\\uDCF2\\uDCF4\\uDCF5\\uDD00-\\uDD15\\uDD20-\\uDD39\\uDD80-\\uDDB7\\uDDBE\\uDDBF\\uDE00\\uDE10-\\uDE13\\uDE15-\\uDE17\\uDE19-\\uDE33\\uDE60-\\uDE7C\\uDE80-\\uDE9C\\uDEC0-\\uDEC7\\uDEC9-\\uDEE4\\uDF00-\\uDF35\\uDF40-\\uDF55\\uDF60-\\uDF72\\uDF80-\\uDF91]|\\uD803[\\uDC00-\\uDC48\\uDC80-\\uDCB2\\uDCC0-\\uDCF2]|\\uD804[\\uDC03-\\uDC37\\uDC83-\\uDCAF\\uDCD0-\\uDCE8\\uDD03-\\uDD26\\uDD50-\\uDD72\\uDD76\\uDD83-\\uDDB2\\uDDC1-\\uDDC4\\uDDDA\\uDDDC\\uDE00-\\uDE11\\uDE13-\\uDE2B\\uDE80-\\uDE86\\uDE88\\uDE8A-\\uDE8D\\uDE8F-\\uDE9D\\uDE9F-\\uDEA8\\uDEB0-\\uDEDE\\uDF05-\\uDF0C\\uDF0F\\uDF10\\uDF13-\\uDF28\\uDF2A-\\uDF30\\uDF32\\uDF33\\uDF35-\\uDF39\\uDF3D\\uDF50\\uDF5D-\\uDF61]|\\uD805[\\uDC00-\\uDC34\\uDC47-\\uDC4A\\uDC80-\\uDCAF\\uDCC4\\uDCC5\\uDCC7\\uDD80-\\uDDAE\\uDDD8-\\uDDDB\\uDE00-\\uDE2F\\uDE44\\uDE80-\\uDEAA\\uDF00-\\uDF19]|\\uD806[\\uDCA0-\\uDCDF\\uDCFF\\uDEC0-\\uDEF8]|\\uD807[\\uDC00-\\uDC08\\uDC0A-\\uDC2E\\uDC40\\uDC72-\\uDC8F]|\\uD808[\\uDC00-\\uDF99]|\\uD809[\\uDC80-\\uDD43]|[\\uD80C\\uD81C-\\uD820\\uD840-\\uD868\\uD86A-\\uD86C\\uD86F-\\uD872][\\uDC00-\\uDFFF]|\\uD80D[\\uDC00-\\uDC2E]|\\uD811[\\uDC00-\\uDE46]|\\uD81A[\\uDC00-\\uDE38\\uDE40-\\uDE5E\\uDED0-\\uDEED\\uDF00-\\uDF2F\\uDF40-\\uDF43\\uDF63-\\uDF77\\uDF7D-\\uDF8F]|\\uD81B[\\uDF00-\\uDF44\\uDF50\\uDF93-\\uDF9F\\uDFE0]|\\uD821[\\uDC00-\\uDFEC]|\\uD822[\\uDC00-\\uDEF2]|\\uD82C[\\uDC00\\uDC01]|\\uD82F[\\uDC00-\\uDC6A\\uDC70-\\uDC7C\\uDC80-\\uDC88\\uDC90-\\uDC99]|\\uD835[\\uDC00-\\uDC54\\uDC56-\\uDC9C\\uDC9E\\uDC9F\\uDCA2\\uDCA5\\uDCA6\\uDCA9-\\uDCAC\\uDCAE-\\uDCB9\\uDCBB\\uDCBD-\\uDCC3\\uDCC5-\\uDD05\\uDD07-\\uDD0A\\uDD0D-\\uDD14\\uDD16-\\uDD1C\\uDD1E-\\uDD39\\uDD3B-\\uDD3E\\uDD40-\\uDD44\\uDD46\\uDD4A-\\uDD50\\uDD52-\\uDEA5\\uDEA8-\\uDEC0\\uDEC2-\\uDEDA\\uDEDC-\\uDEFA\\uDEFC-\\uDF14\\uDF16-\\uDF34\\uDF36-\\uDF4E\\uDF50-\\uDF6E\\uDF70-\\uDF88\\uDF8A-\\uDFA8\\uDFAA-\\uDFC2\\uDFC4-\\uDFCB]|\\uD83A[\\uDC00-\\uDCC4\\uDD00-\\uDD43]|\\uD83B[\\uDE00-\\uDE03\\uDE05-\\uDE1F\\uDE21\\uDE22\\uDE24\\uDE27\\uDE29-\\uDE32\\uDE34-\\uDE37\\uDE39\\uDE3B\\uDE42\\uDE47\\uDE49\\uDE4B\\uDE4D-\\uDE4F\\uDE51\\uDE52\\uDE54\\uDE57\\uDE59\\uDE5B\\uDE5D\\uDE5F\\uDE61\\uDE62\\uDE64\\uDE67-\\uDE6A\\uDE6C-\\uDE72\\uDE74-\\uDE77\\uDE79-\\uDE7C\\uDE7E\\uDE80-\\uDE89\\uDE8B-\\uDE9B\\uDEA1-\\uDEA3\\uDEA5-\\uDEA9\\uDEAB-\\uDEBB]|\\uD869[\\uDC00-\\uDED6\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF34\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D\\uDC20-\\uDFFF]|\\uD873[\\uDC00-\\uDEA1]|\\uD87E[\\uDC00-\\uDE1D]/,\n  Ltmo: /[\\u01C5\\u01C8\\u01CB\\u01F2\\u1F88-\\u1F8F\\u1F98-\\u1F9F\\u1FA8-\\u1FAF\\u1FBC\\u1FCC\\u1FFC]|[\\u02B0-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0374\\u037A\\u0559\\u0640\\u06E5\\u06E6\\u07F4\\u07F5\\u07FA\\u081A\\u0824\\u0828\\u0971\\u0E46\\u0EC6\\u10FC\\u17D7\\u1843\\u1AA7\\u1C78-\\u1C7D\\u1D2C-\\u1D6A\\u1D78\\u1D9B-\\u1DBF\\u2071\\u207F\\u2090-\\u209C\\u2C7C\\u2C7D\\u2D6F\\u2E2F\\u3005\\u3031-\\u3035\\u303B\\u309D\\u309E\\u30FC-\\u30FE\\uA015\\uA4F8-\\uA4FD\\uA60C\\uA67F\\uA69C\\uA69D\\uA717-\\uA71F\\uA770\\uA788\\uA7F8\\uA7F9\\uA9CF\\uA9E6\\uAA70\\uAADD\\uAAF3\\uAAF4\\uAB5C-\\uAB5F\\uFF70\\uFF9E\\uFF9F]|\\uD81A[\\uDF40-\\uDF43]|\\uD81B[\\uDF93-\\uDF9F\\uDFE0]|[\\xAA\\xBA\\u01BB\\u01C0-\\u01C3\\u0294\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u063F\\u0641-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u0800-\\u0815\\u0840-\\u0858\\u08A0-\\u08B4\\u08B6-\\u08BD\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0972-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0AF9\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58-\\u0C5A\\u0C60\\u0C61\\u0C80\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D54-\\u0D56\\u0D5F-\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E45\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10D0-\\u10FA\\u10FD-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16F1-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17DC\\u1820-\\u1842\\u1844-\\u1877\\u1880-\\u1884\\u1887-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C77\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u2135-\\u2138\\u2D30-\\u2D67\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u3006\\u303C\\u3041-\\u3096\\u309F\\u30A1-\\u30FA\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FD5\\uA000-\\uA014\\uA016-\\uA48C\\uA4D0-\\uA4F7\\uA500-\\uA60B\\uA610-\\uA61F\\uA62A\\uA62B\\uA66E\\uA6A0-\\uA6E5\\uA78F\\uA7F7\\uA7FB-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA8FD\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9E0-\\uA9E4\\uA9E7-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA6F\\uAA71-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB\\uAADC\\uAAE0-\\uAAEA\\uAAF2\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF66-\\uFF6F\\uFF71-\\uFF9D\\uFFA0-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]|\\uD800[\\uDC00-\\uDC0B\\uDC0D-\\uDC26\\uDC28-\\uDC3A\\uDC3C\\uDC3D\\uDC3F-\\uDC4D\\uDC50-\\uDC5D\\uDC80-\\uDCFA\\uDE80-\\uDE9C\\uDEA0-\\uDED0\\uDF00-\\uDF1F\\uDF30-\\uDF40\\uDF42-\\uDF49\\uDF50-\\uDF75\\uDF80-\\uDF9D\\uDFA0-\\uDFC3\\uDFC8-\\uDFCF]|\\uD801[\\uDC50-\\uDC9D\\uDD00-\\uDD27\\uDD30-\\uDD63\\uDE00-\\uDF36\\uDF40-\\uDF55\\uDF60-\\uDF67]|\\uD802[\\uDC00-\\uDC05\\uDC08\\uDC0A-\\uDC35\\uDC37\\uDC38\\uDC3C\\uDC3F-\\uDC55\\uDC60-\\uDC76\\uDC80-\\uDC9E\\uDCE0-\\uDCF2\\uDCF4\\uDCF5\\uDD00-\\uDD15\\uDD20-\\uDD39\\uDD80-\\uDDB7\\uDDBE\\uDDBF\\uDE00\\uDE10-\\uDE13\\uDE15-\\uDE17\\uDE19-\\uDE33\\uDE60-\\uDE7C\\uDE80-\\uDE9C\\uDEC0-\\uDEC7\\uDEC9-\\uDEE4\\uDF00-\\uDF35\\uDF40-\\uDF55\\uDF60-\\uDF72\\uDF80-\\uDF91]|\\uD803[\\uDC00-\\uDC48]|\\uD804[\\uDC03-\\uDC37\\uDC83-\\uDCAF\\uDCD0-\\uDCE8\\uDD03-\\uDD26\\uDD50-\\uDD72\\uDD76\\uDD83-\\uDDB2\\uDDC1-\\uDDC4\\uDDDA\\uDDDC\\uDE00-\\uDE11\\uDE13-\\uDE2B\\uDE80-\\uDE86\\uDE88\\uDE8A-\\uDE8D\\uDE8F-\\uDE9D\\uDE9F-\\uDEA8\\uDEB0-\\uDEDE\\uDF05-\\uDF0C\\uDF0F\\uDF10\\uDF13-\\uDF28\\uDF2A-\\uDF30\\uDF32\\uDF33\\uDF35-\\uDF39\\uDF3D\\uDF50\\uDF5D-\\uDF61]|\\uD805[\\uDC00-\\uDC34\\uDC47-\\uDC4A\\uDC80-\\uDCAF\\uDCC4\\uDCC5\\uDCC7\\uDD80-\\uDDAE\\uDDD8-\\uDDDB\\uDE00-\\uDE2F\\uDE44\\uDE80-\\uDEAA\\uDF00-\\uDF19]|\\uD806[\\uDCFF\\uDEC0-\\uDEF8]|\\uD807[\\uDC00-\\uDC08\\uDC0A-\\uDC2E\\uDC40\\uDC72-\\uDC8F]|\\uD808[\\uDC00-\\uDF99]|\\uD809[\\uDC80-\\uDD43]|[\\uD80C\\uD81C-\\uD820\\uD840-\\uD868\\uD86A-\\uD86C\\uD86F-\\uD872][\\uDC00-\\uDFFF]|\\uD80D[\\uDC00-\\uDC2E]|\\uD811[\\uDC00-\\uDE46]|\\uD81A[\\uDC00-\\uDE38\\uDE40-\\uDE5E\\uDED0-\\uDEED\\uDF00-\\uDF2F\\uDF63-\\uDF77\\uDF7D-\\uDF8F]|\\uD81B[\\uDF00-\\uDF44\\uDF50]|\\uD821[\\uDC00-\\uDFEC]|\\uD822[\\uDC00-\\uDEF2]|\\uD82C[\\uDC00\\uDC01]|\\uD82F[\\uDC00-\\uDC6A\\uDC70-\\uDC7C\\uDC80-\\uDC88\\uDC90-\\uDC99]|\\uD83A[\\uDC00-\\uDCC4]|\\uD83B[\\uDE00-\\uDE03\\uDE05-\\uDE1F\\uDE21\\uDE22\\uDE24\\uDE27\\uDE29-\\uDE32\\uDE34-\\uDE37\\uDE39\\uDE3B\\uDE42\\uDE47\\uDE49\\uDE4B\\uDE4D-\\uDE4F\\uDE51\\uDE52\\uDE54\\uDE57\\uDE59\\uDE5B\\uDE5D\\uDE5F\\uDE61\\uDE62\\uDE64\\uDE67-\\uDE6A\\uDE6C-\\uDE72\\uDE74-\\uDE77\\uDE79-\\uDE7C\\uDE7E\\uDE80-\\uDE89\\uDE8B-\\uDE9B\\uDEA1-\\uDEA3\\uDEA5-\\uDEA9\\uDEAB-\\uDEBB]|\\uD869[\\uDC00-\\uDED6\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF34\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D\\uDC20-\\uDFFF]|\\uD873[\\uDC00-\\uDEA1]|\\uD87E[\\uDC00-\\uDE1D]/\n};\n"]}